summaryrefslogtreecommitdiff
path: root/gtk/gtkgamma.c
diff options
context:
space:
mode:
authorOwen Taylor <owt1@cornell.edu>1998-03-18 21:11:04 +0000
committerOwen Taylor <otaylor@src.gnome.org>1998-03-18 21:11:04 +0000
commitf9739e834376121d8f766072499126e1cac2f332 (patch)
treedb18acfaf13950986d1f9098980326cfabfb1d5a /gtk/gtkgamma.c
parent85d4cd0f43c29fcca9c38282d7fa169bf775409e (diff)
downloadgtk+-f9739e834376121d8f766072499126e1cac2f332.tar.gz
( From: James Henstridge <james@daa.com.au> )
Wed Mar 18 11:09:10 1998 Owen Taylor <owt1@cornell.edu> ( From: James Henstridge <james@daa.com.au> ) * gtk/gtkclist.c: Don't remove, then destroy labels in gtk_clist_set_column_[*], just remove them. * gtk/gtkmain.c (gtk_invoke_timeout_function): call marshal when appropriate, not function. Tue Mar 17 14:15:07 1998 Owen Taylor <owt1@cornell.edu> * gtk/testgtk.c (create_main_window): Alphabetize tests * gtk/gtk[hv]paned.c: Change division on resize if necessary to keep handle visible. * gtk/gtkgamma.c gtk/gtkcurve.c: Moved initialization into _init() functions. * gtk/gtkscrolledwindow.c: Added missing _construct() functions.
Diffstat (limited to 'gtk/gtkgamma.c')
-rw-r--r--gtk/gtkgamma.c104
1 files changed, 53 insertions, 51 deletions
diff --git a/gtk/gtkgamma.c b/gtk/gtkgamma.c
index cfad6cc8b8..db4b903fd2 100644
--- a/gtk/gtkgamma.c
+++ b/gtk/gtkgamma.c
@@ -42,6 +42,11 @@ static void gtk_gamma_curve_class_init (GtkGammaCurveClass *class);
static void gtk_gamma_curve_init (GtkGammaCurve *curve);
static void gtk_gamma_curve_destroy (GtkObject *object);
+static void curve_type_changed_callback (GtkWidget *w, gpointer data);
+static void button_realize_callback (GtkWidget *w);
+static void button_toggled_callback (GtkWidget *w, gpointer data);
+static void button_clicked_callback (GtkWidget *w, gpointer data);
+
enum
{
LINEAR = 0,
@@ -234,7 +239,54 @@ gtk_gamma_curve_class_init (GtkGammaCurveClass *class)
static void
gtk_gamma_curve_init (GtkGammaCurve *curve)
{
+ GtkWidget *vbox;
+ int i;
+
curve->gamma = 1.0;
+
+ curve->table = gtk_table_new (1, 2, FALSE);
+ gtk_table_set_col_spacings (GTK_TABLE (curve->table), 3);
+ gtk_container_add (GTK_CONTAINER (curve), curve->table);
+
+ curve->curve = gtk_curve_new ();
+ gtk_signal_connect (GTK_OBJECT (curve->curve), "curve_type_changed",
+ (GtkSignalFunc) curve_type_changed_callback, curve);
+ gtk_table_attach_defaults (GTK_TABLE (curve->table), curve->curve, 0, 1, 0, 1);
+
+ vbox = gtk_vbox_new (/* homogeneous */ FALSE, /* spacing */ 3);
+ gtk_table_attach (GTK_TABLE (curve->table), vbox, 1, 2, 0, 1, 0, 0, 0, 0);
+
+ /* toggle buttons: */
+ for (i = 0; i < 3; ++i)
+ {
+ curve->button[i] = gtk_toggle_button_new ();
+ gtk_object_set_data (GTK_OBJECT (curve->button[i]), "_GtkGammaCurveIndex",
+ (gpointer) (long) i);
+ gtk_container_add (GTK_CONTAINER (vbox), curve->button[i]);
+ gtk_signal_connect (GTK_OBJECT (curve->button[i]), "realize",
+ (GtkSignalFunc) button_realize_callback, 0);
+ gtk_signal_connect (GTK_OBJECT (curve->button[i]), "toggled",
+ (GtkSignalFunc) button_toggled_callback, curve);
+ gtk_widget_show (curve->button[i]);
+ }
+
+ /* push buttons: */
+ for (i = 3; i < 5; ++i)
+ {
+ curve->button[i] = gtk_button_new ();
+ gtk_object_set_data (GTK_OBJECT (curve->button[i]), "_GtkGammaCurveIndex",
+ (gpointer) (long) i);
+ gtk_container_add (GTK_CONTAINER (vbox), curve->button[i]);
+ gtk_signal_connect (GTK_OBJECT (curve->button[i]), "realize",
+ (GtkSignalFunc) button_realize_callback, 0);
+ gtk_signal_connect (GTK_OBJECT (curve->button[i]), "clicked",
+ (GtkSignalFunc) button_clicked_callback, curve);
+ gtk_widget_show (curve->button[i]);
+ }
+
+ gtk_widget_show (vbox);
+ gtk_widget_show (curve->table);
+ gtk_widget_show (curve->curve);
}
static void
@@ -395,57 +447,7 @@ curve_type_changed_callback (GtkWidget *w, gpointer data)
GtkWidget*
gtk_gamma_curve_new (void)
{
- GtkGammaCurve *c;
- GtkWidget *vbox;
- int i;
-
- c = gtk_type_new (gtk_gamma_curve_get_type ());
-
- c->table = gtk_table_new (1, 2, FALSE);
- gtk_table_set_col_spacings (GTK_TABLE (c->table), 3);
- gtk_container_add (GTK_CONTAINER (c), c->table);
-
- c->curve = gtk_curve_new ();
- gtk_signal_connect (GTK_OBJECT (c->curve), "curve_type_changed",
- (GtkSignalFunc) curve_type_changed_callback, c);
- gtk_table_attach_defaults (GTK_TABLE (c->table), c->curve, 0, 1, 0, 1);
-
- vbox = gtk_vbox_new (/* homogeneous */ FALSE, /* spacing */ 3);
- gtk_table_attach (GTK_TABLE (c->table), vbox, 1, 2, 0, 1, 0, 0, 0, 0);
-
- /* toggle buttons: */
- for (i = 0; i < 3; ++i)
- {
- c->button[i] = gtk_toggle_button_new ();
- gtk_object_set_data (GTK_OBJECT (c->button[i]), "_GtkGammaCurveIndex",
- (gpointer) (long) i);
- gtk_container_add (GTK_CONTAINER (vbox), c->button[i]);
- gtk_signal_connect (GTK_OBJECT (c->button[i]), "realize",
- (GtkSignalFunc) button_realize_callback, 0);
- gtk_signal_connect (GTK_OBJECT (c->button[i]), "toggled",
- (GtkSignalFunc) button_toggled_callback, c);
- gtk_widget_show (c->button[i]);
- }
-
- /* push buttons: */
- for (i = 3; i < 5; ++i)
- {
- c->button[i] = gtk_button_new ();
- gtk_object_set_data (GTK_OBJECT (c->button[i]), "_GtkGammaCurveIndex",
- (gpointer) (long) i);
- gtk_container_add (GTK_CONTAINER (vbox), c->button[i]);
- gtk_signal_connect (GTK_OBJECT (c->button[i]), "realize",
- (GtkSignalFunc) button_realize_callback, 0);
- gtk_signal_connect (GTK_OBJECT (c->button[i]), "clicked",
- (GtkSignalFunc) button_clicked_callback, c);
- gtk_widget_show (c->button[i]);
- }
-
- gtk_widget_show (vbox);
- gtk_widget_show (c->table);
- gtk_widget_show (c->curve);
-
- return GTK_WIDGET (c);
+ return gtk_type_new (gtk_gamma_curve_get_type ());
}
static void