libgimp: deprecate GimpDrawablePreview's GimpDrawable API

and add drawable_ID functions instead.
This commit is contained in:
Michael Natterer
2015-09-15 00:49:45 +02:00
parent 6f33d8d86d
commit d9de706946
3 changed files with 213 additions and 83 deletions

View File

@ -46,9 +46,15 @@
enum enum
{ {
PROP_0, PROP_0,
PROP_DRAWABLE PROP_DRAWABLE,
PROP_DRAWABLE_ID
}; };
typedef struct
{
gint32 drawable_ID;
} GimpDrawablePreviewPrivate;
typedef struct typedef struct
{ {
gint x; gint x;
@ -57,6 +63,11 @@ typedef struct
} PreviewSettings; } PreviewSettings;
#define GIMP_DRAWABLE_PREVIEW_GET_PRIVATE(obj) \
G_TYPE_INSTANCE_GET_PRIVATE (preview, \
GIMP_TYPE_DRAWABLE_PREVIEW, \
GimpDrawablePreviewPrivate)
static void gimp_drawable_preview_constructed (GObject *object); static void gimp_drawable_preview_constructed (GObject *object);
static void gimp_drawable_preview_dispose (GObject *object); static void gimp_drawable_preview_dispose (GObject *object);
static void gimp_drawable_preview_get_property (GObject *object, static void gimp_drawable_preview_get_property (GObject *object,
@ -82,6 +93,9 @@ static void gimp_drawable_preview_draw_buffer (GimpPreview *preview,
static void gimp_drawable_preview_set_drawable (GimpDrawablePreview *preview, static void gimp_drawable_preview_set_drawable (GimpDrawablePreview *preview,
GimpDrawable *drawable); GimpDrawable *drawable);
static void gimp_drawable_preview_set_drawable_id
(GimpDrawablePreview *preview,
gint32 drawable_ID);
G_DEFINE_TYPE (GimpDrawablePreview, gimp_drawable_preview, G_DEFINE_TYPE (GimpDrawablePreview, gimp_drawable_preview,
@ -110,15 +124,33 @@ gimp_drawable_preview_class_init (GimpDrawablePreviewClass *klass)
preview_class->draw_thumb = gimp_drawable_preview_draw_thumb; preview_class->draw_thumb = gimp_drawable_preview_draw_thumb;
preview_class->draw_buffer = gimp_drawable_preview_draw_buffer; preview_class->draw_buffer = gimp_drawable_preview_draw_buffer;
g_type_class_add_private (object_class, sizeof (GimpDrawablePreviewPrivate));
/** /**
* GimpDrawablePreview:drawable: * GimpDrawablePreview:drawable:
* *
* Deprecated: use the drawable-id property instead.
*
* Since: 2.4 * Since: 2.4
*/ */
g_object_class_install_property (object_class, PROP_DRAWABLE, g_object_class_install_property (object_class, PROP_DRAWABLE,
g_param_spec_pointer ("drawable", NULL, NULL, g_param_spec_pointer ("drawable", NULL, NULL,
GIMP_PARAM_READWRITE | GIMP_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY)); G_PARAM_CONSTRUCT_ONLY));
/**
* GimpDrawablePreview:drawable-id:
*
* The drawable the #GimpDrawablePreview is attached to.
*
* Since: 2.10
*/
g_object_class_install_property (object_class, PROP_DRAWABLE_ID,
g_param_spec_int ("drawable-id", NULL, NULL,
-1, G_MAXINT, -1,
GIMP_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY));
} }
static void static void
@ -185,8 +217,12 @@ gimp_drawable_preview_get_property (GObject *object,
switch (property_id) switch (property_id)
{ {
case PROP_DRAWABLE: case PROP_DRAWABLE:
g_value_set_pointer (value, g_value_set_pointer (value, preview->drawable);
gimp_drawable_preview_get_drawable (preview)); break;
case PROP_DRAWABLE_ID:
g_value_set_int (value,
gimp_drawable_preview_get_drawable_id (preview));
break; break;
default: default:
@ -202,14 +238,22 @@ gimp_drawable_preview_set_property (GObject *object,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GimpDrawablePreview *preview = GIMP_DRAWABLE_PREVIEW (object); GimpDrawablePreview *preview = GIMP_DRAWABLE_PREVIEW (object);
GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
switch (property_id) switch (property_id)
{ {
case PROP_DRAWABLE: case PROP_DRAWABLE:
g_return_if_fail (priv->drawable_ID < 1);
if (g_value_get_pointer (value))
gimp_drawable_preview_set_drawable (preview, gimp_drawable_preview_set_drawable (preview,
g_value_get_pointer (value)); g_value_get_pointer (value));
break; break;
case PROP_DRAWABLE_ID:
gimp_drawable_preview_set_drawable_id (preview,
g_value_get_int (value));
break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
break; break;
@ -239,39 +283,42 @@ gimp_drawable_preview_style_set (GtkWidget *widget,
static void static void
gimp_drawable_preview_draw_original (GimpPreview *preview) gimp_drawable_preview_draw_original (GimpPreview *preview)
{ {
GimpDrawablePreview *drawable_preview = GIMP_DRAWABLE_PREVIEW (preview); GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
GimpDrawable *drawable = drawable_preview->drawable;
guchar *buffer; guchar *buffer;
GimpPixelRgn srcPR; gint width, height;
guint rowstride; gint bpp;
GimpImageType type;
if (! drawable) if (priv->drawable_ID < 1)
return; return;
rowstride = preview->width * drawable->bpp;
buffer = g_new (guchar, rowstride * preview->height);
preview->xoff = CLAMP (preview->xoff, preview->xoff = CLAMP (preview->xoff,
0, preview->xmax - preview->xmin - preview->width); 0, preview->xmax - preview->xmin - preview->width);
preview->yoff = CLAMP (preview->yoff, preview->yoff = CLAMP (preview->yoff,
0, preview->ymax - preview->ymin - preview->height); 0, preview->ymax - preview->ymin - preview->height);
gimp_pixel_rgn_init (&srcPR, drawable, width = preview->width;
height = preview->height;
buffer = gimp_drawable_get_sub_thumbnail_data (priv->drawable_ID,
preview->xoff + preview->xmin, preview->xoff + preview->xmin,
preview->yoff + preview->ymin, preview->yoff + preview->ymin,
preview->width, preview->height, preview->width, preview->height,
FALSE, FALSE); &width, &height, &bpp);
gimp_pixel_rgn_get_rect (&srcPR, buffer, switch (bpp)
preview->xoff + preview->xmin, {
preview->yoff + preview->ymin, case 1: type = GIMP_GRAY_IMAGE; break;
preview->width, preview->height); case 2: type = GIMP_GRAYA_IMAGE; break;
case 3: type = GIMP_RGB_IMAGE; break;
case 4: type = GIMP_RGBA_IMAGE; break;
default:
g_free (buffer);
return;
}
gimp_preview_area_draw (GIMP_PREVIEW_AREA (preview->area), gimp_preview_area_draw (GIMP_PREVIEW_AREA (preview->area),
0, 0, preview->width, preview->height, 0, 0, width, height, type, buffer, width * bpp);
gimp_drawable_type (drawable->drawable_id),
buffer,
rowstride);
g_free (buffer); g_free (buffer);
} }
@ -281,11 +328,10 @@ gimp_drawable_preview_draw_thumb (GimpPreview *preview,
gint width, gint width,
gint height) gint height)
{ {
GimpDrawablePreview *drawable_preview = GIMP_DRAWABLE_PREVIEW (preview); GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
GimpDrawable *drawable = drawable_preview->drawable;
if (drawable) if (priv->drawable_ID > 0)
_gimp_drawable_preview_area_draw_thumb (area, drawable->drawable_id, _gimp_drawable_preview_area_draw_thumb (area, priv->drawable_ID,
width, height); width, height);
} }
@ -363,7 +409,6 @@ _gimp_drawable_preview_area_draw_thumb (GimpPreviewArea *area,
gimp_preview_area_draw (area, gimp_preview_area_draw (area,
0, 0, nav_width, nav_height, 0, 0, nav_width, nav_height,
type, buffer, bpp * nav_width); type, buffer, bpp * nav_width);
g_free (buffer); g_free (buffer);
} }
} }
@ -377,20 +422,20 @@ gimp_drawable_preview_draw_area (GimpDrawablePreview *preview,
const guchar *buf, const guchar *buf,
gint rowstride) gint rowstride)
{ {
GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
GimpPreview *gimp_preview = GIMP_PREVIEW (preview); GimpPreview *gimp_preview = GIMP_PREVIEW (preview);
GimpDrawable *drawable = preview->drawable; gint32 image_ID;
gint32 image_id;
image_id = gimp_item_get_image (drawable->drawable_id); image_ID = gimp_item_get_image (priv->drawable_ID);
if (gimp_selection_is_empty (image_id)) if (gimp_selection_is_empty (image_ID))
{ {
gimp_preview_area_draw (GIMP_PREVIEW_AREA (gimp_preview->area), gimp_preview_area_draw (GIMP_PREVIEW_AREA (gimp_preview->area),
x - gimp_preview->xoff - gimp_preview->xmin, x - gimp_preview->xoff - gimp_preview->xmin,
y - gimp_preview->yoff - gimp_preview->ymin, y - gimp_preview->yoff - gimp_preview->ymin,
width, width,
height, height,
gimp_drawable_type (drawable->drawable_id), gimp_drawable_type (priv->drawable_ID),
buf, rowstride); buf, rowstride);
} }
else else
@ -401,9 +446,9 @@ gimp_drawable_preview_draw_area (GimpDrawablePreview *preview,
gint draw_x, draw_y; gint draw_x, draw_y;
gint draw_width, draw_height; gint draw_width, draw_height;
gimp_drawable_offsets (drawable->drawable_id, &offset_x, &offset_y); gimp_drawable_offsets (priv->drawable_ID, &offset_x, &offset_y);
if (gimp_drawable_mask_intersect (drawable->drawable_id, if (gimp_drawable_mask_intersect (priv->drawable_ID,
&mask_x, &mask_y, &mask_x, &mask_y,
&mask_width, &mask_height) && &mask_width, &mask_height) &&
gimp_rectangle_intersect (mask_x, mask_y, gimp_rectangle_intersect (mask_x, mask_y,
@ -412,49 +457,61 @@ gimp_drawable_preview_draw_area (GimpDrawablePreview *preview,
&draw_x, &draw_y, &draw_x, &draw_y,
&draw_width, &draw_height)) &draw_width, &draw_height))
{ {
GimpDrawable *selection; GimpImageType type;
GimpPixelRgn drawable_rgn; gint32 selection_ID;
GimpPixelRgn selection_rgn;
guchar *src; guchar *src;
guchar *sel; guchar *sel;
gint d_w, d_h, d_bpp;
gint s_w, s_h, s_bpp;
selection = gimp_drawable_get (gimp_image_get_selection (image_id)); d_w = draw_width;
d_h = draw_height;
gimp_pixel_rgn_init (&drawable_rgn, drawable, s_w = draw_width;
draw_x, draw_y, draw_width, draw_height, s_h = draw_height;
FALSE, FALSE);
gimp_pixel_rgn_init (&selection_rgn, selection,
draw_x + offset_x, draw_y + offset_y,
draw_width, draw_height,
FALSE, FALSE);
src = g_new (guchar, draw_width * draw_height * drawable->bpp); selection_ID = gimp_image_get_selection (image_ID);
sel = g_new (guchar, draw_width * draw_height);
gimp_pixel_rgn_get_rect (&drawable_rgn, src, src = gimp_drawable_get_sub_thumbnail_data (priv->drawable_ID,
draw_x, draw_y, draw_x, draw_y,
draw_width, draw_height); draw_width, draw_height,
gimp_pixel_rgn_get_rect (&selection_rgn, sel, &d_w, &d_h,
draw_x + offset_x, draw_y + offset_y, &d_bpp);
draw_width, draw_height);
sel = gimp_drawable_get_sub_thumbnail_data (selection_ID,
draw_x + offset_x,
draw_y + offset_y,
draw_width, draw_height,
&s_w, &s_h,
&s_bpp);
switch (d_bpp)
{
case 1: type = GIMP_GRAY_IMAGE; break;
case 2: type = GIMP_GRAYA_IMAGE; break;
case 3: type = GIMP_RGB_IMAGE; break;
case 4: type = GIMP_RGBA_IMAGE; break;
default:
g_free (sel);
g_free (src);
return;
}
gimp_preview_area_mask (GIMP_PREVIEW_AREA (gimp_preview->area), gimp_preview_area_mask (GIMP_PREVIEW_AREA (gimp_preview->area),
draw_x - gimp_preview->xoff - gimp_preview->xmin, draw_x - gimp_preview->xoff - gimp_preview->xmin,
draw_y - gimp_preview->yoff - gimp_preview->ymin, draw_y - gimp_preview->yoff - gimp_preview->ymin,
draw_width, draw_width,
draw_height, draw_height,
gimp_drawable_type (drawable->drawable_id), type,
src, draw_width * drawable->bpp, src, draw_width * d_bpp,
(buf + (buf +
(draw_x - x) * drawable->bpp + (draw_x - x) * d_bpp +
(draw_y - y) * rowstride), (draw_y - y) * d_w * d_bpp),
rowstride, rowstride,
sel, draw_width); sel, s_w);
g_free (sel); g_free (sel);
g_free (src); g_free (src);
gimp_drawable_detach (selection);
} }
} }
} }
@ -477,21 +534,40 @@ gimp_drawable_preview_set_drawable (GimpDrawablePreview *drawable_preview,
GimpDrawable *drawable) GimpDrawable *drawable)
{ {
GimpPreview *preview = GIMP_PREVIEW (drawable_preview); GimpPreview *preview = GIMP_PREVIEW (drawable_preview);
gint x1, y1, x2, y2; GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
g_return_if_fail (drawable_preview->drawable == NULL);
g_return_if_fail (priv->drawable_ID < 1);
drawable_preview->drawable = drawable; drawable_preview->drawable = drawable;
_gimp_drawable_preview_get_bounds (drawable->drawable_id, &x1, &y1, &x2, &y2); gimp_drawable_preview_set_drawable_id (drawable_preview,
drawable->drawable_id);
}
static void
gimp_drawable_preview_set_drawable_id (GimpDrawablePreview *drawable_preview,
gint32 drawable_ID)
{
GimpPreview *preview = GIMP_PREVIEW (drawable_preview);
GimpDrawablePreviewPrivate *priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
gint x1, y1, x2, y2;
g_return_if_fail (priv->drawable_ID < 1);
priv->drawable_ID = drawable_ID;
_gimp_drawable_preview_get_bounds (drawable_ID, &x1, &y1, &x2, &y2);
gimp_preview_set_bounds (preview, x1, y1, x2, y2); gimp_preview_set_bounds (preview, x1, y1, x2, y2);
if (gimp_drawable_is_indexed (drawable->drawable_id)) if (gimp_drawable_is_indexed (drawable_ID))
{ {
guint32 image = gimp_item_get_image (drawable->drawable_id); guint32 image_ID = gimp_item_get_image (drawable_ID);
guchar *cmap; guchar *cmap;
gint num_colors; gint num_colors;
cmap = gimp_image_get_colormap (image, &num_colors); cmap = gimp_image_get_colormap (image_ID, &num_colors);
gimp_preview_area_set_colormap (GIMP_PREVIEW_AREA (preview->area), gimp_preview_area_set_colormap (GIMP_PREVIEW_AREA (preview->area),
cmap, num_colors); cmap, num_colors);
g_free (cmap); g_free (cmap);
@ -536,6 +612,44 @@ _gimp_drawable_preview_get_bounds (gint32 drawable_ID,
} }
/**
* gimp_drawable_preview_new_from_drawable_id:
* @drawable_ID: a drawable ID
*
* Creates a new #GimpDrawablePreview widget for @drawable_ID.
*
* Returns: A pointer to the new #GimpDrawablePreview widget.
*
* Since: 2.10
**/
GtkWidget *
gimp_drawable_preview_new_from_drawable_id (gint32 drawable_ID)
{
g_return_val_if_fail (gimp_item_is_valid (drawable_ID), NULL);
g_return_val_if_fail (gimp_item_is_drawable (drawable_ID), NULL);
return g_object_new (GIMP_TYPE_DRAWABLE_PREVIEW,
"drawable-id", drawable_ID,
NULL);
}
/**
* gimp_drawable_preview_get_drawable_id:
* @preview: a #GimpDrawablePreview widget
*
* Return value: the drawable_ID that has been passed to
* gimp_drawable_preview_new_from_drawable_id().
*
* Since: 2.10
**/
gint32
gimp_drawable_preview_get_drawable_id (GimpDrawablePreview *preview)
{
g_return_val_if_fail (GIMP_IS_DRAWABLE_PREVIEW (preview), NULL);
return GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview)->drawable_ID;
}
/** /**
* gimp_drawable_preview_new: * gimp_drawable_preview_new:
* @drawable: a #GimpDrawable * @drawable: a #GimpDrawable
@ -550,6 +664,8 @@ _gimp_drawable_preview_get_bounds (gint32 drawable_ID,
* *
* Returns: A pointer to the new #GimpDrawablePreview widget. * Returns: A pointer to the new #GimpDrawablePreview widget.
* *
* Deprecated: Use gimp_drawable_preview_new_from_drawable_id() instead.
*
* Since: 2.2 * Since: 2.2
**/ **/
GtkWidget * GtkWidget *
@ -570,6 +686,8 @@ gimp_drawable_preview_new (GimpDrawable *drawable,
* Return value: the #GimpDrawable that has been passed to * Return value: the #GimpDrawable that has been passed to
* gimp_drawable_preview_new(). * gimp_drawable_preview_new().
* *
* Deprecated: use gimp_drawable_preview_get_drawable_id() instead.
*
* Since: 2.2 * Since: 2.2
**/ **/
GimpDrawable * GimpDrawable *
@ -591,10 +709,15 @@ void
gimp_drawable_preview_draw_region (GimpDrawablePreview *preview, gimp_drawable_preview_draw_region (GimpDrawablePreview *preview,
const GimpPixelRgn *region) const GimpPixelRgn *region)
{ {
GimpDrawablePreviewPrivate *priv;
g_return_if_fail (GIMP_IS_DRAWABLE_PREVIEW (preview)); g_return_if_fail (GIMP_IS_DRAWABLE_PREVIEW (preview));
g_return_if_fail (preview->drawable != NULL);
g_return_if_fail (region != NULL); g_return_if_fail (region != NULL);
priv = GIMP_DRAWABLE_PREVIEW_GET_PRIVATE (preview);
g_return_if_fail (priv->drawable_ID > 0);
/* If the data field is initialized, this region is currently being /* If the data field is initialized, this region is currently being
* processed and we can access it directly. * processed and we can access it directly.
*/ */

View File

@ -62,8 +62,13 @@ struct _GimpDrawablePreviewClass
GType gimp_drawable_preview_get_type (void) G_GNUC_CONST; GType gimp_drawable_preview_get_type (void) G_GNUC_CONST;
GtkWidget * gimp_drawable_preview_new_from_drawable_id (gint32 drawable_ID);
gint32 gimp_drawable_preview_get_drawable_id (GimpDrawablePreview *preview);
GIMP_DEPRECATED_FOR(gimp_drawable_preview_new_from_drawable_id)
GtkWidget * gimp_drawable_preview_new (GimpDrawable *drawable, GtkWidget * gimp_drawable_preview_new (GimpDrawable *drawable,
gboolean *toggle); gboolean *toggle);
GIMP_DEPRECATED_FOR(gimp_drawable_preview_get_drawable_id)
GimpDrawable * gimp_drawable_preview_get_drawable (GimpDrawablePreview *preview); GimpDrawable * gimp_drawable_preview_get_drawable (GimpDrawablePreview *preview);
void gimp_drawable_preview_draw_region (GimpDrawablePreview *preview, void gimp_drawable_preview_draw_region (GimpDrawablePreview *preview,

View File

@ -16,8 +16,10 @@ EXPORTS
gimp_drawable_menu_new gimp_drawable_menu_new
gimp_drawable_preview_draw_region gimp_drawable_preview_draw_region
gimp_drawable_preview_get_drawable gimp_drawable_preview_get_drawable
gimp_drawable_preview_get_drawable_id
gimp_drawable_preview_get_type gimp_drawable_preview_get_type
gimp_drawable_preview_new gimp_drawable_preview_new
gimp_drawable_preview_new_from_drawable_id
gimp_export_dialog_get_content_area gimp_export_dialog_get_content_area
gimp_export_dialog_new gimp_export_dialog_new
gimp_export_image gimp_export_image