Re: [Gimp-developer] EXIF information in JPEG files

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 2002-02-05 at 19:08, Raphael Quinet wrote:
> Hi Lutz!
> 
> On Tue, 5 Feb 2002, Lutz Müller wrote:
>  > PS: It would be nice if this mailing list program could automatically cc
>  > replies to anyone sending mails to this list while not being subscribed
>  > (like me).
> 
> Does this mean that you have not seen the two replies that I posted
> yesterday, and the discussion today between Dave Neary and myself?

Just read it on the web. As I don't have gtk-1.3 and greater available
on my system, I won't be able to contribute anything right now.

In case you are interested in a proof of concept of the alternative "1
big EXIF parasite":

Attached are diffs against gimp-1.2.2:
 - configure.in (adding an opt. dependency to libexif-gtk)
 - acconfig.h (#undef HAVE_EXIF)
 - plug-ins/common/Makefile.am (EXIF_LIBS, EXIF_CFLAGS)
 - plug-ins/common/jpeg.c (some lines of code)

Apply them and you will be able to edit EXIF data when the JPEG format
chooser will pop up after selecting a filename. In addition, EXIF
information will not get lost if you open a JPEG file and save it again
as JPEG.

If you define how parts of the EXIF information should be stored in
individual parasites so that they are accessible to other plug-ins, I
can easily write an importer/exporter (EXIF data <-> GIMP format).
However, I think the user should still have the possibility to add/edit
EXIF tags that are not handled by those individual parasites.

Lutz
-- 
+------------------------------------------+      \|||/
| Lutz Müller            +49 (7156) 34837  |      (o o)
|                                          +---ooO-(_)-Ooo---+
| Hans-Sachs-Strasse 5                                       |
| 71254 Ditzingen        http://www.topfrose.de              |
| Germany                lutz@xxxxxxxxxxxxxxxxxxxxx          |
+------------------------------------------------------------+
--- configure.in.orig	Tue Feb  5 23:19:52 2002
+++ configure.in	Tue Feb  5 23:24:56 2002
@@ -643,7 +643,38 @@ dnl fi
 dnl AC_SUBST(PYGIMP_CFLAGS_NOUI)
 dnl AC_SUBST(PYGIMP_LIBS_NOUI)
 dnl AM_CONDITIONAL(BUILD_PYTHON, $build_python)
-  
+
+dnl ---------------------------------------------------------------------------
+dnl libexif-gtk: JPEG files can contain EXIF data. If libexif-gtk is installed
+dnl              on the system, gimp can use it to read this data from 
+dnl              JPEG files and save it (if the file is saved again in
+dnl              the JPEG format). In addition, gimp can offer the user the
+dnl              possibility to edit (!) EXIF data.
+dnl ---------------------------------------------------------------------------
+exif_msg="no (http://www.sourceforge.net/projects/libexif)"
+try_exif=true
+AC_ARG_WITH(exif, [  --without-exif          Don't use libexif],[
+	if test x$withval = xno; then
+		try_exif=false
+	fi])
+if $try_exif; then
+	AC_PATH_PROG(PKG_CONFIG,pkg-config)
+	if test -n "${PKG_CONFIG}"; then
+		AC_MSG_CHECKING([for libexif-gtk])
+		if ${PKG_CONFIG} --exists libexif-gtk > /dev/null 2>&1; then
+			EXIF_CFLAGS=`$PKG_CONFIG --cflags libexif-gtk`
+			EXIF_LIBS=`$PKG_CONFIG --libs libexif-gtk`
+			exif_msg=yes
+			AC_DEFINE(HAVE_EXIF)
+			fi
+		AC_MSG_RESULT($exif_msg)
+	else
+		AC_WARN([Not searching for libexif - pkg-config not found.])
+	fi
+fi
+AC_SUBST(EXIF_CFLAGS)
+AC_SUBST(EXIF_LIBS)
+
 
 GIMPINSTALL=
 if test "$INSTALL" = "$ac_install_sh"; then
--- acconfig.h.orig	Tue Feb  5 23:29:29 2002
+++ acconfig.h	Tue Feb  5 23:08:46 2002
@@ -19,6 +19,7 @@
 #undef HAVE_CATGETS
 #undef HAVE_DIRENT_H
 #undef HAVE_DOPRNT
+#undef HAVE_EXIF
 #undef HAVE_FINITE
 #undef HAVE_GETTEXT
 #undef HAVE_IPC_H
--- Makefile.am.orig	Tue Feb  5 23:30:17 2002
+++ Makefile.am	Tue Feb  5 23:18:09 2002
@@ -15,6 +15,7 @@ INCLUDES = \
 	-I$(top_srcdir)		\
 	-I$(top_srcdir)/intl	\
 	$(GTK_CFLAGS)		\
+	$(EXIF_CFLAGS)		\
 	-I$(includedir)
 
 libexec_PROGRAMS = \
@@ -722,6 +723,7 @@ jpeg_LDADD = \
 	$(top_builddir)/libgimp/libgimpui.la	\
 	$(top_builddir)/libgimp/libgimp.la	\
 	$(LIBJPEG)				\
+	$(EXIF_LIBS)				\
 	$(GTK_LIBS)				\
 	$(INTLLIBS)
 
--- jpeg.c.orig	Tue Feb  5 23:06:55 2002
+++ jpeg.c	Tue Feb  5 23:08:13 2002
@@ -138,6 +138,10 @@
 #include <jpeglib.h>
 #include <jerror.h>
 
+#ifdef HAVE_EXIF
+#include <libexif-gtk/gtk-exif-browser.h>
+#endif
+
 #include <libgimp/gimp.h>
 #include <libgimp/gimpui.h>
 
@@ -273,6 +277,9 @@ static JpegSaveInterface jsint =
 static gchar     *image_comment         = NULL;
 static GtkWidget *restart_markers_scale = NULL;
 static GtkWidget *restart_markers_label = NULL;
+#ifdef HAVE_EXIF
+static ExifData  *exif_data = NULL;
+#endif
 
 
 MAIN ()
@@ -424,6 +431,10 @@ run (gchar      *name,
 	default:
 	  break;
 	}
+#ifdef HAVE_EXIF
+      exif_data_unref (exif_data);
+      exif_data = NULL;
+#endif
       
       g_free (image_comment);
       image_comment = NULL;
@@ -435,6 +446,14 @@ run (gchar      *name,
 	  image_comment = g_strdup (parasite->data);
 	  gimp_parasite_free (parasite);
 	}
+#ifdef HAVE_EXIF
+      parasite = gimp_image_parasite_find (orig_image_ID, "exif-data");
+      if (parasite)
+	{
+          exif_data = exif_data_new_from_data (parasite->data, parasite->size);
+          gimp_parasite_free (parasite);
+	}
+#endif /* HAVE_EXIF */
 #endif /* GIMP_HAVE_PARASITES */
       if (!image_comment) 
 	image_comment = g_strdup (DEFAULT_COMMENT);
@@ -722,6 +741,12 @@ load_image (gchar           *filename, 
   JpegSaveVals local_save_vals;
   GimpParasite * volatile comment_parasite = NULL;
   GimpParasite * volatile vals_parasite    = NULL;
+#ifdef HAVE_EXIF
+  GimpParasite * exif_parasite = NULL;
+  ExifData *exif_data = NULL;
+  unsigned char *exif_buf = NULL;
+  unsigned int exif_buf_len = 0;
+#endif
 #endif /* GIMP_HAVE_PARASITES */
 
   /* We set up the normal JPEG error routines. */
@@ -1057,6 +1082,19 @@ load_image (gchar           *filename, 
 	  gimp_parasite_free (vals_parasite);
 	}   
     }
+#ifdef HAVE_EXIF
+  exif_data = exif_data_new_from_file (filename);
+  if (exif_data)
+    {
+      exif_data_save_data (exif_data, &exif_buf, &exif_buf_len);
+      exif_data_unref (exif_data);
+      exif_parasite = gimp_parasite_new ("exif-data", GIMP_PARASITE_PERSISTENT,
+				         exif_buf_len, exif_buf);
+      g_free (exif_buf);
+      gimp_image_parasite_attach (image_ID, exif_parasite);
+      gimp_parasite_free (exif_parasite);
+    }
+#endif
 #endif /* GIMP_HAVE_PARASITES */
 
   return image_ID;
@@ -1186,6 +1224,10 @@ save_image (gchar    *filename,
   gboolean  has_alpha;
   gint      rowstride, yend;
   gint      i, j;
+#ifdef HAVE_EXIF
+  unsigned char *exif_buf;
+  unsigned int   exif_buf_len;
+#endif
 
   drawable = gimp_drawable_get (drawable_ID);
   drawable_type = gimp_drawable_type (drawable_ID);
@@ -1391,6 +1433,15 @@ save_image (gchar    *filename,
    */
   jpeg_start_compress (&cinfo, TRUE);
 
+#ifdef HAVE_EXIF
+  if (exif_data)
+    {
+      exif_data_save_data (exif_data, &exif_buf, &exif_buf_len);
+      jpeg_write_marker (&cinfo, 0xe1, exif_buf, exif_buf_len);
+      g_free (exif_buf);
+    }
+#endif
+
   /* Step 4.1: Write the comment out - pw */
   if (image_comment && *image_comment)
     {
@@ -1562,12 +1613,14 @@ save_dialog (void)
   GtkWidget *dlg;
   GtkWidget *vbox;
   GtkWidget *main_vbox;
+  GtkWidget *exif_vbox;
   GtkWidget *label;
   GtkWidget *scale;
   GtkWidget *frame;
   GtkWidget *table;
   GtkWidget *toggle;
   GtkWidget *abox;
+  GtkWidget *notebook;
   GtkObject *scale_data;
 
   GtkWidget *progressive;
@@ -1583,6 +1636,7 @@ save_dialog (void)
   GtkWidget *com_frame;
   GtkWidget *com_table;
   GtkWidget *vscrollbar;
+  GtkWidget *browser;
   
   GtkWidget *prv_frame;
   GimpImageType dtype;
@@ -1603,11 +1657,36 @@ save_dialog (void)
 		      GTK_SIGNAL_FUNC (save_close_callback),
 		      NULL);
 
-  main_vbox = gtk_vbox_new (FALSE, 4);
-  gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 6);
-  gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dlg)->vbox), main_vbox,
+  notebook = gtk_notebook_new ();
+  gtk_container_set_border_width (GTK_CONTAINER (notebook), 6);
+  gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dlg)->vbox), notebook,
 		      TRUE, TRUE, 0);
+  gtk_widget_show (notebook);
+
+  main_vbox = gtk_vbox_new (FALSE, 4);
+  gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 3);
+  label = gtk_label_new (_("JPEG Settings"));
+  gtk_notebook_append_page (GTK_NOTEBOOK (notebook), main_vbox, label);
   gtk_widget_show (main_vbox);
+  gtk_widget_show (label);
+
+  exif_vbox = gtk_vbox_new (FALSE, 4);
+  gtk_container_set_border_width (GTK_CONTAINER (exif_vbox), 3);
+  label = gtk_label_new (_("EXIF Data"));
+  gtk_notebook_append_page (GTK_NOTEBOOK (notebook), exif_vbox, label);
+  gtk_widget_show (exif_vbox);
+  gtk_widget_show (label);
+
+#ifdef HAVE_EXIF
+  browser = gtk_exif_browser_new ();
+  if (!exif_data)
+    exif_data = exif_data_new ();
+  gtk_exif_browser_set_data (GTK_EXIF_BROWSER (browser), exif_data);
+#else
+  browser = gtk_label_new (_("No EXIF support available."));
+#endif
+  gtk_box_pack_start (GTK_BOX (exif_vbox), browser, TRUE, TRUE, 0);
+  gtk_widget_show (browser);
 
   /* sg - preview */
   prv_frame = gtk_frame_new (_("Image Preview"));

Attachment: signature.asc
Description: This is a digitally signed message part


[Index of Archives]     [Video For Linux]     [Photo]     [Yosemite News]     [gtk]     [GIMP for Windows]     [KDE]     [GEGL]     [Gimp's Home]     [Gimp on GUI]     [Gimp on Windows]     [Steve's Art]

  Powered by Linux