awful.completion: callback functions return table of matches
[awesome.git] / image.c
blobec8b9adea1c9c5bf1603edc5c30082ef92e6d680
1 /*
2 * image.c - image object
4 * Copyright © 2008-2009 Julien Danjou <julien@danjou.info>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #include <xcb/xcb_image.h>
24 #include <Imlib2.h>
26 #include "globalconf.h"
27 #include "config.h"
28 #include "luaa.h"
29 #include "common/luaobject.h"
31 struct image
33 LUA_OBJECT_HEADER
34 /** Imlib2 image */
35 Imlib_Image image;
36 /** Image data */
37 uint8_t *data;
38 /** Flag telling if the image is up to date or needs computing before
39 * drawing */
40 bool isupdated;
43 LUA_OBJECT_FUNCS(image_class, image_t, image)
45 static int
46 luaA_image_gc(lua_State *L)
48 image_t *p = luaA_checkudata(L, 1, &image_class);
49 imlib_context_set_image(p->image);
50 imlib_free_image();
51 p_delete(&p->data);
52 return luaA_object_gc(L);
55 static const char *
56 image_imlib_load_strerror(Imlib_Load_Error e)
58 switch(e)
60 case IMLIB_LOAD_ERROR_FILE_DOES_NOT_EXIST:
61 return "no such file or directory";
62 case IMLIB_LOAD_ERROR_FILE_IS_DIRECTORY:
63 return "file is a directory";
64 case IMLIB_LOAD_ERROR_PERMISSION_DENIED_TO_READ:
65 return "read permission denied";
66 case IMLIB_LOAD_ERROR_NO_LOADER_FOR_FILE_FORMAT:
67 return "no loader for file format";
68 case IMLIB_LOAD_ERROR_PATH_TOO_LONG:
69 return "path too long";
70 case IMLIB_LOAD_ERROR_PATH_COMPONENT_NON_EXISTANT:
71 return "path component non existent";
72 case IMLIB_LOAD_ERROR_PATH_COMPONENT_NOT_DIRECTORY:
73 return "path component not a directory";
74 case IMLIB_LOAD_ERROR_PATH_POINTS_OUTSIDE_ADDRESS_SPACE:
75 return "path points outside address space";
76 case IMLIB_LOAD_ERROR_TOO_MANY_SYMBOLIC_LINKS:
77 return "too many symbolic links";
78 case IMLIB_LOAD_ERROR_OUT_OF_MEMORY:
79 return "out of memory";
80 case IMLIB_LOAD_ERROR_OUT_OF_FILE_DESCRIPTORS:
81 return "out of file descriptors";
82 case IMLIB_LOAD_ERROR_PERMISSION_DENIED_TO_WRITE:
83 return "write permission denied";
84 case IMLIB_LOAD_ERROR_OUT_OF_DISK_SPACE:
85 return "out of disk space";
86 case IMLIB_LOAD_ERROR_UNKNOWN:
87 return "unknown error, that's really bad";
88 case IMLIB_LOAD_ERROR_NONE:
89 return "no error, oops";
92 return "unknown error";
95 /** Get image width.
96 * \param image The image.
97 * \return The image width in pixel.
99 int
100 image_getwidth(image_t *image)
102 imlib_context_set_image(image->image);
103 return imlib_image_get_width();
106 /** Get image height.
107 * \param image The image.
108 * \return The image height in pixel.
111 image_getheight(image_t *image)
113 imlib_context_set_image(image->image);
114 return imlib_image_get_height();
117 /** Get the ARGB32 data from an image.
118 * \param image The image.
119 * \return Data.
121 uint8_t *
122 image_getdata(image_t *image)
124 int size, i;
125 uint32_t *data;
126 double alpha;
127 uint8_t *dataimg;
128 #if AWESOME_IS_BIG_ENDIAN
129 const int index_a = 0, index_r = 1, index_g = 2, index_b = 3;
130 #else
131 const int index_a = 3, index_r = 2, index_g = 1, index_b = 0;
132 #endif
134 if(image->isupdated)
135 return image->data;
137 imlib_context_set_image(image->image);
139 data = imlib_image_get_data_for_reading_only();
141 size = imlib_image_get_width() * imlib_image_get_height();
143 p_realloc(&image->data, size * 4);
144 dataimg = image->data;
146 for(i = 0; i < size; i++, dataimg += 4)
148 dataimg[index_a] = (data[i] >> 24) & 0xff; /* A */
149 /* cairo wants pre-multiplied alpha */
150 alpha = dataimg[index_a] / 255.0;
151 dataimg[index_r] = ((data[i] >> 16) & 0xff) * alpha; /* R */
152 dataimg[index_g] = ((data[i] >> 8) & 0xff) * alpha; /* G */
153 dataimg[index_b] = (data[i] & 0xff) * alpha; /* B */
156 image->isupdated = true;
158 return image->data;
162 static void
163 image_draw_to_1bit_ximage(image_t *image, xcb_image_t *img)
165 imlib_context_set_image(image->image);
167 uint32_t *data = imlib_image_get_data_for_reading_only();
169 int width = imlib_image_get_width();
170 int height = imlib_image_get_height();
172 for(int y = 0; y < height; y++)
173 for(int x = 0; x < width; x++)
175 int i, pixel, tmp;
177 i = y * width + x;
179 // Sum up all color components ignoring alpha
180 tmp = (data[i] >> 16) & 0xff;
181 tmp += (data[i] >> 8) & 0xff;
182 tmp += data[i] & 0xff;
184 pixel = (tmp / 3 < 127) ? 0 : 1;
186 xcb_image_put_pixel(img, x, y, pixel);
190 // Convert an image to a 1bit pixmap
191 xcb_pixmap_t
192 image_to_1bit_pixmap(image_t *image, xcb_drawable_t d)
194 xcb_pixmap_t pixmap;
195 xcb_gcontext_t gc;
196 xcb_image_t *img;
197 uint16_t width, height;
199 width = image_getwidth(image);
200 height = image_getheight(image);
202 /* Prepare the pixmap and gc */
203 pixmap = xcb_generate_id(globalconf.connection);
204 xcb_create_pixmap(globalconf.connection, 1, pixmap, d, width, height);
206 gc = xcb_generate_id(globalconf.connection);
207 xcb_create_gc(globalconf.connection, gc, pixmap, 0, NULL);
209 /* Prepare the image */
210 img = xcb_image_create_native(globalconf.connection, width, height,
211 XCB_IMAGE_FORMAT_XY_BITMAP, 1, NULL, 0, NULL);
212 image_draw_to_1bit_ximage(image, img);
214 /* Paint the image to the pixmap */
215 xcb_image_put(globalconf.connection, pixmap, gc, img, 0, 0, 0);
217 xcb_free_gc(globalconf.connection, gc);
219 xcb_image_destroy(img);
221 return pixmap;
224 /** Create a new image from ARGB32 data.
225 * \param width The image width.
226 * \param height The image height.
227 * \param data The image data.
228 * \return 1 if an image has been pushed on stack, 0 otherwise.
231 image_new_from_argb32(int width, int height, uint32_t *data)
233 Imlib_Image imimage;
235 if((imimage = imlib_create_image_using_copied_data(width, height, data)))
237 imlib_context_set_image(imimage);
238 imlib_image_set_has_alpha(true);
239 image_t *image = image_new(globalconf.L);
240 image->image = imimage;
241 return 1;
244 return 0;
247 /** Create a new, completely black image.
248 * \param width The image width.
249 * \param height The image height.
250 * \return 1 if an image has been pushed on stack, 0 otherwise.
252 static int
253 image_new_blank(int width, int height)
255 Imlib_Image imimage;
257 if((imimage = imlib_create_image(width, height)))
259 imlib_context_set_image(imimage);
260 imlib_image_set_has_alpha(true);
261 /* After creation, an image has undefined content. Fix that up. */
262 imlib_context_set_color(0, 0, 0, 0xff);
263 imlib_image_fill_rectangle(0, 0, width, height);
264 image_t *image = image_new(globalconf.L);
265 image->image = imimage;
266 return 1;
269 return 0;
272 /** Load an image from filename.
273 * \param filename The image file to load.
274 * \return 1 if image is loaded and on stack, 0 otherwise.
276 static int
277 image_new_from_file(const char *filename)
279 Imlib_Image imimage;
280 Imlib_Load_Error e = IMLIB_LOAD_ERROR_NONE;
281 image_t *image;
283 if(!filename)
284 return 0;
286 if(!(imimage = imlib_load_image_with_error_return(filename, &e)))
288 warn("cannot load image %s: %s", filename, image_imlib_load_strerror(e));
289 return 0;
292 /* Make imlib check if the file changed on disk if it's later opened by the
293 * same file name again before using its cache.
295 imlib_context_set_image(imimage);
296 imlib_image_set_changes_on_disk();
298 image = image_new(globalconf.L);
299 image->image = imimage;
301 return 1;
304 /** Create a new image object.
305 * \param L The Lua stack.
306 * \return The number of elements pushed on stack.
307 * \luastack
308 * \lparam The image path.
309 * \lreturn An image object.
311 static int
312 luaA_image_new(lua_State *L)
314 const char *filename;
316 if((filename = lua_tostring(L, 2)))
317 return image_new_from_file(filename);
318 return 0;
321 /** Create a new image object from ARGB32 data.
322 * \param L The Lua stack.
323 * \return The number of elements pushed on stack.
324 * \luastack
325 * \lparam The image width.
326 * \lparam The image height.
327 * \lparam The image data as a string in ARGB32 format, or nil to create an
328 * empty image.
329 * \lreturn An image object.
331 static int
332 luaA_image_argb32_new(lua_State *L)
334 size_t len;
335 unsigned int width = luaL_checknumber(L, 1);
336 unsigned int height = luaL_checknumber(L, 2);
338 if (width == 0)
339 luaL_error(L, "image.argb32() called with zero width");
340 if (height == 0)
341 luaL_error(L, "image.argb32() called with zero height");
343 if(lua_isnil(L, 3))
345 return image_new_blank(width, height);
348 const char *data = luaL_checklstring(L, 3, &len);
350 if(width * height * 4 != len)
351 luaL_error(L, "string size does not match image size");
353 return image_new_from_argb32(width, height, (uint32_t *) data);
356 /** Performs 90 degree rotations on the current image. Passing 0 orientation
357 * does not rotate, 1 rotates clockwise by 90 degree, 2, rotates clockwise by
358 * 180 degrees, 3 rotates clockwise by 270 degrees.
359 * \param L The Lua VM state.
360 * \return The number of elements pushed on stack.
361 * \luastack
362 * \lvalue An image.
363 * \lparam The rotation to perform.
365 static int
366 luaA_image_orientate(lua_State *L)
368 image_t *image = luaA_checkudata(L, 1, &image_class);
369 int orientation = luaL_checknumber(L, 2);
371 imlib_context_set_image(image->image);
372 imlib_image_orientate(orientation);
374 image->isupdated = false;
376 return 0;
379 /** Rotate an image with specified angle radians and return a new image.
380 * \param L The Lua VM state.
381 * \return The number of elements pushed on stack.
382 * \luastack
383 * \lvalue An image.
384 * \lparam The angle in radians.
385 * \lreturn A rotated image.
387 static int
388 luaA_image_rotate(lua_State *L)
390 image_t *image = luaA_checkudata(L, 1, &image_class), *new;
391 double angle = luaL_checknumber(L, 2);
393 new = image_new(L);
395 imlib_context_set_image(image->image);
396 new->image = imlib_create_rotated_image(angle);
398 return 1;
401 /** Crop an image to the given rectangle.
402 * \return The number of elements pushed on stack.
403 * \luastack
404 * \lvalue An image.
405 * \lparam The top left x coordinate of the rectangle.
406 * \lparam The top left y coordinate of the rectangle.
407 * \lparam The width of the rectangle.
408 * \lparam The height of the rectangle.
409 * \lreturn A cropped image.
411 static int
412 luaA_image_crop(lua_State *L)
414 image_t *image = luaA_checkudata(L, 1, &image_class), *new;
415 int x = luaL_checkint(L, 2);
416 int y = luaL_checkint(L, 3);
417 int w = luaL_checkint(L, 4);
418 int h = luaL_checkint(L, 5);
420 new = image_new(L);
422 imlib_context_set_image(image->image);
423 int ow = imlib_image_get_width(), oh = imlib_image_get_height();
424 new->image = imlib_create_cropped_image(x, y, w, h);
425 imlib_context_set_image(new->image);
426 imlib_context_set_color(0, 0, 0, 0);
427 imlib_context_set_blend(0);
428 if(x < 0)
429 imlib_image_fill_rectangle(0, 0, -x, h);
430 if(y < 0)
431 imlib_image_fill_rectangle(x < 0 ? -x : 0, 0, w, -y);
432 if(x + w > ow)
433 imlib_image_fill_rectangle(ow - x, y < 0 ? -y : 0, x + w - ow, h);
434 if(y + h > oh)
435 imlib_image_fill_rectangle(x < 0 ? -x : 0, oh - y, x + w > ow ? ow - x : w, y + h - oh);
436 imlib_context_set_blend(1);
438 return 1;
441 /** Crop the image to the given rectangle and scales it.
442 * \param L The Lua VM state.
443 * \return The number of elements pushed on stack.
444 * \luastack
445 * \lvalue An image.
446 * \lparam The top left x coordinate of the source rectangle.
447 * \lparam The top left y coordinate of the source rectangle.
448 * \lparam The width of the source rectangle.
449 * \lparam The height of the source rectangle.
450 * \lparam The width of the destination rectangle.
451 * \lparam The height of the destination rectangle.
452 * \lreturn A cropped image.
454 static int
455 luaA_image_crop_and_scale(lua_State *L)
457 image_t *image = luaA_checkudata(L, 1, &image_class), *new;
458 int source_x = luaL_checkint(L, 2);
459 int source_y = luaL_checkint(L, 3);
460 int w = luaL_checkint(L, 4);
461 int h = luaL_checkint(L, 5);
462 int dest_w = luaL_checkint(L, 6);
463 int dest_h = luaL_checkint(L, 7);
465 new = image_new(L);
467 imlib_context_set_image(image->image);
468 new->image = imlib_create_cropped_scaled_image(source_x,
469 source_y,
470 w, h,
471 dest_w, dest_h);
473 return 1;
476 /** Draw a pixel in an image
477 * \param L The Lua VM state
478 * \luastack
479 * \lvalue An image.
480 * \lparam The x coordinate of the pixel to draw
481 * \lparam The y coordinate of the pixel to draw
482 * \lparam The color to draw the pixel in
484 static int
485 luaA_image_draw_pixel(lua_State *L)
487 size_t len;
488 color_t color;
489 color_init_cookie_t cookie;
490 image_t *image = luaA_checkudata(L, 1, &image_class);
491 int x = luaL_checkint(L, 2);
492 int y = luaL_checkint(L, 3);
493 const char *buf = luaL_checklstring(L, 4, &len);
495 cookie = color_init_unchecked(&color, buf, len);
496 imlib_context_set_image(image->image);
497 color_init_reply(cookie);
499 if((x > imlib_image_get_width()) || (y > imlib_image_get_height()))
500 return 0;
502 imlib_context_set_color(color.red, color.green, color.blue, color.alpha);
503 imlib_image_draw_pixel(x, y, 1);
504 image->isupdated = false;
505 return 0;
508 /** Draw a line in an image
509 * \param L The Lua VM state
510 * \luastack
511 * \lvalue An image.
512 * \lparam The x1 coordinate of the line to draw
513 * \lparam The y1 coordinate of the line to draw
514 * \lparam The x2 coordinate of the line to draw
515 * \lparam The y2 coordinate of the line to draw
516 * \lparam The color to draw the line in
518 static int
519 luaA_image_draw_line(lua_State *L)
521 size_t len;
522 color_t color;
523 color_init_cookie_t cookie;
524 image_t *image = luaA_checkudata(L, 1, &image_class);
525 int x1 = luaL_checkint(L, 2);
526 int y1 = luaL_checkint(L, 3);
527 int x2 = luaL_checkint(L, 4);
528 int y2 = luaL_checkint(L, 5);
529 const char *buf = luaL_checklstring(L, 6, &len);
531 cookie = color_init_unchecked(&color, buf, len);
532 imlib_context_set_image(image->image);
533 color_init_reply(cookie);
535 imlib_context_set_color(color.red, color.green, color.blue, color.alpha);
536 imlib_image_draw_line(x1, y1, x2, y2, 0);
537 image->isupdated = false;
538 return 0;
541 /** Draw a rectangle in an image
542 * \param L The Lua VM state
543 * \luastack
544 * \lvalue An image.
545 * \lparam The x coordinate of the rectangles top left corner
546 * \lparam The y coordinate of the rectangles top left corner
547 * \lparam The width of the rectangle
548 * \lparam The height of the rectangle
549 * \lparam True if the rectangle should be filled, False otherwise
550 * \lparam The color to draw the rectangle in
552 static int
553 luaA_image_draw_rectangle(lua_State *L)
555 size_t len;
556 color_t color;
557 color_init_cookie_t cookie;
558 image_t *image = luaA_checkudata(L, 1, &image_class);
559 int x = luaL_checkint(L, 2);
560 int y = luaL_checkint(L, 3);
561 int width = luaL_checkint(L, 4);
562 int height = luaL_checkint(L, 5);
563 int fill = luaA_checkboolean(L, 6);
564 const char *buf = luaL_checklstring(L, 7, &len);
566 cookie = color_init_unchecked(&color, buf, len);
567 imlib_context_set_image(image->image);
568 color_init_reply(cookie);
570 imlib_context_set_color(color.red, color.green, color.blue, color.alpha);
571 if(!fill)
572 imlib_image_draw_rectangle(x, y, width, height);
573 else
574 imlib_image_fill_rectangle(x, y, width, height);
575 image->isupdated = false;
576 return 0;
579 /** Convert a table to a color range and set it as current color range.
580 * \param L The Lua VM state.
581 * \param ud The index of the table.
582 * \return A color range that you are responsible to free.
584 static Imlib_Color_Range
585 luaA_table_to_color_range(lua_State *L, int ud)
587 Imlib_Color_Range range = imlib_create_color_range();
589 imlib_context_set_color_range(range);
591 for(size_t i = 1; i <= lua_objlen(L, ud); i++)
593 /* get t[i] */
594 lua_pushnumber(L, i);
595 lua_gettable(L, ud);
597 size_t len;
598 const char *colstr = lua_tolstring(L, -1, &len);
600 if(colstr)
602 color_t color;
604 color_init_cookie_t cookie = color_init_unchecked(&color, colstr, len);
606 /* get value with colstr as key in table */
607 lua_pushvalue(L, -1);
608 lua_gettable(L, ud);
610 /* convert the distance, if any, to number, or set 1 */
611 int distance = lua_tonumber(L, -1);
612 /* remove distance */
613 lua_pop(L, 1);
615 color_init_reply(cookie);
617 imlib_context_set_color(color.red, color.green, color.blue, color.alpha);
619 imlib_add_color_to_color_range(distance);
622 /* remove color string (value) */
623 lua_pop(L, 1);
626 return range;
629 /** Draw a rectangle in an image with gradient color.
630 * \param L The Lua VM state.
631 * \return The number of elements pushed on stack.
632 * \luastack
633 * \lvalue An image.
634 * \lparam The x coordinate of the rectangles top left corner.
635 * \lparam The y coordinate of the rectangles top left corner.
636 * \lparam The width of the rectangle.
637 * \lparam The height of the rectangle.
638 * \lparam A table with the color to draw the rectangle. You can specified the
639 * color distance from the previous one by setting t[color] = distance.
640 * \lparam The angle of gradient.
642 static int
643 luaA_image_draw_rectangle_gradient(lua_State *L)
645 image_t *image = luaA_checkudata(L, 1, &image_class);
646 int x = luaL_checkint(L, 2);
647 int y = luaL_checkint(L, 3);
648 int width = luaL_checkint(L, 4);
649 int height = luaL_checkint(L, 5);
650 luaA_checktable(L, 6);
651 double angle = luaL_checknumber(L, 7);
653 imlib_context_set_image(image->image);
655 luaA_table_to_color_range(L, 6);
657 imlib_image_fill_color_range_rectangle(x, y, width, height, angle);
659 imlib_free_color_range();
661 image->isupdated = false;
663 return 0;
666 /** Draw a circle in an image
667 * \param L The Lua VM state
668 * \luastack
669 * \lvalue An image.
670 * \lparam The x coordinate of the center of the circle
671 * \lparam The y coordinate of the center of the circle
672 * \lparam The horizontal amplitude (width)
673 * \lparam The vertical amplitude (height)
674 * \lparam True if the circle should be filled, False otherwise
675 * \lparam The color to draw the circle in
677 static int
678 luaA_image_draw_circle(lua_State *L)
680 size_t len;
681 color_t color;
682 color_init_cookie_t cookie;
683 image_t *image = luaA_checkudata(L, 1, &image_class);
684 int x = luaL_checkint(L, 2);
685 int y = luaL_checkint(L, 3);
686 int ah = luaL_checkint(L, 4);
687 int av = luaL_checkint(L, 5);
688 int fill = luaA_checkboolean(L, 6);
689 const char *buf = luaL_checklstring(L, 7, &len);
691 cookie = color_init_unchecked(&color, buf, len);
692 imlib_context_set_image(image->image);
693 color_init_reply(cookie);
695 imlib_context_set_color(color.red, color.green, color.blue, color.alpha);
696 if(!fill)
697 imlib_image_draw_ellipse(x, y, ah, av);
698 else
699 imlib_image_fill_ellipse(x, y, ah, av);
700 image->isupdated = false;
701 return 0;
704 /** Saves the image to the given path. The file extension (e.g. .png or .jpg)
705 * will affect the output format.
706 * \param L The Lua VM state.
707 * \return The number of elements pushed on stack.
708 * \luastack
709 * \lvalue An image.
710 * \lparam The image path.
712 static int
713 luaA_image_save(lua_State *L)
715 image_t *image = luaA_checkudata(L, 1, &image_class);
716 const char *path = luaL_checkstring(L, 2);
717 Imlib_Load_Error err;
719 imlib_context_set_image(image->image);
720 imlib_save_image_with_error_return(path, &err);
722 if(err != IMLIB_LOAD_ERROR_NONE)
723 warn("cannot save image %s: %s", path, image_imlib_load_strerror(err));
725 return 0;
728 /** Insert one image into another.
729 * \param L The Lua VM state.
730 * \return The number of elements pushed on stack.
731 * \luastack
732 * \lvalue An image.
733 * \lparam The image to insert.
734 * \lparam The X offset of the image to insert (optional).
735 * \lparam The Y offset of the image to insert (optional).
736 * \lparam The horizontal offset of the upper right image corner (optional).
737 * \lparam The vertical offset of the upper right image corner (optional).
738 * \lparam The horizontal offset of the lower left image corner (optional).
739 * \lparam The vertical offset of the lower left image corner (optional).
740 * \lparam The X coordinate of the source rectangle (optional).
741 * \lparam The Y coordinate of the source rectangle (optional).
742 * \lparam The width of the source rectangle (optional).
743 * \lparam The height of the source rectangle (optional).
745 static int
746 luaA_image_insert(lua_State *L)
748 image_t *image_target = luaA_checkudata(L, 1, &image_class);
749 image_t *image_source = luaA_checkudata(L, 2, &image_class);
750 int xoff = luaL_optnumber(L, 3, 0);
751 int yoff = luaL_optnumber(L, 4, 0);
753 int xsrc = luaL_optnumber(L, 5, 0);
754 int ysrc = luaL_optnumber(L, 6, 0);
755 int wsrc = luaL_optnumber(L, 7, image_getwidth(image_source));
756 int hsrc = luaL_optnumber(L, 8, image_getheight(image_source));
758 int hxoff = luaL_optnumber(L, 9, image_getwidth(image_source));
759 int hyoff = luaL_optnumber(L, 10, 0);
761 int vxoff = luaL_optnumber(L, 11, 0);
762 int vyoff = luaL_optnumber(L, 12, image_getheight(image_source));
764 imlib_context_set_image(image_target->image);
766 imlib_blend_image_onto_image_skewed(image_source->image, 0,
767 /* source rectangle */
768 xsrc, ysrc, wsrc, hsrc,
769 /* position of the source image in the target image */
770 xoff, yoff,
771 /* axis offsets for the source image, (w|0|0|h)
772 * is the default */
773 hxoff, hyoff, vxoff, vyoff);
775 image_target->isupdated = false;
777 return 0;
780 static int
781 luaA_image_get_width(lua_State *L, image_t *image)
783 lua_pushnumber(L, image_getwidth(image));
784 return 1;
787 static int
788 luaA_image_get_height(lua_State *L, image_t *image)
790 lua_pushnumber(L, image_getheight(image));
791 return 1;
794 static int
795 luaA_image_get_alpha(lua_State *L, image_t *image)
797 imlib_context_set_image(image->image);
798 lua_pushboolean(L, imlib_image_has_alpha());
799 return 1;
802 void
803 image_class_setup(lua_State *L)
805 static const struct luaL_reg image_methods[] =
807 LUA_CLASS_METHODS(image)
808 { "__call", luaA_image_new },
809 { "argb32", luaA_image_argb32_new },
810 { NULL, NULL }
813 static const struct luaL_reg image_meta[] =
815 LUA_OBJECT_META(image)
816 LUA_CLASS_META
817 { "rotate", luaA_image_rotate },
818 { "orientate", luaA_image_orientate },
819 { "crop", luaA_image_crop },
820 { "crop_and_scale", luaA_image_crop_and_scale },
821 { "save", luaA_image_save },
822 { "insert", luaA_image_insert },
823 /* draw on images, whee! */
824 { "draw_pixel", luaA_image_draw_pixel },
825 { "draw_line", luaA_image_draw_line },
826 { "draw_rectangle", luaA_image_draw_rectangle },
827 { "draw_rectangle_gradient", luaA_image_draw_rectangle_gradient },
828 { "draw_circle", luaA_image_draw_circle },
829 { "__gc", luaA_image_gc },
830 { NULL, NULL }
833 luaA_class_setup(L, &image_class, "image", (lua_class_allocator_t) image_new,
834 luaA_class_index_miss_property, luaA_class_newindex_miss_property,
835 image_methods, image_meta);
836 luaA_class_add_property(&image_class, A_TK_WIDTH,
837 NULL,
838 (lua_class_propfunc_t) luaA_image_get_width,
839 NULL);
840 luaA_class_add_property(&image_class, A_TK_HEIGHT,
841 NULL,
842 (lua_class_propfunc_t) luaA_image_get_height,
843 NULL);
844 luaA_class_add_property(&image_class, A_TK_ALPHA,
845 NULL,
846 (lua_class_propfunc_t) luaA_image_get_alpha,
847 NULL);
850 // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80