Add gdk-pixbuf support
When imaging support is required, we prefer to use gdk-pixbuf, as it's already on things like Live CDs. Also fix the examples building against the system libfprint.
This commit is contained in:
parent
911c6bf102
commit
014b933b2b
4 changed files with 123 additions and 15 deletions
30
configure.ac
30
configure.ac
|
@ -21,7 +21,7 @@ AC_SUBST(lt_age)
|
||||||
|
|
||||||
all_drivers="upekts upektc upeksonly vcom5s uru4000 fdu2000 aes1610 aes2501 aes4000"
|
all_drivers="upekts upektc upeksonly vcom5s uru4000 fdu2000 aes1610 aes2501 aes4000"
|
||||||
|
|
||||||
require_imagemagick='no'
|
require_imaging='no'
|
||||||
require_aeslib='no'
|
require_aeslib='no'
|
||||||
enable_upekts='no'
|
enable_upekts='no'
|
||||||
enable_upektc='no'
|
enable_upektc='no'
|
||||||
|
@ -77,7 +77,7 @@ for driver in `echo ${drivers} | sed -e 's/,/ /g' -e 's/,$//g'`; do
|
||||||
aes4000)
|
aes4000)
|
||||||
AC_DEFINE([ENABLE_AES4000], [], [Build AuthenTec AES4000 driver])
|
AC_DEFINE([ENABLE_AES4000], [], [Build AuthenTec AES4000 driver])
|
||||||
require_aeslib="yes"
|
require_aeslib="yes"
|
||||||
require_imagemagick="yes"
|
require_imaging="yes"
|
||||||
enable_aes4000="yes"
|
enable_aes4000="yes"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
@ -92,7 +92,6 @@ AM_CONDITIONAL([ENABLE_URU4000], [test "$enable_uru4000" != "no"])
|
||||||
#AM_CONDITIONAL([ENABLE_AES1610], [test "$enable_aes1610" != "no"])
|
#AM_CONDITIONAL([ENABLE_AES1610], [test "$enable_aes1610" != "no"])
|
||||||
AM_CONDITIONAL([ENABLE_AES2501], [test "$enable_aes2501" != "no"])
|
AM_CONDITIONAL([ENABLE_AES2501], [test "$enable_aes2501" != "no"])
|
||||||
AM_CONDITIONAL([ENABLE_AES4000], [test "$enable_aes4000" != "no"])
|
AM_CONDITIONAL([ENABLE_AES4000], [test "$enable_aes4000" != "no"])
|
||||||
AM_CONDITIONAL([REQUIRE_IMAGEMAGICK], [test "$require_imagemagick" != "no"])
|
|
||||||
AM_CONDITIONAL([REQUIRE_AESLIB], [test "$require_aeslib" != "no"])
|
AM_CONDITIONAL([REQUIRE_AESLIB], [test "$require_aeslib" != "no"])
|
||||||
|
|
||||||
|
|
||||||
|
@ -109,11 +108,26 @@ PKG_CHECK_MODULES(GLIB, "glib-2.0")
|
||||||
AC_SUBST(GLIB_CFLAGS)
|
AC_SUBST(GLIB_CFLAGS)
|
||||||
AC_SUBST(GLIB_LIBS)
|
AC_SUBST(GLIB_LIBS)
|
||||||
|
|
||||||
if test "$require_imagemagick" != "no"; then
|
imagemagick_found=no
|
||||||
PKG_CHECK_MODULES(IMAGEMAGICK, "ImageMagick")
|
gdkpixbuf_found=no
|
||||||
AC_SUBST(IMAGEMAGICK_CFLAGS)
|
|
||||||
AC_SUBST(IMAGEMAGICK_LIBS)
|
if test "$require_imaging" != "no"; then
|
||||||
fi;
|
PKG_CHECK_MODULES(IMAGING, gthread-2.0 gdk-pixbuf-2.0, [gdkpixbuf_found=yes], [gdkpixbuf_found=no])
|
||||||
|
if test "$gdkpixbuf_found" != "yes"; then
|
||||||
|
PKG_CHECK_MODULES(IMAGING, ImageMagick, [imagemagick_found=yes], [imagemagick_found=no])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$require_imaging" != "no"; then
|
||||||
|
if test "$gdkpixbuf_found" != "yes" && test "$imagemagick_found" != "yes"; then
|
||||||
|
AC_MSG_ERROR([gdk-pixbuf or ImageMagick is required for imaging support])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
AM_CONDITIONAL([REQUIRE_GDKPIXBUF], [test "$gdkpixbuf_found" != "no"])
|
||||||
|
AM_CONDITIONAL([REQUIRE_IMAGEMAGICK], [test "$imagemagick_found" != "no"])
|
||||||
|
AC_SUBST(IMAGING_CFLAGS)
|
||||||
|
AC_SUBST(IMAGING_LIBS)
|
||||||
|
|
||||||
# Examples build
|
# Examples build
|
||||||
AC_ARG_ENABLE([examples-build], [AS_HELP_STRING([--enable-examples-build],
|
AC_ARG_ENABLE([examples-build], [AS_HELP_STRING([--enable-examples-build],
|
||||||
|
|
|
@ -2,22 +2,22 @@ INCLUDES = -I$(top_srcdir)
|
||||||
noinst_PROGRAMS = verify_live enroll verify img_capture
|
noinst_PROGRAMS = verify_live enroll verify img_capture
|
||||||
|
|
||||||
verify_live_SOURCES = verify_live.c
|
verify_live_SOURCES = verify_live.c
|
||||||
verify_live_LDADD = ../libfprint/libfprint.la -lfprint
|
verify_live_LDADD = ../libfprint/libfprint.la
|
||||||
|
|
||||||
enroll_SOURCES = enroll.c
|
enroll_SOURCES = enroll.c
|
||||||
enroll_LDADD = ../libfprint/libfprint.la -lfprint
|
enroll_LDADD = ../libfprint/libfprint.la
|
||||||
|
|
||||||
verify_SOURCES = verify.c
|
verify_SOURCES = verify.c
|
||||||
verify_LDADD = ../libfprint/libfprint.la -lfprint
|
verify_LDADD = ../libfprint/libfprint.la
|
||||||
|
|
||||||
img_capture_SOURCES = img_capture.c
|
img_capture_SOURCES = img_capture.c
|
||||||
img_capture_LDADD = ../libfprint/libfprint.la -lfprint
|
img_capture_LDADD = ../libfprint/libfprint.la
|
||||||
|
|
||||||
if BUILD_X11_EXAMPLES
|
if BUILD_X11_EXAMPLES
|
||||||
noinst_PROGRAMS += img_capture_continuous
|
noinst_PROGRAMS += img_capture_continuous
|
||||||
|
|
||||||
img_capture_continuous_CFLAGS = $(X_CFLAGS) $(XV_CFLAGS)
|
img_capture_continuous_CFLAGS = $(X_CFLAGS) $(XV_CFLAGS)
|
||||||
img_capture_continuous_SOURCES = img_capture_continuous.c
|
img_capture_continuous_SOURCES = img_capture_continuous.c
|
||||||
img_capture_continuous_LDADD = ../libfprint/libfprint.la -lfprint $(X_LIBS) $(X_PRE_LIBS) $(XV_LIBS) -lX11 $(X_EXTRA_LIBS);
|
img_capture_continuous_LDADD = ../libfprint/libfprint.la $(X_LIBS) $(X_PRE_LIBS) $(XV_LIBS) -lX11 $(X_EXTRA_LIBS);
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
@ -105,8 +105,14 @@ endif
|
||||||
|
|
||||||
if REQUIRE_IMAGEMAGICK
|
if REQUIRE_IMAGEMAGICK
|
||||||
OTHER_SRC += imagemagick.c
|
OTHER_SRC += imagemagick.c
|
||||||
libfprint_la_CFLAGS += $(IMAGEMAGICK_CFLAGS)
|
libfprint_la_CFLAGS += $(IMAGING_CFLAGS)
|
||||||
libfprint_la_LIBADD += $(IMAGEMAGICK_LIBS)
|
libfprint_la_LIBADD += $(IMAGING_LIBS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if REQUIRE_GDKPIXBUF
|
||||||
|
OTHER_SRC += gdkpixbuf.c
|
||||||
|
libfprint_la_CFLAGS += $(IMAGING_CFLAGS)
|
||||||
|
libfprint_la_LIBADD += $(IMAGING_LIBS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if REQUIRE_AESLIB
|
if REQUIRE_AESLIB
|
||||||
|
|
88
libfprint/gdkpixbuf.c
Normal file
88
libfprint/gdkpixbuf.c
Normal file
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* Imaging utility functions for libfprint
|
||||||
|
* Copyright (C) 2007-2008 Daniel Drake <dsd@gentoo.org>
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <gdk-pixbuf/gdk-pixbuf.h>
|
||||||
|
|
||||||
|
#include "fp_internal.h"
|
||||||
|
|
||||||
|
struct fp_img *fpi_im_resize(struct fp_img *img, unsigned int factor)
|
||||||
|
{
|
||||||
|
int new_width = img->width * factor;
|
||||||
|
int new_height = img->height * factor;
|
||||||
|
GdkPixbuf *orig, *resized;
|
||||||
|
struct fp_img *newimg;
|
||||||
|
guchar *pixels;
|
||||||
|
guint y;
|
||||||
|
int rowstride;
|
||||||
|
|
||||||
|
g_type_init ();
|
||||||
|
|
||||||
|
/* It is possible to implement resizing using a simple algorithm, however
|
||||||
|
* we use gdk-pixbuf because it applies some kind of smoothing to the
|
||||||
|
* result, which improves matching performances in my experiments. */
|
||||||
|
|
||||||
|
/* Create the original pixbuf, and fill it in from the grayscale data */
|
||||||
|
orig = gdk_pixbuf_new (GDK_COLORSPACE_RGB,
|
||||||
|
FALSE,
|
||||||
|
8,
|
||||||
|
img->width,
|
||||||
|
img->height);
|
||||||
|
rowstride = gdk_pixbuf_get_rowstride (orig);
|
||||||
|
pixels = gdk_pixbuf_get_pixels (orig);
|
||||||
|
for (y = 0; y < img->height; y++) {
|
||||||
|
guint x;
|
||||||
|
for (x = 0; x < img->width; x++) {
|
||||||
|
guchar *p, *r;
|
||||||
|
|
||||||
|
p = pixels + y * rowstride + x * 3;
|
||||||
|
r = img->data + y * img->width + x;
|
||||||
|
p[0] = r[0];
|
||||||
|
p[1] = r[0];
|
||||||
|
p[2] = r[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Resize the pixbuf, and create the new fp_img */
|
||||||
|
resized = gdk_pixbuf_scale_simple (orig, new_width, new_height, GDK_INTERP_HYPER);
|
||||||
|
g_object_unref (orig);
|
||||||
|
|
||||||
|
newimg = fpi_img_new(new_width * new_height);
|
||||||
|
newimg->width = new_width;
|
||||||
|
newimg->height = new_height;
|
||||||
|
newimg->flags = img->flags;
|
||||||
|
|
||||||
|
rowstride = gdk_pixbuf_get_rowstride (resized);
|
||||||
|
pixels = gdk_pixbuf_get_pixels (resized);
|
||||||
|
for (y = 0; y < newimg->height; y++) {
|
||||||
|
guint x;
|
||||||
|
for (x = 0; x < newimg->width; x++) {
|
||||||
|
guchar *p, *r;
|
||||||
|
|
||||||
|
r = img->data + y * img->width + x;
|
||||||
|
p = pixels + y * rowstride + x * 3;
|
||||||
|
r[0] = p[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref (resized);
|
||||||
|
|
||||||
|
return newimg;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue