[gimp] app: move all GimpTemplateEditor members to private
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] app: move all GimpTemplateEditor members to private
- Date: Tue, 1 Mar 2011 10:50:40 +0000 (UTC)
commit f0f94ba6a14da5c9d728de24f4856a703bfe5f4c
Author: Michael Natterer <mitch gimp org>
Date: Tue Mar 1 11:50:16 2011 +0100
app: move all GimpTemplateEditor members to private
app/actions/templates-commands.c | 11 +-
app/dialogs/image-new-dialog.c | 2 +-
app/widgets/gimptemplateeditor.c | 337 ++++++++++++++++++++++----------------
app/widgets/gimptemplateeditor.h | 32 +---
4 files changed, 217 insertions(+), 165 deletions(-)
---
diff --git a/app/actions/templates-commands.c b/app/actions/templates-commands.c
index cfd3274..9769f87 100644
--- a/app/actions/templates-commands.c
+++ b/app/actions/templates-commands.c
@@ -253,8 +253,10 @@ templates_new_response (GtkWidget *dialog,
{
if (response_id == GTK_RESPONSE_OK)
{
- GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (options->editor);
- GimpTemplate *template = editor->template;
+ GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (options->editor);
+ GimpTemplate *template;
+
+ template = gimp_template_editor_get_template (editor);
gimp_container_add (options->gimp->templates, GIMP_OBJECT (template));
gimp_context_set_template (gimp_get_user_context (options->gimp),
@@ -272,8 +274,11 @@ templates_edit_response (GtkWidget *dialog,
if (response_id == GTK_RESPONSE_OK)
{
GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (options->editor);
+ GimpTemplate *template;
+
+ template = gimp_template_editor_get_template (editor);
- gimp_config_sync (G_OBJECT (editor->template),
+ gimp_config_sync (G_OBJECT (template),
G_OBJECT (options->template), 0);
}
diff --git a/app/dialogs/image-new-dialog.c b/app/dialogs/image-new-dialog.c
index 0fc0375..78488ca 100644
--- a/app/dialogs/image-new-dialog.c
+++ b/app/dialogs/image-new-dialog.c
@@ -154,7 +154,7 @@ image_new_dialog_new (GimpContext *context)
gtk_box_pack_start (GTK_BOX (main_vbox), dialog->editor, FALSE, FALSE, 0);
gtk_widget_show (dialog->editor);
- entry = GIMP_SIZE_ENTRY (GIMP_TEMPLATE_EDITOR (dialog->editor)->size_se);
+ entry = GIMP_SIZE_ENTRY (gimp_template_editor_get_size_se (GIMP_TEMPLATE_EDITOR (dialog->editor)));
gimp_size_entry_set_activates_default (entry, TRUE);
gimp_size_entry_grab_focus (entry);
diff --git a/app/widgets/gimptemplateeditor.c b/app/widgets/gimptemplateeditor.c
index d423891..4486a69 100644
--- a/app/widgets/gimptemplateeditor.c
+++ b/app/widgets/gimptemplateeditor.c
@@ -42,6 +42,7 @@
#define SB_WIDTH 8
#define MAX_COMMENT_LENGTH 512 /* arbitrary */
+
enum
{
PROP_0,
@@ -49,6 +50,32 @@ enum
};
+typedef struct _GimpTemplateEditorPrivate GimpTemplateEditorPrivate;
+
+struct _GimpTemplateEditorPrivate
+{
+ GimpTemplate *template;
+
+ GimpContainer *stock_id_container;
+ GimpContext *stock_id_context;
+
+ GtkWidget *aspect_button;
+ gboolean block_aspect;
+
+ GtkWidget *expander;
+ GtkWidget *size_se;
+ GtkWidget *memsize_label;
+ GtkWidget *pixel_label;
+ GtkWidget *more_label;
+ GtkWidget *resolution_se;
+};
+
+#define GET_PRIVATE(editor) \
+ G_TYPE_INSTANCE_GET_PRIVATE (editor, \
+ GIMP_TYPE_TEMPLATE_EDITOR, \
+ GimpTemplateEditorPrivate)
+
+
static void gimp_template_editor_constructed (GObject *object);
static void gimp_template_editor_finalize (GObject *object);
static void gimp_template_editor_set_property (GObject *object,
@@ -90,6 +117,8 @@ gimp_template_editor_class_init (GimpTemplateEditorClass *klass)
GIMP_TYPE_TEMPLATE,
GIMP_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY));
+
+ g_type_class_add_private (object_class, sizeof (GimpTemplateEditorPrivate));
}
static void
@@ -99,37 +128,36 @@ gimp_template_editor_init (GimpTemplateEditor *editor)
GTK_ORIENTATION_VERTICAL);
gtk_box_set_spacing (GTK_BOX (editor), 12);
-
- editor->template = NULL;
}
static void
gimp_template_editor_constructed (GObject *object)
{
- GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (object);
- GtkWidget *aspect_box;
- GtkWidget *frame;
- GtkWidget *hbox;
- GtkWidget *vbox;
- GtkWidget *table;
- GtkWidget *label;
- GtkObject *adjustment;
- GtkWidget *width;
- GtkWidget *height;
- GtkWidget *xres;
- GtkWidget *yres;
- GtkWidget *chainbutton;
- GtkWidget *combo;
- GtkWidget *scrolled_window;
- GtkWidget *text_view;
- GtkTextBuffer *text_buffer;
- GList *focus_chain = NULL;
- gchar *text;
+ GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (object);
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (object);
+ GtkWidget *aspect_box;
+ GtkWidget *frame;
+ GtkWidget *hbox;
+ GtkWidget *vbox;
+ GtkWidget *table;
+ GtkWidget *label;
+ GtkObject *adjustment;
+ GtkWidget *width;
+ GtkWidget *height;
+ GtkWidget *xres;
+ GtkWidget *yres;
+ GtkWidget *chainbutton;
+ GtkWidget *combo;
+ GtkWidget *scrolled_window;
+ GtkWidget *text_view;
+ GtkTextBuffer *text_buffer;
+ GList *focus_chain = NULL;
+ gchar *text;
if (G_OBJECT_CLASS (parent_class)->constructed)
G_OBJECT_CLASS (parent_class)->constructed (object);
- g_assert (editor->template != NULL);
+ g_assert (private->template != NULL);
/* Image size frame */
frame = gimp_frame_new (_("Image Size"));
@@ -173,31 +201,31 @@ gimp_template_editor_constructed (GObject *object)
gtk_table_attach_defaults (GTK_TABLE (table), hbox, 1, 2, 0, 2);
gtk_widget_show (hbox);
- editor->size_se = gimp_size_entry_new (0, editor->template->unit,_("%p"),
- TRUE, FALSE, FALSE, SB_WIDTH,
- GIMP_SIZE_ENTRY_UPDATE_SIZE);
+ private->size_se = gimp_size_entry_new (0, private->template->unit,_("%p"),
+ TRUE, FALSE, FALSE, SB_WIDTH,
+ GIMP_SIZE_ENTRY_UPDATE_SIZE);
- gtk_table_set_row_spacing (GTK_TABLE (editor->size_se), 0, 2);
- gtk_table_set_col_spacing (GTK_TABLE (editor->size_se), 1, 6);
+ gtk_table_set_row_spacing (GTK_TABLE (private->size_se), 0, 2);
+ gtk_table_set_col_spacing (GTK_TABLE (private->size_se), 1, 6);
- gtk_box_pack_start (GTK_BOX (hbox), editor->size_se, FALSE, FALSE, 0);
- gtk_widget_show (editor->size_se);
+ gtk_box_pack_start (GTK_BOX (hbox), private->size_se, FALSE, FALSE, 0);
+ gtk_widget_show (private->size_se);
- gimp_size_entry_add_field (GIMP_SIZE_ENTRY (editor->size_se),
+ gimp_size_entry_add_field (GIMP_SIZE_ENTRY (private->size_se),
GTK_SPIN_BUTTON (height), NULL);
- gtk_table_attach_defaults (GTK_TABLE (editor->size_se), height, 0, 1, 1, 2);
+ gtk_table_attach_defaults (GTK_TABLE (private->size_se), height, 0, 1, 1, 2);
gtk_widget_show (height);
- gimp_size_entry_add_field (GIMP_SIZE_ENTRY (editor->size_se),
+ gimp_size_entry_add_field (GIMP_SIZE_ENTRY (private->size_se),
GTK_SPIN_BUTTON (width), NULL);
- gtk_table_attach_defaults (GTK_TABLE (editor->size_se), width, 0, 1, 0, 1);
+ gtk_table_attach_defaults (GTK_TABLE (private->size_se), width, 0, 1, 0, 1);
gtk_widget_show (width);
- gimp_prop_coordinates_connect (G_OBJECT (editor->template),
+ gimp_prop_coordinates_connect (G_OBJECT (private->template),
"width", "height", "unit",
- editor->size_se, NULL,
- editor->template->xresolution,
- editor->template->yresolution);
+ private->size_se, NULL,
+ private->template->xresolution,
+ private->template->yresolution);
hbox = gtk_hbox_new (FALSE, 12);
gtk_table_attach_defaults (GTK_TABLE (table), hbox, 1, 3, 2, 3);
@@ -211,8 +239,8 @@ gimp_template_editor_constructed (GObject *object)
"gimp", GTK_ICON_SIZE_MENU,
G_CALLBACK (gimp_template_editor_aspect_callback),
editor,
- &editor->aspect_button);
- gtk_widget_hide (editor->aspect_button); /* hide "square" */
+ &private->aspect_button);
+ gtk_widget_hide (private->aspect_button); /* hide "square" */
gtk_box_pack_start (GTK_BOX (vbox), aspect_box, FALSE, FALSE, 0);
gtk_widget_show (aspect_box);
@@ -221,46 +249,46 @@ gimp_template_editor_constructed (GObject *object)
gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
gtk_widget_show (vbox);
- editor->pixel_label = gtk_label_new (NULL);
- gimp_label_set_attributes (GTK_LABEL (editor->pixel_label),
+ private->pixel_label = gtk_label_new (NULL);
+ gimp_label_set_attributes (GTK_LABEL (private->pixel_label),
PANGO_ATTR_SCALE, PANGO_SCALE_SMALL,
-1);
- gtk_misc_set_alignment (GTK_MISC (editor->pixel_label), 0.0, 0.0);
- gtk_box_pack_start (GTK_BOX (vbox), editor->pixel_label, FALSE, FALSE, 0);
- gtk_widget_show (editor->pixel_label);
+ gtk_misc_set_alignment (GTK_MISC (private->pixel_label), 0.0, 0.0);
+ gtk_box_pack_start (GTK_BOX (vbox), private->pixel_label, FALSE, FALSE, 0);
+ gtk_widget_show (private->pixel_label);
- editor->more_label = gtk_label_new (NULL);
- gimp_label_set_attributes (GTK_LABEL (editor->more_label),
+ private->more_label = gtk_label_new (NULL);
+ gimp_label_set_attributes (GTK_LABEL (private->more_label),
PANGO_ATTR_SCALE, PANGO_SCALE_SMALL,
-1);
- gtk_misc_set_alignment (GTK_MISC (editor->more_label), 0.0, 0.0);
- gtk_box_pack_start (GTK_BOX (vbox), editor->more_label, FALSE, FALSE, 0);
- gtk_widget_show (editor->more_label);
+ gtk_misc_set_alignment (GTK_MISC (private->more_label), 0.0, 0.0);
+ gtk_box_pack_start (GTK_BOX (vbox), private->more_label, FALSE, FALSE, 0);
+ gtk_widget_show (private->more_label);
#ifdef ENABLE_MEMSIZE_LABEL
- editor->memsize_label = gtk_label_new (NULL);
- gimp_label_set_attributes (GTK_LABEL (editor->memsize_label),
+ private->memsize_label = gtk_label_new (NULL);
+ gimp_label_set_attributes (GTK_LABEL (private->memsize_label),
PANGO_ATTR_SCALE, PANGO_SCALE_SMALL,
PANGO_ATTR_WEIGHT, PANGO_WEIGHT_BOLD,
-1);
- gtk_misc_set_alignment (GTK_MISC (editor->memsize_label), 0.0, 0.0);
- gtk_box_pack_start (GTK_BOX (vbox), editor->memsize_label, FALSE, FALSE, 0);
- gtk_widget_show (editor->memsize_label);
+ gtk_misc_set_alignment (GTK_MISC (private->memsize_label), 0.0, 0.0);
+ gtk_box_pack_start (GTK_BOX (vbox), private->memsize_label, FALSE, FALSE, 0);
+ gtk_widget_show (private->memsize_label);
#endif
text = g_strdup_printf ("<b>%s</b>", _("_Advanced Options"));
- editor->expander = g_object_new (GTK_TYPE_EXPANDER,
- "label", text,
- "use-markup", TRUE,
- "use-underline", TRUE,
- NULL);
+ private->expander = g_object_new (GTK_TYPE_EXPANDER,
+ "label", text,
+ "use-markup", TRUE,
+ "use-underline", TRUE,
+ NULL);
g_free (text);
- gtk_box_pack_start (GTK_BOX (editor), editor->expander, TRUE, TRUE, 0);
- gtk_widget_show (editor->expander);
+ gtk_box_pack_start (GTK_BOX (editor), private->expander, TRUE, TRUE, 0);
+ gtk_widget_show (private->expander);
frame = gimp_frame_new ("<expander>");
- gtk_container_add (GTK_CONTAINER (editor->expander), frame);
+ gtk_container_add (GTK_CONTAINER (private->expander), frame);
gtk_widget_show (frame);
table = gtk_table_new (5, 2, FALSE);
@@ -300,65 +328,65 @@ gimp_template_editor_constructed (GObject *object)
gtk_table_attach_defaults (GTK_TABLE (table), hbox, 1, 2, 0, 2);
gtk_widget_show (hbox);
- editor->resolution_se =
- gimp_size_entry_new (0, editor->template->resolution_unit, _("pixels/%s"),
+ private->resolution_se =
+ gimp_size_entry_new (0, private->template->resolution_unit, _("pixels/%s"),
FALSE, FALSE, FALSE, SB_WIDTH,
GIMP_SIZE_ENTRY_UPDATE_RESOLUTION);
- gtk_table_set_row_spacing (GTK_TABLE (editor->resolution_se), 0, 2);
- gtk_table_set_col_spacing (GTK_TABLE (editor->resolution_se), 1, 2);
- gtk_table_set_col_spacing (GTK_TABLE (editor->resolution_se), 2, 2);
+ gtk_table_set_row_spacing (GTK_TABLE (private->resolution_se), 0, 2);
+ gtk_table_set_col_spacing (GTK_TABLE (private->resolution_se), 1, 2);
+ gtk_table_set_col_spacing (GTK_TABLE (private->resolution_se), 2, 2);
- gtk_box_pack_start (GTK_BOX (hbox), editor->resolution_se, FALSE, FALSE, 0);
- gtk_widget_show (editor->resolution_se);
+ gtk_box_pack_start (GTK_BOX (hbox), private->resolution_se, FALSE, FALSE, 0);
+ gtk_widget_show (private->resolution_se);
- gimp_size_entry_add_field (GIMP_SIZE_ENTRY (editor->resolution_se),
+ gimp_size_entry_add_field (GIMP_SIZE_ENTRY (private->resolution_se),
GTK_SPIN_BUTTON (yres), NULL);
- gtk_table_attach_defaults (GTK_TABLE (editor->resolution_se), yres,
+ gtk_table_attach_defaults (GTK_TABLE (private->resolution_se), yres,
0, 1, 1, 2);
gtk_widget_show (yres);
- gimp_size_entry_add_field (GIMP_SIZE_ENTRY (editor->resolution_se),
+ gimp_size_entry_add_field (GIMP_SIZE_ENTRY (private->resolution_se),
GTK_SPIN_BUTTON (xres), NULL);
- gtk_table_attach_defaults (GTK_TABLE (editor->resolution_se), xres,
+ gtk_table_attach_defaults (GTK_TABLE (private->resolution_se), xres,
0, 1, 0, 1);
gtk_widget_show (xres);
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 0,
- editor->template->xresolution, FALSE);
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 1,
- editor->template->yresolution, FALSE);
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 0,
+ private->template->xresolution, FALSE);
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 1,
+ private->template->yresolution, FALSE);
/* the resolution chainbutton */
chainbutton = gimp_chain_button_new (GIMP_CHAIN_RIGHT);
- gtk_table_attach_defaults (GTK_TABLE (editor->resolution_se), chainbutton,
+ gtk_table_attach_defaults (GTK_TABLE (private->resolution_se), chainbutton,
1, 2, 0, 2);
gtk_widget_show (chainbutton);
- gimp_prop_coordinates_connect (G_OBJECT (editor->template),
+ gimp_prop_coordinates_connect (G_OBJECT (private->template),
"xresolution", "yresolution",
"resolution-unit",
- editor->resolution_se, chainbutton,
+ private->resolution_se, chainbutton,
1.0, 1.0);
focus_chain = g_list_prepend (focus_chain,
- GIMP_SIZE_ENTRY (editor->resolution_se)->unitmenu);
+ GIMP_SIZE_ENTRY (private->resolution_se)->unitmenu);
focus_chain = g_list_prepend (focus_chain, chainbutton);
focus_chain = g_list_prepend (focus_chain, yres);
focus_chain = g_list_prepend (focus_chain, xres);
- gtk_container_set_focus_chain (GTK_CONTAINER (editor->resolution_se),
+ gtk_container_set_focus_chain (GTK_CONTAINER (private->resolution_se),
focus_chain);
g_list_free (focus_chain);
- combo = gimp_prop_enum_combo_box_new (G_OBJECT (editor->template),
+ combo = gimp_prop_enum_combo_box_new (G_OBJECT (private->template),
"image-type",
GIMP_RGB, GIMP_GRAY);
gimp_table_attach_aligned (GTK_TABLE (table), 0, 2,
_("Color _space:"), 0.0, 0.5,
combo, 1, FALSE);
- combo = gimp_prop_enum_combo_box_new (G_OBJECT (editor->template),
+ combo = gimp_prop_enum_combo_box_new (G_OBJECT (private->template),
"fill-type",
GIMP_FOREGROUND_FILL,
GIMP_TRANSPARENT_FILL);
@@ -376,7 +404,7 @@ gimp_template_editor_constructed (GObject *object)
_("Comme_nt:"), 0.0, 0.0,
scrolled_window, 1, FALSE);
- text_buffer = gimp_prop_text_buffer_new (G_OBJECT (editor->template),
+ text_buffer = gimp_prop_text_buffer_new (G_OBJECT (private->template),
"comment", MAX_COMMENT_LENGTH);
text_view = gtk_text_view_new_with_buffer (text_buffer);
@@ -386,35 +414,35 @@ gimp_template_editor_constructed (GObject *object)
gtk_container_add (GTK_CONTAINER (scrolled_window), text_view);
gtk_widget_show (text_view);
- g_signal_connect_object (editor->template, "notify",
+ g_signal_connect_object (private->template, "notify",
G_CALLBACK (gimp_template_editor_template_notify),
editor, 0);
/* call the notify callback once to get the labels set initially */
- gimp_template_editor_template_notify (editor->template, NULL, editor);
+ gimp_template_editor_template_notify (private->template, NULL, editor);
}
static void
gimp_template_editor_finalize (GObject *object)
{
- GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (object);
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (object);
- if (editor->template)
+ if (private->template)
{
- g_object_unref (editor->template);
- editor->template = NULL;
+ g_object_unref (private->template);
+ private->template = NULL;
}
- if (editor->stock_id_container)
+ if (private->stock_id_container)
{
- g_object_unref (editor->stock_id_container);
- editor->stock_id_container = NULL;
+ g_object_unref (private->stock_id_container);
+ private->stock_id_container = NULL;
}
- if (editor->stock_id_context)
+ if (private->stock_id_context)
{
- g_object_unref (editor->stock_id_context);
- editor->stock_id_context = NULL;
+ g_object_unref (private->stock_id_context);
+ private->stock_id_context = NULL;
}
G_OBJECT_CLASS (parent_class)->finalize (object);
@@ -426,12 +454,12 @@ gimp_template_editor_set_property (GObject *object,
const GValue *value,
GParamSpec *pspec)
{
- GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (object);
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (object);
switch (property_id)
{
case PROP_TEMPLATE:
- editor->template = g_value_dup_object (value);
+ private->template = g_value_dup_object (value);
break;
default:
@@ -446,12 +474,12 @@ gimp_template_editor_get_property (GObject *object,
GValue *value,
GParamSpec *pspec)
{
- GimpTemplateEditor *editor = GIMP_TEMPLATE_EDITOR (object);
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (object);
switch (property_id)
{
case PROP_TEMPLATE:
- g_value_set_object (value, editor->template);
+ g_value_set_object (value, private->template);
break;
default:
@@ -465,7 +493,8 @@ gimp_template_editor_new (GimpTemplate *template,
Gimp *gimp,
gboolean edit_template)
{
- GimpTemplateEditor *editor;
+ GimpTemplateEditor *editor;
+ GimpTemplateEditorPrivate *private;
g_return_val_if_fail (!edit_template || GIMP_IS_GIMP (gimp), NULL);
@@ -473,6 +502,8 @@ gimp_template_editor_new (GimpTemplate *template,
"template", template,
NULL);
+ private = GET_PRIVATE (editor);
+
if (edit_template)
{
GtkWidget *table;
@@ -482,12 +513,12 @@ gimp_template_editor_new (GimpTemplate *template,
GSList *list;
const gchar *stock_id;
- stock_id = gimp_viewable_get_stock_id (GIMP_VIEWABLE (editor->template));
+ stock_id = gimp_viewable_get_stock_id (GIMP_VIEWABLE (private->template));
- editor->stock_id_container = gimp_list_new (GIMP_TYPE_TEMPLATE, FALSE);
- editor->stock_id_context = gimp_context_new (gimp, "foo", NULL);
+ private->stock_id_container = gimp_list_new (GIMP_TYPE_TEMPLATE, FALSE);
+ private->stock_id_context = gimp_context_new (gimp, "foo", NULL);
- g_signal_connect (editor->stock_id_context, "template-changed",
+ g_signal_connect (private->stock_id_context, "template-changed",
G_CALLBACK (gimp_template_editor_icon_changed),
editor);
@@ -500,11 +531,11 @@ gimp_template_editor_new (GimpTemplate *template,
"stock-id", list->data,
NULL);
- gimp_container_add (editor->stock_id_container, object);
+ gimp_container_add (private->stock_id_container, object);
g_object_unref (object);
if (strcmp (list->data, stock_id) == 0)
- gimp_context_set_template (editor->stock_id_context,
+ gimp_context_set_template (private->stock_id_context,
GIMP_TEMPLATE (object));
}
@@ -518,14 +549,14 @@ gimp_template_editor_new (GimpTemplate *template,
gtk_box_reorder_child (GTK_BOX (editor), table, 0);
gtk_widget_show (table);
- entry = gimp_prop_entry_new (G_OBJECT (editor->template), "name", 128);
+ entry = gimp_prop_entry_new (G_OBJECT (private->template), "name", 128);
gimp_table_attach_aligned (GTK_TABLE (table), 0, 0,
_("_Name:"), 1.0, 0.5,
entry, 1, FALSE);
- button = gimp_viewable_button_new (editor->stock_id_container,
- editor->stock_id_context,
+ button = gimp_viewable_button_new (private->stock_id_container,
+ private->stock_id_context,
GIMP_VIEW_TYPE_LIST,
GIMP_VIEW_SIZE_SMALL,
GIMP_VIEW_SIZE_SMALL, 0,
@@ -541,13 +572,33 @@ gimp_template_editor_new (GimpTemplate *template,
return GTK_WIDGET (editor);
}
+GimpTemplate *
+gimp_template_editor_get_template (GimpTemplateEditor *editor)
+{
+ g_return_val_if_fail (GIMP_IS_TEMPLATE_EDITOR (editor), NULL);
+
+ return GET_PRIVATE (editor)->template;
+}
+
void
gimp_template_editor_show_advanced (GimpTemplateEditor *editor,
gboolean expanded)
{
+ GimpTemplateEditorPrivate *private;
+
g_return_if_fail (GIMP_IS_TEMPLATE_EDITOR (editor));
- gtk_expander_set_expanded (GTK_EXPANDER (editor->expander), expanded);
+ private = GET_PRIVATE (editor);
+
+ gtk_expander_set_expanded (GTK_EXPANDER (private->expander), expanded);
+}
+
+GtkWidget *
+gimp_template_editor_get_size_se (GimpTemplateEditor *editor)
+{
+ g_return_val_if_fail (GIMP_IS_TEMPLATE_EDITOR (editor), NULL);
+
+ return GET_PRIVATE (editor)->size_se;
}
@@ -557,10 +608,13 @@ static void
gimp_template_editor_set_pixels (GimpTemplateEditor *editor,
GimpTemplate *template)
{
- gchar *text = g_strdup_printf (ngettext ("%d Ã? %d pixel",
- "%d Ã? %d pixels", template->height),
- template->width, template->height);
- gtk_label_set_text (GTK_LABEL (editor->pixel_label), text);
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (editor);
+ gchar *text;
+
+ text = g_strdup_printf (ngettext ("%d Ã? %d pixel",
+ "%d Ã? %d pixels", template->height),
+ template->width, template->height);
+ gtk_label_set_text (GTK_LABEL (private->pixel_label), text);
g_free (text);
}
@@ -568,10 +622,12 @@ static void
gimp_template_editor_aspect_callback (GtkWidget *widget,
GimpTemplateEditor *editor)
{
- if (! editor->block_aspect &&
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (editor);
+
+ if (! private->block_aspect &&
gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)))
{
- GimpTemplate *template = editor->template;
+ GimpTemplate *template = private->template;
gint width = template->width;
gint height = template->height;
gdouble xresolution = template->xresolution;
@@ -579,10 +635,10 @@ gimp_template_editor_aspect_callback (GtkWidget *widget,
if (template->width == template->height)
{
- editor->block_aspect = TRUE;
- gimp_int_radio_group_set_active (GTK_RADIO_BUTTON (editor->aspect_button),
+ private->block_aspect = TRUE;
+ gimp_int_radio_group_set_active (GTK_RADIO_BUTTON (private->aspect_button),
GIMP_ASPECT_SQUARE);
- editor->block_aspect = FALSE;
+ private->block_aspect = FALSE;
return;
}
@@ -590,9 +646,9 @@ gimp_template_editor_aspect_callback (GtkWidget *widget,
gimp_template_editor_template_notify,
editor);
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 0,
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 0,
yresolution, FALSE);
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 1,
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 1,
xresolution, FALSE);
g_object_set (template,
@@ -615,29 +671,30 @@ gimp_template_editor_template_notify (GimpTemplate *template,
GParamSpec *param_spec,
GimpTemplateEditor *editor)
{
- GimpAspectType aspect;
- const gchar *desc;
- gchar *text;
- gint xres;
- gint yres;
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (editor);
+ GimpAspectType aspect;
+ const gchar *desc;
+ gchar *text;
+ gint xres;
+ gint yres;
if (param_spec)
{
if (! strcmp (param_spec->name, "xresolution"))
{
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 0,
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 0,
template->xresolution, FALSE);
}
else if (! strcmp (param_spec->name, "yresolution"))
{
- gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (editor->size_se), 1,
+ gimp_size_entry_set_resolution (GIMP_SIZE_ENTRY (private->size_se), 1,
template->yresolution, FALSE);
}
}
#ifdef ENABLE_MEMSIZE_LABEL
text = g_format_size_for_display (template->initial_size);
- gtk_label_set_text (GTK_LABEL (editor->memsize_label), text);
+ gtk_label_set_text (GTK_LABEL (private->memsize_label), text);
g_free (text);
#endif
@@ -650,10 +707,10 @@ gimp_template_editor_template_notify (GimpTemplate *template,
else
aspect = GIMP_ASPECT_SQUARE;
- editor->block_aspect = TRUE;
- gimp_int_radio_group_set_active (GTK_RADIO_BUTTON (editor->aspect_button),
+ private->block_aspect = TRUE;
+ gimp_int_radio_group_set_active (GTK_RADIO_BUTTON (private->aspect_button),
aspect);
- editor->block_aspect = FALSE;
+ private->block_aspect = FALSE;
gimp_enum_get_value (GIMP_TYPE_IMAGE_BASE_TYPE, template->image_type,
NULL, NULL, &desc, NULL);
@@ -666,20 +723,20 @@ gimp_template_editor_template_notify (GimpTemplate *template,
else
text = g_strdup_printf (_("%d ppi, %s"), yres, desc);
- gtk_label_set_text (GTK_LABEL (editor->more_label), text);
+ gtk_label_set_text (GTK_LABEL (private->more_label), text);
g_free (text);
- if (editor->stock_id_container)
+ if (private->stock_id_container)
{
GimpObject *object;
const gchar *stock_id;
stock_id = gimp_viewable_get_stock_id (GIMP_VIEWABLE (template));
- object = gimp_container_get_child_by_name (editor->stock_id_container,
+ object = gimp_container_get_child_by_name (private->stock_id_container,
stock_id);
- gimp_context_set_template (editor->stock_id_context,
+ gimp_context_set_template (private->stock_id_context,
(GimpTemplate *) object);
}
}
@@ -689,7 +746,9 @@ gimp_template_editor_icon_changed (GimpContext *context,
GimpTemplate *template,
GimpTemplateEditor *editor)
{
- g_object_set (editor->template,
+ GimpTemplateEditorPrivate *private = GET_PRIVATE (editor);
+
+ g_object_set (private->template,
"stock-id", gimp_object_get_name (template),
NULL);
}
diff --git a/app/widgets/gimptemplateeditor.h b/app/widgets/gimptemplateeditor.h
index b5e9b27..0c47833 100644
--- a/app/widgets/gimptemplateeditor.h
+++ b/app/widgets/gimptemplateeditor.h
@@ -34,22 +34,7 @@ typedef struct _GimpTemplateEditorClass GimpTemplateEditorClass;
struct _GimpTemplateEditor
{
- GtkBox parent_instance;
-
- GimpTemplate *template;
-
- GimpContainer *stock_id_container;
- GimpContext *stock_id_context;
-
- GtkWidget *aspect_button;
- gboolean block_aspect;
-
- GtkWidget *expander;
- GtkWidget *size_se;
- GtkWidget *memsize_label;
- GtkWidget *pixel_label;
- GtkWidget *more_label;
- GtkWidget *resolution_se;
+ GtkBox parent_instance;
};
struct _GimpTemplateEditorClass
@@ -58,14 +43,17 @@ struct _GimpTemplateEditorClass
};
-GType gimp_template_editor_get_type (void) G_GNUC_CONST;
+GType gimp_template_editor_get_type (void) G_GNUC_CONST;
+
+GtkWidget * gimp_template_editor_new (GimpTemplate *template,
+ Gimp *gimp,
+ gboolean edit_template);
-GtkWidget * gimp_template_editor_new (GimpTemplate *template,
- Gimp *gimp,
- gboolean edit_template);
+GimpTemplate * gimp_template_editor_get_template (GimpTemplateEditor *editor);
-void gimp_template_editor_show_advanced (GimpTemplateEditor *editor,
- gboolean expanded);
+void gimp_template_editor_show_advanced (GimpTemplateEditor *editor,
+ gboolean expanded);
+GtkWidget * gimp_template_editor_get_size_se (GimpTemplateEditor *editor);
#endif /* __GIMP_TEMPLATE_EDITOR_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]