[gimp/gtk3-port: 39/170] app: port to GtkWidget::draw() and s/GtkObject/GtkAdjustment/
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/gtk3-port: 39/170] app: port to GtkWidget::draw() and s/GtkObject/GtkAdjustment/
- Date: Mon, 20 Dec 2010 22:23:34 +0000 (UTC)
commit e15a0cb800f5b2d112d020d5ac432faa9ad8d315
Author: Michael Natterer <mitch gimp org>
Date: Fri Oct 15 14:19:42 2010 +0200
app: port to GtkWidget::draw() and s/GtkObject/GtkAdjustment/
app/widgets/gimpgradienteditor.c | 70 ++++++++++++++++++--------------------
app/widgets/gimpgradienteditor.h | 2 +-
2 files changed, 34 insertions(+), 38 deletions(-)
---
diff --git a/app/widgets/gimpgradienteditor.c b/app/widgets/gimpgradienteditor.c
index a5fe306..84e1cc8 100644
--- a/app/widgets/gimpgradienteditor.c
+++ b/app/widgets/gimpgradienteditor.c
@@ -163,8 +163,8 @@ static void view_pick_color (GimpGradientEditor *editor,
static gboolean control_events (GtkWidget *widget,
GdkEvent *event,
GimpGradientEditor *editor);
-static gboolean control_expose (GtkWidget *widget,
- GdkEventExpose *event,
+static gboolean control_draw (GtkWidget *widget,
+ cairo_t *cr,
GimpGradientEditor *editor);
static void control_do_hint (GimpGradientEditor *editor,
gint x,
@@ -205,7 +205,7 @@ static double control_move (GimpGradientEditor *editor,
static void control_update (GimpGradientEditor *editor,
GimpGradient *gradient,
gboolean recalculate);
-static void control_draw (GimpGradientEditor *editor,
+static void control_draw_all (GimpGradientEditor *editor,
GimpGradient *gradient,
cairo_t *cr,
gint width,
@@ -356,8 +356,8 @@ gimp_gradient_editor_init (GimpGradientEditor *editor)
G_CALLBACK (control_events),
editor);
- g_signal_connect (editor->control, "expose-event",
- G_CALLBACK (control_expose),
+ g_signal_connect (editor->control, "draw",
+ G_CALLBACK (control_draw),
editor);
gimp_dnd_color_dest_add (GTK_WIDGET (editor->control),
@@ -379,7 +379,7 @@ gimp_gradient_editor_init (GimpGradientEditor *editor)
G_CALLBACK (gradient_editor_scrollbar_update),
editor);
- editor->scrollbar = gtk_hscrollbar_new (GTK_ADJUSTMENT (editor->scroll_data));
+ editor->scrollbar = gtk_hscrollbar_new (editor->scroll_data);
gtk_range_set_update_policy (GTK_RANGE (editor->scrollbar),
GTK_UPDATE_CONTINUOUS);
gtk_box_pack_start (GTK_BOX (editor), editor->scrollbar, FALSE, FALSE, 0);
@@ -581,7 +581,7 @@ gimp_gradient_editor_zoom (GimpGradientEditor *editor,
g_return_if_fail (GIMP_IS_GRADIENT_EDITOR (editor));
- adjustment = GTK_ADJUSTMENT (editor->scroll_data);
+ adjustment = editor->scroll_data;
old_value = gtk_adjustment_get_value (adjustment);
old_page_size = gtk_adjustment_get_page_size (adjustment);
@@ -918,7 +918,7 @@ view_events (GtkWidget *widget,
}
else
{
- GtkAdjustment *adj = GTK_ADJUSTMENT (editor->scroll_data);
+ GtkAdjustment *adj = editor->scroll_data;
gfloat value = gtk_adjustment_get_value (adj);
switch (sevent->direction)
@@ -1117,9 +1117,8 @@ control_events (GtkWidget *widget,
}
else
{
- GtkAdjustment *adj = GTK_ADJUSTMENT (editor->scroll_data);
-
- gfloat new_value;
+ GtkAdjustment *adj = editor->scroll_data;
+ gfloat new_value;
new_value = (gtk_adjustment_get_value (adj) +
((sevent->direction == GDK_SCROLL_UP) ?
@@ -1223,26 +1222,23 @@ control_events (GtkWidget *widget,
}
static gboolean
-control_expose (GtkWidget *widget,
- GdkEventExpose *event,
- GimpGradientEditor *editor)
+control_draw (GtkWidget *widget,
+ cairo_t *cr,
+ GimpGradientEditor *editor)
{
- GtkAdjustment *adj = GTK_ADJUSTMENT (editor->scroll_data);
- cairo_t *cr = gdk_cairo_create (gtk_widget_get_window (widget));
- gint width;
- gint height;
-
- gdk_drawable_get_size (gtk_widget_get_window (widget), &width, &height);
+ GtkAdjustment *adj = editor->scroll_data;
+ GtkAllocation allocation;
- control_draw (editor,
- GIMP_GRADIENT (GIMP_DATA_EDITOR (editor)->data),
- cr,
- width, height,
- gtk_adjustment_get_value (adj),
- gtk_adjustment_get_value (adj) +
- gtk_adjustment_get_page_size (adj));
+ gtk_widget_get_allocation (widget, &allocation);
- cairo_destroy (cr);
+ control_draw_all (editor,
+ GIMP_GRADIENT (GIMP_DATA_EDITOR (editor)->data),
+ cr,
+ allocation.width,
+ allocation.height,
+ gtk_adjustment_get_value (adj),
+ gtk_adjustment_get_value (adj) +
+ gtk_adjustment_get_page_size (adj));
return TRUE;
}
@@ -1739,13 +1735,13 @@ control_update (GimpGradientEditor *editor,
}
static void
-control_draw (GimpGradientEditor *editor,
- GimpGradient *gradient,
- cairo_t *cr,
- gint width,
- gint height,
- gdouble left,
- gdouble right)
+control_draw_all (GimpGradientEditor *editor,
+ GimpGradient *gradient,
+ cairo_t *cr,
+ gint width,
+ gint height,
+ gdouble left,
+ gdouble right)
{
GtkStyle *control_style;
GimpGradientSegment *seg;
@@ -1890,7 +1886,7 @@ static gint
control_calc_p_pos (GimpGradientEditor *editor,
gdouble pos)
{
- GtkAdjustment *adjustment = GTK_ADJUSTMENT (editor->scroll_data);
+ GtkAdjustment *adjustment = editor->scroll_data;
GtkAllocation allocation;
gint pwidth;
@@ -1912,7 +1908,7 @@ static gdouble
control_calc_g_pos (GimpGradientEditor *editor,
gint pos)
{
- GtkAdjustment *adjustment = GTK_ADJUSTMENT (editor->scroll_data);
+ GtkAdjustment *adjustment = editor->scroll_data;
GtkAllocation allocation;
gint pwidth;
diff --git a/app/widgets/gimpgradienteditor.h b/app/widgets/gimpgradienteditor.h
index 9f4be26..2fb8ddc 100644
--- a/app/widgets/gimpgradienteditor.h
+++ b/app/widgets/gimpgradienteditor.h
@@ -61,7 +61,7 @@ struct _GimpGradientEditor
/* Zoom and scrollbar */
guint zoom_factor;
- GtkObject *scroll_data;
+ GtkAdjustment *scroll_data;
/* Instant update */
gboolean instant_update;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]