Use Imlib2 to load images
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
9f72e70089
commit
de5d82b8c2
|
@ -107,7 +107,7 @@ AWESOME_CFLAGS = -std=gnu99 -pipe \
|
||||||
-Wunused -Winit-self -Wpointer-arith -Wredundant-decls \
|
-Wunused -Winit-self -Wpointer-arith -Wredundant-decls \
|
||||||
-Wmissing-prototypes -Wmissing-format-attribute -Wmissing-noreturn
|
-Wmissing-prototypes -Wmissing-format-attribute -Wmissing-noreturn
|
||||||
endif
|
endif
|
||||||
AM_CPPFLAGS = $(X_CFLAGS) $(PANGOCAIRO_CFLAGS) $(CONFUSE_CFLAGS) $(XRANDR_CFLAGS) $(XINERAMA_CFLAGS) $(AWESOME_CFLAGS)
|
AM_CPPFLAGS = $(X_CFLAGS) $(PANGOCAIRO_CFLAGS) $(CONFUSE_CFLAGS) $(XRANDR_CFLAGS) $(XINERAMA_CFLAGS) $(AWESOME_CFLAGS) $(imlib2_CFLAGS)
|
||||||
|
|
||||||
bin_PROGRAMS += awesome
|
bin_PROGRAMS += awesome
|
||||||
awesome_SOURCES = \
|
awesome_SOURCES = \
|
||||||
|
@ -140,7 +140,7 @@ awesome_SOURCES = \
|
||||||
ewmh.c ewmh.h
|
ewmh.c ewmh.h
|
||||||
awesome_SOURCES += $(LAYOUTS)
|
awesome_SOURCES += $(LAYOUTS)
|
||||||
awesome_SOURCES += $(WIDGETS)
|
awesome_SOURCES += $(WIDGETS)
|
||||||
awesome_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XRANDR_LIBS) $(XINERAMA_LIBS)
|
awesome_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XRANDR_LIBS) $(XINERAMA_LIBS) $(imlib2_LIBS)
|
||||||
|
|
||||||
bin_PROGRAMS += awesome-client
|
bin_PROGRAMS += awesome-client
|
||||||
awesome_client_SOURCES = \
|
awesome_client_SOURCES = \
|
||||||
|
@ -159,7 +159,7 @@ awesome_message_SOURCES = \
|
||||||
common/xscreen.h common/xscreen.c \
|
common/xscreen.h common/xscreen.c \
|
||||||
awesome-message.c
|
awesome-message.c
|
||||||
|
|
||||||
awesome_message_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XINERAMA_LIBS)
|
awesome_message_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XINERAMA_LIBS) $(imlib2_LIBS)
|
||||||
|
|
||||||
bin_PROGRAMS += awesome-menu
|
bin_PROGRAMS += awesome-menu
|
||||||
awesome_menu_SOURCES = \
|
awesome_menu_SOURCES = \
|
||||||
|
@ -171,7 +171,7 @@ awesome_menu_SOURCES = \
|
||||||
common/xutil.h common/xutil.c \
|
common/xutil.h common/xutil.c \
|
||||||
awesome-menu.c
|
awesome-menu.c
|
||||||
|
|
||||||
awesome_menu_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XINERAMA_LIBS)
|
awesome_menu_LDADD = $(X_LIBS) $(PANGOCAIRO_LIBS) $(CONFUSE_LIBS) $(XINERAMA_LIBS) $(imlib2_LIBS)
|
||||||
|
|
||||||
if HAVE_XMLTO
|
if HAVE_XMLTO
|
||||||
if HAVE_ASCIIDOC
|
if HAVE_ASCIIDOC
|
||||||
|
|
122
common/draw.c
122
common/draw.c
|
@ -19,8 +19,8 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cairo.h>
|
|
||||||
#include <cairo-xlib.h>
|
#include <cairo-xlib.h>
|
||||||
|
#include <Imlib2.h>
|
||||||
|
|
||||||
#include <langinfo.h>
|
#include <langinfo.h>
|
||||||
#include <iconv.h>
|
#include <iconv.h>
|
||||||
|
@ -593,6 +593,46 @@ void draw_image_from_argb_data(DrawCtx *ctx, int x, int y, int w, int h,
|
||||||
cairo_surface_destroy(source);
|
cairo_surface_destroy(source);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
draw_imlib_load_strerror(Imlib_Load_Error e)
|
||||||
|
{
|
||||||
|
switch(e)
|
||||||
|
{
|
||||||
|
case IMLIB_LOAD_ERROR_FILE_DOES_NOT_EXIST:
|
||||||
|
return "no such file or directory";
|
||||||
|
case IMLIB_LOAD_ERROR_FILE_IS_DIRECTORY:
|
||||||
|
return "file is a directory";
|
||||||
|
case IMLIB_LOAD_ERROR_PERMISSION_DENIED_TO_READ:
|
||||||
|
return "read permission denied";
|
||||||
|
case IMLIB_LOAD_ERROR_NO_LOADER_FOR_FILE_FORMAT:
|
||||||
|
return "no loader for file format";
|
||||||
|
case IMLIB_LOAD_ERROR_PATH_TOO_LONG:
|
||||||
|
return "path too long";
|
||||||
|
case IMLIB_LOAD_ERROR_PATH_COMPONENT_NON_EXISTANT:
|
||||||
|
return "path component non existant";
|
||||||
|
case IMLIB_LOAD_ERROR_PATH_COMPONENT_NOT_DIRECTORY:
|
||||||
|
return "path compoment not a directory";
|
||||||
|
case IMLIB_LOAD_ERROR_PATH_POINTS_OUTSIDE_ADDRESS_SPACE:
|
||||||
|
return "path points oustide address space";
|
||||||
|
case IMLIB_LOAD_ERROR_TOO_MANY_SYMBOLIC_LINKS:
|
||||||
|
return "too many symbolic links";
|
||||||
|
case IMLIB_LOAD_ERROR_OUT_OF_MEMORY:
|
||||||
|
return "out of memory";
|
||||||
|
case IMLIB_LOAD_ERROR_OUT_OF_FILE_DESCRIPTORS:
|
||||||
|
return "out of file descriptors";
|
||||||
|
case IMLIB_LOAD_ERROR_PERMISSION_DENIED_TO_WRITE:
|
||||||
|
return "write permission denied";
|
||||||
|
case IMLIB_LOAD_ERROR_OUT_OF_DISK_SPACE:
|
||||||
|
return "out of disk space";
|
||||||
|
case IMLIB_LOAD_ERROR_UNKNOWN:
|
||||||
|
return "unknown error, that's really bad";
|
||||||
|
case IMLIB_LOAD_ERROR_NONE:
|
||||||
|
return "no error, oops";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "unknown error";
|
||||||
|
}
|
||||||
|
|
||||||
/** Draw an image (PNG format only) from a file to a draw context
|
/** Draw an image (PNG format only) from a file to a draw context
|
||||||
* \param ctx Draw context to draw to
|
* \param ctx Draw context to draw to
|
||||||
* \param x x coordinate
|
* \param x x coordinate
|
||||||
|
@ -603,35 +643,45 @@ void draw_image_from_argb_data(DrawCtx *ctx, int x, int y, int w, int h,
|
||||||
void
|
void
|
||||||
draw_image(DrawCtx *ctx, int x, int y, int wanted_h, const char *filename)
|
draw_image(DrawCtx *ctx, int x, int y, int wanted_h, const char *filename)
|
||||||
{
|
{
|
||||||
double ratio;
|
int w, h, size;
|
||||||
int h;
|
DATA32 *data;
|
||||||
cairo_surface_t *source;
|
unsigned char *dataimg;
|
||||||
cairo_t *cr;
|
Imlib_Image image;
|
||||||
cairo_status_t cairo_st;
|
Imlib_Load_Error e = IMLIB_LOAD_ERROR_NONE;
|
||||||
|
|
||||||
source = cairo_image_surface_create_from_png(filename);
|
if(!(image = imlib_load_image_with_error_return(filename, &e)))
|
||||||
if((cairo_st = cairo_surface_status(source)))
|
return warn("cannot load image %s: %s\n", filename, draw_imlib_load_strerror(e));
|
||||||
|
|
||||||
|
imlib_context_set_image(image);
|
||||||
|
h = imlib_image_get_height();
|
||||||
|
w = imlib_image_get_width();
|
||||||
|
|
||||||
|
size = w * h;
|
||||||
|
|
||||||
|
data = imlib_image_get_data_for_reading_only();
|
||||||
|
|
||||||
|
dataimg = p_new(unsigned char, size * 4);
|
||||||
|
|
||||||
|
memcpy(dataimg, data, size * 4);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* Alternate method */
|
||||||
|
for(i = 0; i < size; i++, dataimg += 4)
|
||||||
{
|
{
|
||||||
warn("failed to draw image %s: %s\n", filename, cairo_status_to_string(cairo_st));
|
dataimg[3] = (data[i] >> 24) & 0xff; /* A */
|
||||||
cairo_surface_destroy(source);
|
dataimg[2] = (data[i] >> 16) & 0xff; /* R */
|
||||||
return;
|
dataimg[1] = (data[i] >> 8) & 0xff; /* G */
|
||||||
|
dataimg[0] = data[i] & 0xff; /* B */
|
||||||
}
|
}
|
||||||
cr = cairo_create (ctx->surface);
|
#endif
|
||||||
if(wanted_h > 0 && (h = cairo_image_surface_get_height(source)) > 0)
|
|
||||||
{
|
|
||||||
ratio = (double) wanted_h / (double) h;
|
|
||||||
cairo_scale(cr, ratio, ratio);
|
|
||||||
cairo_set_source_surface(cr, source, x / ratio, y / ratio);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
cairo_set_source_surface(cr, source, x, y);
|
|
||||||
cairo_paint(cr);
|
|
||||||
|
|
||||||
cairo_destroy(cr);
|
draw_image_from_argb_data(ctx, x, y, w, h, wanted_h, dataimg);
|
||||||
cairo_surface_destroy(source);
|
|
||||||
|
imlib_free_image();
|
||||||
|
p_delete(&dataimg);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get an imag size (PNG format only)
|
/** Get an image size
|
||||||
* \param filename file name
|
* \param filename file name
|
||||||
* \return area_t structure with width and height set to image size
|
* \return area_t structure with width and height set to image size
|
||||||
*/
|
*/
|
||||||
|
@ -639,22 +689,20 @@ area_t
|
||||||
draw_get_image_size(const char *filename)
|
draw_get_image_size(const char *filename)
|
||||||
{
|
{
|
||||||
area_t size = { -1, -1, -1, -1, NULL, NULL };
|
area_t size = { -1, -1, -1, -1, NULL, NULL };
|
||||||
cairo_surface_t *surface;
|
Imlib_Image image;
|
||||||
cairo_status_t cairo_st;
|
Imlib_Load_Error e = IMLIB_LOAD_ERROR_NONE;
|
||||||
|
|
||||||
surface = cairo_image_surface_create_from_png(filename);
|
if((image = imlib_load_image_with_error_return(filename, &e)))
|
||||||
if((cairo_st = cairo_surface_status(surface)))
|
|
||||||
warn("failed to get image size %s: %s\n", filename, cairo_status_to_string(cairo_st));
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
cairo_image_surface_get_width(surface);
|
imlib_context_set_image(image);
|
||||||
size.x = 0;
|
|
||||||
size.y = 0;
|
|
||||||
size.width = cairo_image_surface_get_width(surface);
|
|
||||||
size.height = cairo_image_surface_get_height(surface);
|
|
||||||
}
|
|
||||||
|
|
||||||
cairo_surface_destroy(surface);
|
size.width = imlib_image_get_width();
|
||||||
|
size.height = imlib_image_get_height();
|
||||||
|
|
||||||
|
imlib_free_image();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
warn("cannot load image %s: %s\n", filename, draw_imlib_load_strerror(e));
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
|
@ -114,6 +114,8 @@ PKG_CHECK_MODULES([XINERAMA], [xinerama],,
|
||||||
[AC_MSG_ERROR([awesome requires Xinerama.])])
|
[AC_MSG_ERROR([awesome requires Xinerama.])])
|
||||||
PKG_CHECK_MODULES([XRANDR], [xrandr],,
|
PKG_CHECK_MODULES([XRANDR], [xrandr],,
|
||||||
[AC_MSG_ERROR([awesome requires Xrandr.])])
|
[AC_MSG_ERROR([awesome requires Xrandr.])])
|
||||||
|
PKG_CHECK_MODULES([imlib2], [imlib2],,
|
||||||
|
[AC_MSG_ERROR([awesome requires Imbli2.])])
|
||||||
|
|
||||||
# Checks for header files.
|
# Checks for header files.
|
||||||
AC_PATH_X
|
AC_PATH_X
|
||||||
|
|
Loading…
Reference in New Issue