aboutsummaryrefslogtreecommitdiff
path: root/src/image.cc
diff options
context:
space:
mode:
authorSebastian Geerken <devnull@localhost>2013-11-19 12:14:34 +0100
committerSebastian Geerken <devnull@localhost>2013-11-19 12:14:34 +0100
commit5d18e6897aa7fe53fcadb457fa7d1caf5a143da3 (patch)
treea73ea9f2e373c22b0c040fe1e7c6d85cf0a2500b /src/image.cc
parentc575cfbaec41b4badb0ff3c686d640c3fa80687b (diff)
Toplevel images work now.
Diffstat (limited to 'src/image.cc')
-rw-r--r--src/image.cc20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/image.cc b/src/image.cc
index 04d89a82..7e6c27a4 100644
--- a/src/image.cc
+++ b/src/image.cc
@@ -50,6 +50,26 @@ DilloImage *a_Image_new(void *layout, void *img_rnd, int32_t bg_color)
}
/*
+ * Create and initialize a new image structure with an image widget.
+ */
+DilloImage *a_Image_new_with_dw(void *layout, const char *alt_text,
+ int32_t bg_color)
+{
+ dw::Image *dw = new dw::Image(alt_text);
+ return a_Image_new(layout, (void*)(dw::core::ImgRenderer*)dw, bg_color);
+}
+
+/*
+ * Return the image renderer as a widget. This is somewhat tricky,
+ * since simple casting leads to wrong (and hard to debug) results,
+ * because of multiple inheritance. This function can be used from C
+ * code, where only access to void* is possible.
+ */
+void *a_Image_get_dw(DilloImage *Image)
+{
+ return (dw::Image*)(dw::core::ImgRenderer*)Image->img_rnd;
+}
+/*
* Deallocate an Image structure
*/
static void Image_free(DilloImage *Image)