Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <mpg@redhat.com>2007-11-04 15:40:28 (GMT)
committer Marco Pesenti Gritti <mpg@redhat.com>2007-11-04 15:40:28 (GMT)
commitcd61c52c7ba3649e1d1a4a049dd284ea4b5dd998 (patch)
treea5b71258d438c51a7f6b1d2c34fd8cb9edf5bdda
parentcd4cb6bd672fd5bee38da40c6466e8fced10bbeb (diff)
SugarPreview API improvements
-rw-r--r--lib/sugar/_sugarext.defs21
-rw-r--r--lib/sugar/sugar-preview.c38
-rw-r--r--lib/sugar/sugar-preview.h15
-rw-r--r--tests/graphics/preview.py3
4 files changed, 49 insertions, 28 deletions
diff --git a/lib/sugar/_sugarext.defs b/lib/sugar/_sugarext.defs
index 18a4461..151bc92 100644
--- a/lib/sugar/_sugarext.defs
+++ b/lib/sugar/_sugarext.defs
@@ -173,11 +173,24 @@
)
)
-(define-method save
+(define-method set_size
(of-object "SugarPreview")
- (c-name "sugar_preview_save")
- (return-type "gboolean")
+ (c-name "sugar_preview_set_size")
+ (return-type "none")
(parameters
- '("const-char*" "key")
+ '("int" "width")
+ '("int" "height")
)
)
+
+(define-method clear
+ (of-object "SugarPreview")
+ (c-name "sugar_preview_clear")
+ (return-type "none")
+)
+
+(define-method get_pixbuf
+ (of-object "SugarPreview")
+ (c-name "sugar_preview_get_pixbuf")
+ (return-type "GdkPixbuf*")
+)
diff --git a/lib/sugar/sugar-preview.c b/lib/sugar/sugar-preview.c
index 3cf938e..d20f609 100644
--- a/lib/sugar/sugar-preview.c
+++ b/lib/sugar/sugar-preview.c
@@ -27,13 +27,20 @@ static void sugar_preview_init (SugarPreview *menu);
G_DEFINE_TYPE(SugarPreview, sugar_preview, G_TYPE_OBJECT)
-gboolean
-sugar_preview_save(SugarPreview *preview, const char *file_name)
+void
+sugar_preview_set_size(SugarPreview *preview, int width, int height)
+{
+ preview->width = width;
+ preview->height = height;
+}
+
+GdkPixbuf *
+sugar_preview_get_pixbuf(SugarPreview *preview)
{
GdkPixbuf *pixbuf;
- if (preview->image != NULL) {
- return FALSE;
+ if (preview->image == NULL) {
+ return NULL;
}
pixbuf = gdk_pixbuf_get_from_image(NULL, preview->image, NULL,
@@ -41,14 +48,16 @@ sugar_preview_save(SugarPreview *preview, const char *file_name)
preview->image->width,
preview->image->height);
- gdk_pixbuf_save(pixbuf, file_name, "png", NULL);
+ return pixbuf;
+}
+void
+sugar_preview_clear(SugarPreview *preview)
+{
if (preview->image != NULL) {
g_object_unref(G_OBJECT(preview->image));
preview->image = NULL;
}
-
- return TRUE;
}
void
@@ -59,16 +68,14 @@ sugar_preview_take_screenshot(SugarPreview *preview, GdkDrawable *drawable)
GdkColormap *colormap;
gint width, height;
+ sugar_preview_clear(preview);
+
gdk_drawable_get_size(drawable, &width, &height);
screen = gdk_drawable_get_screen(drawable);
visual = gdk_drawable_get_visual(drawable);
colormap = gdk_drawable_get_colormap(drawable);
- if (preview->image != NULL) {
- g_object_unref(G_OBJECT(preview->image));
- }
-
preview->image = gdk_image_new(GDK_IMAGE_SHARED, visual, width, height);
gdk_image_set_colormap(preview->image, colormap);
@@ -79,17 +86,12 @@ sugar_preview_take_screenshot(SugarPreview *preview, GdkDrawable *drawable)
}
static void
-sugar_preview_dispose (GObject *object)
+sugar_preview_dispose(GObject *object)
{
SugarPreview *preview = SUGAR_PREVIEW(object);
-
- if (preview->image != NULL) {
- g_object_unref(G_OBJECT(preview->image));
- preview->image = NULL;
- }
+ sugar_preview_clear(preview);
}
-
static void
sugar_preview_class_init(SugarPreviewClass *preview_class)
{
diff --git a/lib/sugar/sugar-preview.h b/lib/sugar/sugar-preview.h
index 3fe1056..1cd3bb4 100644
--- a/lib/sugar/sugar-preview.h
+++ b/lib/sugar/sugar-preview.h
@@ -38,17 +38,22 @@ struct _SugarPreview {
GObject base_instance;
GdkImage *image;
+ int width;
+ int height;
};
struct _SugarPreviewClass {
GObjectClass base_class;
};
-GType sugar_preview_get_type (void);
-void sugar_preview_take_screenshot (SugarPreview *menu,
- GdkDrawable *drawable);
-gboolean sugar_preview_save (SugarPreview *menu,
- const char *file_name);
+GType sugar_preview_get_type (void);
+void sugar_preview_take_screenshot (SugarPreview *preview,
+ GdkDrawable *drawable);
+void sugar_preview_set_size (SugarPreview *preview,
+ int width,
+ int height);
+GdkPixbuf *sugar_preview_get_pixbuf (SugarPreview *preview);
+void sugar_preview_clear (SugarPreview *preview);
G_END_DECLS
diff --git a/tests/graphics/preview.py b/tests/graphics/preview.py
index 2e058af..c1e9ccb 100644
--- a/tests/graphics/preview.py
+++ b/tests/graphics/preview.py
@@ -28,7 +28,8 @@ import common
def _preview_timeout_cb():
preview = _sugarext.Preview()
preview.take_screenshot(button.window)
- preview.save('/home/marco/test.png')
+ preview.get_pixbuf().save('/home/marco/test.png','png')
+ preview.clear()
test = common.Test()