diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/Makefile.am | 17 | ||||
-rw-r--r-- | tests/autotestfilechooser.c | 3 | ||||
-rw-r--r-- | tests/defaultvaluetest.c | 3 | ||||
-rw-r--r-- | tests/objecttests.c | 3 | ||||
-rw-r--r-- | tests/testgtk.c | 13834 | ||||
-rw-r--r-- | tests/textbuffertest.c | 3 |
6 files changed, 42 insertions, 13821 deletions
diff --git a/tests/Makefile.am b/tests/Makefile.am index 0131e366bd..38205b24d9 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -29,26 +29,29 @@ TEST_PROGS += floatingtest floatingtest_DEPENDENCIES = $(TEST_DEPS) floatingtest_LDADD = $(LDADDS) TEST_PROGS += objecttests -objecttests_SOURCES = objecttests.c +objecttests_SOURCES = objecttests.c pixbuf-init.c objecttests_LDADD = $(LDADDS) objecttests_DEPENDENCIES = $(TEST_DEPS) -TEST_PROGS += autotestfilechooser +# this doesn't work in make distcheck, since it doesn't +# find file-chooser-test-dir +# TEST_PROGS += autotestfilechooser autotestfilechooser_DEPENDENCIES = $(TEST_DEPS) autotestfilechooser_LDADD = $(LDADDS) -autotestfilechooser_SOURCES = autotestfilechooser.c +autotestfilechooser_SOURCES = autotestfilechooser.c pixbuf-init.c TEST_PROGS += buildertest buildertest_DEPENDENCIES = $(TEST_DEPS) buildertest_LDADD = $(LDADDS) buildertest_LDFLAGS = -export-dynamic if OS_UNIX -TEST_PROGS += defaultvaluetest +TEST_PROGS += defaultvaluetest endif defaultvaluetest_DEPENDENCIES = $(TEST_DEPS) defaultvaluetest_LDADD = $(LDADDS) +defaultvaluetest_SOURCES = defaultvaluetest.c pixbuf-init.c TEST_PROGS += textbuffertest textbuffertest_DEPENDENCIES = $(TEST_DEPS) textbuffertest_LDADD = $(LDADDS) -textbuffertest_SOURCES = textbuffertest.c +textbuffertest_SOURCES = textbuffertest.c pixbuf-init.c noinst_PROGRAMS = $(TEST_PROGS) \ autotestkeywords \ @@ -345,5 +348,7 @@ EXTRA_DIST += \ merge-2.ui \ merge-3.ui \ gnome-textfile.png \ - makefile.msc + makefile.msc \ + file-chooser-test-dir/empty \ + file-chooser-test-dir/text.txt diff --git a/tests/autotestfilechooser.c b/tests/autotestfilechooser.c index 696dea2d3e..1742d1b882 100644 --- a/tests/autotestfilechooser.c +++ b/tests/autotestfilechooser.c @@ -1064,10 +1064,13 @@ test_folder_switch_and_filters (void) log_test (passed, "test_folder_switch_and_filters(): all filter tests"); } +extern void pixbuf_init (void); + int main (int argc, char **argv) { + pixbuf_init (); /* initialize test program */ gtk_test_init (&argc, &argv); diff --git a/tests/defaultvaluetest.c b/tests/defaultvaluetest.c index b36e7fb9ac..8937aa8665 100644 --- a/tests/defaultvaluetest.c +++ b/tests/defaultvaluetest.c @@ -312,6 +312,8 @@ test_type (gconstpointer data) g_type_class_unref (klass); } +extern void pixbuf_init (void); + int main (int argc, char **argv) { @@ -319,6 +321,7 @@ main (int argc, char **argv) guint i; gtk_test_init (&argc, &argv); + pixbuf_init (); gtk_test_register_all_types(); otypes = gtk_test_list_all_types (NULL); diff --git a/tests/objecttests.c b/tests/objecttests.c index 5be64b62d1..c24ba9f7df 100644 --- a/tests/objecttests.c +++ b/tests/objecttests.c @@ -330,6 +330,8 @@ widget_property_tests (gconstpointer test_data) g_object_unref (widget); } +extern void pixbuf_init (void); + /* --- main test program --- */ int main (int argc, @@ -338,6 +340,7 @@ main (int argc, const GType *otypes; guint i; /* initialize test program */ + pixbuf_init (); gtk_test_init (&argc, &argv); gtk_test_register_all_types(); /* install a property test for each widget type */ diff --git a/tests/testgtk.c b/tests/testgtk.c index 1c0dde58e0..03afb44fb0 100644 --- a/tests/testgtk.c +++ b/tests/testgtk.c @@ -1,13831 +1,35 @@ -/* GTK - The GIMP Toolkit - * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ +#include <gtk/gtk.h> -/* - * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS - * file for a list of people on the GTK+ Team. See the ChangeLog - * files for a list of changes. These files are distributed with - * GTK+ at ftp://ftp.gtk.org/pub/gtk/. - */ - -#undef GTK_DISABLE_DEPRECATED - -#include <config.h> - -#undef G_LOG_DOMAIN - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <sys/stat.h> -#include <math.h> -#include <time.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif - -#define GTK_ENABLE_BROKEN -#include "gtk/gtk.h" -#include "gdk/gdk.h" -#include "gdk/gdkkeysyms.h" - -#ifdef G_OS_WIN32 -#define sleep(n) _sleep(n) -#endif - -#include "prop-editor.h" - -#include "circles.xbm" -#include "test.xpm" - -gboolean -file_exists (const char *filename) -{ - struct stat statbuf; - - return stat (filename, &statbuf) == 0; -} - -GtkWidget * -shape_create_icon (GdkScreen *screen, - char *xpm_file, - gint x, - gint y, - gint px, - gint py, - gint window_type); - -static GtkWidget * -build_option_menu (gchar *items[], - gint num_items, - gint history, - void (*func) (GtkWidget *widget, gpointer data), - gpointer data); - -/* macro, structure and variables used by tree window demos */ -#define DEFAULT_NUMBER_OF_ITEM 3 -#define DEFAULT_RECURSION_LEVEL 3 - -struct { - GSList* selection_mode_group; - GtkWidget* single_button; - GtkWidget* browse_button; - GtkWidget* multiple_button; - GtkWidget* draw_line_button; - GtkWidget* view_line_button; - GtkWidget* no_root_item_button; - GtkWidget* nb_item_spinner; - GtkWidget* recursion_spinner; -} sTreeSampleSelection; - -typedef struct sTreeButtons { - guint nb_item_add; - GtkWidget* add_button; - GtkWidget* remove_button; - GtkWidget* subtree_button; -} sTreeButtons; -/* end of tree section */ - -static GtkWidget * -build_option_menu (gchar *items[], - gint num_items, - gint history, - void (*func)(GtkWidget *widget, gpointer data), - gpointer data) -{ - GtkWidget *omenu; - GtkWidget *menu; - GtkWidget *menu_item; - GSList *group; - gint i; - - omenu = gtk_option_menu_new (); - g_signal_connect (omenu, "changed", - G_CALLBACK (func), data); - - menu = gtk_menu_new (); - group = NULL; - - for (i = 0; i < num_items; i++) - { - menu_item = gtk_radio_menu_item_new_with_label (group, items[i]); - group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menu_item)); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item); - if (i == history) - gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (menu_item), TRUE); - gtk_widget_show (menu_item); - } - - gtk_option_menu_set_menu (GTK_OPTION_MENU (omenu), menu); - gtk_option_menu_set_history (GTK_OPTION_MENU (omenu), history); - - return omenu; -} - -static void -destroy_tooltips (GtkWidget *widget, GtkWindow **window) -{ - GtkTooltips *tt = g_object_get_data (G_OBJECT (*window), "tooltips"); - g_object_unref (tt); - *window = NULL; -} - - -/* - * Windows with an alpha channel - */ - - -static gboolean -on_alpha_window_expose (GtkWidget *widget, - GdkEventExpose *expose) -{ - cairo_t *cr; - cairo_pattern_t *pattern; - int radius; - - cr = gdk_cairo_create (widget->window); - - radius = MIN (widget->allocation.width, widget->allocation.height) / 2; - pattern = cairo_pattern_create_radial (widget->allocation.width / 2, - widget->allocation.height / 2, - 0.0, - widget->allocation.width / 2, - widget->allocation.height / 2, - radius * 1.33); - - if (gdk_screen_get_rgba_colormap (gtk_widget_get_screen (widget)) && - gtk_widget_is_composited (widget)) - cairo_set_source_rgba (cr, 1.0, 1.0, 1.0, 0.0); /* transparent */ - else - cairo_set_source_rgb (cr, 1.0, 1.0, 1.0); /* opaque white */ - - cairo_set_operator (cr, CAIRO_OPERATOR_SOURCE); - cairo_paint (cr); - - cairo_pattern_add_color_stop_rgba (pattern, 0.0, - 1.0, 0.75, 0.0, 1.0); /* solid orange */ - cairo_pattern_add_color_stop_rgba (pattern, 1.0, - 1.0, 0.75, 0.0, 0.0); /* transparent orange */ - - cairo_set_source (cr, pattern); - cairo_pattern_destroy (pattern); - - cairo_set_operator (cr, CAIRO_OPERATOR_OVER); - cairo_paint (cr); - - cairo_destroy (cr); - - return FALSE; -} - -static GtkWidget * -build_alpha_widgets (void) -{ - GtkWidget *table; - GtkWidget *radio_button; - GtkWidget *hbox; - GtkWidget *label; - GtkWidget *entry; - - table = gtk_table_new (1, 1, FALSE); - - radio_button = gtk_radio_button_new_with_label (NULL, "Red"); - gtk_table_attach (GTK_TABLE (table), - radio_button, - 0, 1, 0, 1, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - radio_button = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (radio_button), "Green"); - gtk_table_attach (GTK_TABLE (table), - radio_button, - 0, 1, 1, 2, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - radio_button = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (radio_button), "Blue"), - gtk_table_attach (GTK_TABLE (table), - radio_button, - 0, 1, 2, 3, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - gtk_table_attach (GTK_TABLE (table), - gtk_check_button_new_with_label ("Sedentary"), - 1, 2, 0, 1, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - gtk_table_attach (GTK_TABLE (table), - gtk_check_button_new_with_label ("Nocturnal"), - 1, 2, 1, 2, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - gtk_table_attach (GTK_TABLE (table), - gtk_check_button_new_with_label ("Compulsive"), - 1, 2, 2, 3, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - radio_button = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (radio_button), "Green"); - gtk_table_attach (GTK_TABLE (table), - radio_button, - 0, 1, 1, 2, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - radio_button = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (radio_button), "Blue"), - gtk_table_attach (GTK_TABLE (table), - radio_button, - 0, 1, 2, 3, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - hbox = gtk_hbox_new (FALSE, 0); - label = gtk_label_new (NULL); - gtk_label_set_markup (GTK_LABEL (label), "<i>Entry: </i>"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0); - entry = gtk_entry_new (); - gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0); - gtk_table_attach (GTK_TABLE (table), - hbox, - 0, 1, 3, 4, - GTK_EXPAND | GTK_FILL, 0, - 0, 0); - - return table; -} - -static gboolean -on_alpha_drawing_expose (GtkWidget *widget, - GdkEventExpose *expose) -{ - int x = widget->allocation.x; - int y = widget->allocation.y; - int width = widget->allocation.width; - int height = widget->allocation.height; - GdkPixbuf *pixbuf; - guchar *buffer; - guchar *p; - int i, j; - - buffer = g_malloc (64 * 64 * 4); - - gdk_draw_rectangle (widget->window, widget->style->black_gc, FALSE, - x, y, - width - 1, height - 1); - - p = buffer; - for (i = 0; i < 64; i++) { - for (j = 0; j < 64; j++) { - *(p++) = i * 4 + 3; - *(p++) = 0; - *(p++) = j + 4 + 3; - *(p++) = MIN (255, ((32 - i) * (32 - i) + (32 - j) * (32 - j)) / 8); - } - } - p++; - - gdk_draw_rgb_32_image (widget->window, widget->style->black_gc, - x + 18, y + (height - 64) /2, - 64, 64, GDK_RGB_DITHER_NORMAL, buffer, 64 * 4); - - pixbuf = gdk_pixbuf_new_from_data (buffer, GDK_COLORSPACE_RGB, TRUE, - 8, 64, 64, 4 * 64, NULL, NULL); - - gdk_draw_pixbuf (widget->window, widget->style->black_gc, pixbuf, - 0, 0, x + width - 18 - 64, y + (height - 64) /2, - 64, 64, GDK_RGB_DITHER_NORMAL, 0, 0); - - g_object_unref (pixbuf); - - g_free (buffer); - - return FALSE; -} - -static GtkWidget * -build_alpha_drawing () -{ - GtkWidget *hbox; - - hbox = gtk_hbox_new (FALSE, 0); - gtk_widget_set_size_request (hbox, 100, 100); - - g_signal_connect (hbox, "expose-event", - G_CALLBACK (on_alpha_drawing_expose), NULL); - - return hbox; -} - -static void -on_alpha_screen_changed (GtkWidget *widget, - GdkScreen *old_screen, - GtkWidget *label) -{ - GdkScreen *screen = gtk_widget_get_screen (widget); - GdkColormap *colormap = gdk_screen_get_rgba_colormap (screen); - - if (!colormap) - { - colormap = gdk_screen_get_rgb_colormap (screen); - gtk_label_set_markup (GTK_LABEL (label), "<b>Screen doesn't support alpha</b>"); - } - else - { - gtk_label_set_markup (GTK_LABEL (label), "<b>Screen supports alpha</b>"); - } - - gtk_widget_set_colormap (widget, colormap); -} - -static void -on_composited_changed (GtkWidget *window, - GtkLabel *label) -{ - gboolean is_composited = gtk_widget_is_composited (window); - - if (is_composited) - gtk_label_set_text (label, "Composited"); - else - gtk_label_set_text (label, "Not composited"); -} - -void -create_alpha_window (GtkWidget *widget) -{ - static GtkWidget *window; - - if (!window) - { - GtkWidget *vbox; - GtkWidget *label; - - window = gtk_dialog_new_with_buttons ("Alpha Window", - GTK_WINDOW (gtk_widget_get_toplevel (widget)), 0, - GTK_STOCK_CLOSE, 0, - NULL); - - gtk_widget_set_app_paintable (window, TRUE); - g_signal_connect (window, "expose-event", - G_CALLBACK (on_alpha_window_expose), NULL); - - vbox = gtk_vbox_new (FALSE, 8); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 12); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox, - TRUE, TRUE, 0); - - label = gtk_label_new (NULL); - gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0); - on_alpha_screen_changed (window, NULL, label); - g_signal_connect (window, "screen-changed", - G_CALLBACK (on_alpha_screen_changed), label); - - label = gtk_label_new (NULL); - gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0); - on_composited_changed (window, GTK_LABEL (label)); - g_signal_connect (window, "composited_changed", G_CALLBACK (on_composited_changed), label); - - gtk_box_pack_start (GTK_BOX (vbox), build_alpha_widgets (), TRUE, TRUE, 0); - gtk_box_pack_start (GTK_BOX (vbox), build_alpha_drawing (), TRUE, TRUE, 0); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Composited non-toplevel window - */ - -/* The expose event handler for the event box. - * - * This function simply draws a transparency onto a widget on the area - * for which it receives expose events. This is intended to give the - * event box a "transparent" background. - * - * In order for this to work properly, the widget must have an RGBA - * colourmap. The widget should also be set as app-paintable since it - * doesn't make sense for GTK to draw a background if we are drawing it - * (and because GTK might actually replace our transparency with its - * default background colour). - */ -static gboolean -transparent_expose (GtkWidget *widget, - GdkEventExpose *event) -{ - cairo_t *cr; - - cr = gdk_cairo_create (widget->window); - cairo_set_operator (cr, CAIRO_OPERATOR_CLEAR); - gdk_cairo_region (cr, event->region); - cairo_fill (cr); - cairo_destroy (cr); - - return FALSE; -} - -/* The expose event handler for the window. - * - * This function performs the actual compositing of the event box onto - * the already-existing background of the window at 50% normal opacity. - * - * In this case we do not want app-paintable to be set on the widget - * since we want it to draw its own (red) background. Because of this, - * however, we must ensure that we use g_signal_register_after so that - * this handler is called after the red has been drawn. If it was - * called before then GTK would just blindly paint over our work. - */ -static gboolean -window_expose_event (GtkWidget *widget, - GdkEventExpose *event) -{ - GdkRegion *region; - GtkWidget *child; - cairo_t *cr; - - /* get our child (in this case, the event box) */ - child = gtk_bin_get_child (GTK_BIN (widget)); - - /* create a cairo context to draw to the window */ - cr = gdk_cairo_create (widget->window); - - /* the source data is the (composited) event box */ - gdk_cairo_set_source_pixmap (cr, child->window, - child->allocation.x, - child->allocation.y); - - /* draw no more than our expose event intersects our child */ - region = gdk_region_rectangle (&child->allocation); - gdk_region_intersect (region, event->region); - gdk_cairo_region (cr, region); - cairo_clip (cr); - - /* composite, with a 50% opacity */ - cairo_set_operator (cr, CAIRO_OPERATOR_OVER); - cairo_paint_with_alpha (cr, 0.5); - - /* we're done */ - cairo_destroy (cr); - - return FALSE; -} - -void -create_composited_window (GtkWidget *widget) -{ - static GtkWidget *window; - - if (!window) - { - GtkWidget *event, *button; - GdkScreen *screen; - GdkColormap *rgba; - GdkColor red; - - /* make the widgets */ - button = gtk_button_new_with_label ("A Button"); - event = gtk_event_box_new (); - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - /* put a red background on the window */ - gdk_color_parse ("red", &red); - gtk_widget_modify_bg (window, GTK_STATE_NORMAL, &red); - - /* set the colourmap for the event box. - * must be done before the event box is realised. - */ - screen = gtk_widget_get_screen (event); - rgba = gdk_screen_get_rgba_colormap (screen); - gtk_widget_set_colormap (event, rgba); - - /* set our event box to have a fully-transparent background - * drawn on it. currently there is no way to simply tell gtk - * that "transparency" is the background colour for a widget. - */ - gtk_widget_set_app_paintable (GTK_WIDGET (event), TRUE); - g_signal_connect (event, "expose-event", - G_CALLBACK (transparent_expose), NULL); - - /* put them inside one another */ - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - gtk_container_add (GTK_CONTAINER (window), event); - gtk_container_add (GTK_CONTAINER (event), button); - - /* realise and show everything */ - gtk_widget_realize (button); - - /* set the event box GdkWindow to be composited. - * obviously must be performed after event box is realised. - */ - gdk_window_set_composited (event->window, TRUE); - - /* set up the compositing handler. - * note that we do _after so that the normal (red) background is drawn - * by gtk before our compositing occurs. - */ - g_signal_connect_after (window, "expose-event", - G_CALLBACK (window_expose_event), NULL); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Big windows and guffaw scrolling - */ - -static gboolean -pattern_expose (GtkWidget *widget, - GdkEventExpose *event, - gpointer data) -{ - GdkColor *color; - GdkWindow *window = event->window; - - color = g_object_get_data (G_OBJECT (window), "pattern-color"); - if (color) - { - GdkGC *tmp_gc = gdk_gc_new (window); - gdk_gc_set_rgb_fg_color (tmp_gc, color); - - gdk_draw_rectangle (window, tmp_gc, TRUE, - event->area.x, event->area.y, - event->area.width, event->area.height); - - g_object_unref (tmp_gc); - } - - return FALSE; -} - -static void -pattern_set_bg (GtkWidget *widget, - GdkWindow *child, - gint level) -{ - static const GdkColor colors[] = { - { 0, 0x4444, 0x4444, 0xffff }, - { 0, 0x8888, 0x8888, 0xffff }, - { 0, 0xaaaa, 0xaaaa, 0xffff } - }; - - g_object_set_data (G_OBJECT (child), "pattern-color", (gpointer) &colors[level]); - gdk_window_set_user_data (child, widget); -} - -static void -create_pattern (GtkWidget *widget, - GdkWindow *parent, - gint level, - gint width, - gint height) -{ - gint h = 1; - gint i = 0; - - GdkWindow *child; - - while (2 * h <= height) - { - gint w = 1; - gint j = 0; - - while (2 * w <= width) - { - if ((i + j) % 2 == 0) - { - gint x = w - 1; - gint y = h - 1; - - GdkWindowAttr attributes; - - attributes.window_type = GDK_WINDOW_CHILD; - attributes.x = x; - attributes.y = y; - attributes.width = w; - attributes.height = h; - attributes.wclass = GDK_INPUT_OUTPUT; - attributes.event_mask = GDK_EXPOSURE_MASK; - attributes.visual = gtk_widget_get_visual (widget); - attributes.colormap = gtk_widget_get_colormap (widget); - - child = gdk_window_new (parent, &attributes, - GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP); - - pattern_set_bg (widget, child, level); - - if (level < 2) - create_pattern (widget, child, level + 1, w, h); - - gdk_window_show (child); - } - j++; - w *= 2; - } - i++; - h *= 2; - } -} - -#define PATTERN_SIZE (1 << 18) - -static void -pattern_hadj_changed (GtkAdjustment *adj, - GtkWidget *darea) -{ - gint *old_value = g_object_get_data (G_OBJECT (adj), "old-value"); - gint new_value = adj->value; - - if (GTK_WIDGET_REALIZED (darea)) - { - gdk_window_scroll (darea->window, *old_value - new_value, 0); - *old_value = new_value; - } -} - -static void -pattern_vadj_changed (GtkAdjustment *adj, - GtkWidget *darea) -{ - gint *old_value = g_object_get_data (G_OBJECT (adj), "old-value"); - gint new_value = adj->value; - - if (GTK_WIDGET_REALIZED (darea)) - { - gdk_window_scroll (darea->window, 0, *old_value - new_value); - *old_value = new_value; - } -} - -static void -pattern_realize (GtkWidget *widget, - gpointer data) -{ - pattern_set_bg (widget, widget->window, 0); - create_pattern (widget, widget->window, 1, PATTERN_SIZE, PATTERN_SIZE); -} - -static void -create_big_windows (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *darea, *table, *scrollbar; - GtkWidget *eventbox; - GtkAdjustment *hadj; - GtkAdjustment *vadj; - static gint current_x; - static gint current_y; - - if (!window) - { - current_x = 0; - current_y = 0; - - window = gtk_dialog_new_with_buttons ("Big Windows", - NULL, 0, - GTK_STOCK_CLOSE, - GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_default_size (GTK_WINDOW (window), 200, 300); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - - table = gtk_table_new (2, 2, FALSE); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - table, TRUE, TRUE, 0); - - darea = gtk_drawing_area_new (); - - hadj = (GtkAdjustment *)gtk_adjustment_new (0, 0, PATTERN_SIZE, 10, 100, 100); - g_signal_connect (hadj, "value_changed", - G_CALLBACK (pattern_hadj_changed), darea); - g_object_set_data (G_OBJECT (hadj), "old-value", ¤t_x); - - vadj = (GtkAdjustment *)gtk_adjustment_new (0, 0, PATTERN_SIZE, 10, 100, 100); - g_signal_connect (vadj, "value_changed", - G_CALLBACK (pattern_vadj_changed), darea); - g_object_set_data (G_OBJECT (vadj), "old-value", ¤t_y); - - g_signal_connect (darea, "realize", - G_CALLBACK (pattern_realize), - NULL); - g_signal_connect (darea, "expose_event", - G_CALLBACK (pattern_expose), - NULL); - - eventbox = gtk_event_box_new (); - gtk_table_attach (GTK_TABLE (table), eventbox, - 0, 1, 0, 1, - GTK_FILL | GTK_EXPAND, GTK_FILL | GTK_EXPAND, - 0, 0); - - gtk_container_add (GTK_CONTAINER (eventbox), darea); - - scrollbar = gtk_hscrollbar_new (hadj); - gtk_table_attach (GTK_TABLE (table), scrollbar, - 0, 1, 1, 2, - GTK_FILL | GTK_EXPAND, GTK_FILL, - 0, 0); - - scrollbar = gtk_vscrollbar_new (vadj); - gtk_table_attach (GTK_TABLE (table), scrollbar, - 1, 2, 0, 1, - GTK_FILL, GTK_EXPAND | GTK_FILL, - 0, 0); - - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_hide (window); -} - -/* - * GtkButton - */ - -static void -button_window (GtkWidget *widget, - GtkWidget *button) -{ - if (!GTK_WIDGET_VISIBLE (button)) - gtk_widget_show (button); - else - gtk_widget_hide (button); -} - -static void -create_buttons (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *table; - GtkWidget *button[10]; - GtkWidget *separator; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkButton"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - table = gtk_table_new (3, 3, FALSE); - gtk_table_set_row_spacings (GTK_TABLE (table), 5); - gtk_table_set_col_spacings (GTK_TABLE (table), 5); - gtk_container_set_border_width (GTK_CONTAINER (table), 10); - gtk_box_pack_start (GTK_BOX (box1), table, TRUE, TRUE, 0); - - button[0] = gtk_button_new_with_label ("button1"); - button[1] = gtk_button_new_with_mnemonic ("_button2"); - button[2] = gtk_button_new_with_mnemonic ("_button3"); - button[3] = gtk_button_new_from_stock (GTK_STOCK_OK); - button[4] = gtk_button_new_with_label ("button5"); - button[5] = gtk_button_new_with_label ("button6"); - button[6] = gtk_button_new_with_label ("button7"); - button[7] = gtk_button_new_from_stock (GTK_STOCK_CLOSE); - button[8] = gtk_button_new_with_label ("button9"); - - g_signal_connect (button[0], "clicked", - G_CALLBACK (button_window), - button[1]); - - gtk_table_attach (GTK_TABLE (table), button[0], 0, 1, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[1], "clicked", - G_CALLBACK (button_window), - button[2]); - - gtk_table_attach (GTK_TABLE (table), button[1], 1, 2, 1, 2, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[2], "clicked", - G_CALLBACK (button_window), - button[3]); - gtk_table_attach (GTK_TABLE (table), button[2], 2, 3, 2, 3, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[3], "clicked", - G_CALLBACK (button_window), - button[4]); - gtk_table_attach (GTK_TABLE (table), button[3], 0, 1, 2, 3, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[4], "clicked", - G_CALLBACK (button_window), - button[5]); - gtk_table_attach (GTK_TABLE (table), button[4], 2, 3, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[5], "clicked", - G_CALLBACK (button_window), - button[6]); - gtk_table_attach (GTK_TABLE (table), button[5], 1, 2, 2, 3, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[6], "clicked", - G_CALLBACK (button_window), - button[7]); - gtk_table_attach (GTK_TABLE (table), button[6], 1, 2, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[7], "clicked", - G_CALLBACK (button_window), - button[8]); - gtk_table_attach (GTK_TABLE (table), button[7], 2, 3, 1, 2, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - g_signal_connect (button[8], "clicked", - G_CALLBACK (button_window), - button[0]); - gtk_table_attach (GTK_TABLE (table), button[8], 0, 1, 1, 2, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button[9] = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button[9], "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button[9], TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button[9], GTK_CAN_DEFAULT); - gtk_widget_grab_default (button[9]); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkToggleButton - */ - -static void -create_toggle_buttons (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *separator; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkToggleButton"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_toggle_button_new_with_label ("button1"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_toggle_button_new_with_label ("button2"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_toggle_button_new_with_label ("button3"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_toggle_button_new_with_label ("inconsistent"); - gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -static GtkWidget * -create_widget_grid (GType widget_type) -{ - GtkWidget *table; - GtkWidget *group_widget = NULL; - gint i, j; - - table = gtk_table_new (FALSE, 3, 3); - - for (i = 0; i < 5; i++) - { - for (j = 0; j < 5; j++) - { - GtkWidget *widget; - char *tmp; - - if (i == 0 && j == 0) - { - widget = NULL; - } - else if (i == 0) - { - tmp = g_strdup_printf ("%d", j); - widget = gtk_label_new (tmp); - g_free (tmp); - } - else if (j == 0) - { - tmp = g_strdup_printf ("%c", 'A' + i - 1); - widget = gtk_label_new (tmp); - g_free (tmp); - } - else - { - widget = g_object_new (widget_type, NULL); - - if (g_type_is_a (widget_type, GTK_TYPE_RADIO_BUTTON)) - { - if (!group_widget) - group_widget = widget; - else - g_object_set (widget, "group", group_widget, NULL); - } - } - - if (widget) - gtk_table_attach (GTK_TABLE (table), widget, - i, i + 1, j, j + 1, - 0, 0, - 0, 0); - } - } - - return table; -} - -/* - * GtkCheckButton - */ - -static void -create_check_buttons (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *table; - - if (!window) - { - window = gtk_dialog_new_with_buttons ("Check Buttons", - NULL, 0, - GTK_STOCK_CLOSE, - GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - - box1 = GTK_DIALOG (window)->vbox; - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_check_button_new_with_mnemonic ("_button1"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_check_button_new_with_label ("button2"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_check_button_new_with_label ("button3"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_check_button_new_with_label ("inconsistent"); - gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - table = create_widget_grid (GTK_TYPE_CHECK_BUTTON); - gtk_container_set_border_width (GTK_CONTAINER (table), 10); - gtk_box_pack_start (GTK_BOX (box1), table, TRUE, TRUE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkRadioButton - */ - -static void -create_radio_buttons (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *table; - - if (!window) - { - window = gtk_dialog_new_with_buttons ("Radio Buttons", - NULL, 0, - GTK_STOCK_CLOSE, - GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - - box1 = GTK_DIALOG (window)->vbox; - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label (NULL, "button1"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label ( - gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "button2"); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label ( - gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "button3"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label ( - gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "inconsistent"); - gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label (NULL, "button4"); - gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (button), FALSE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label ( - gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "button5"); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (button), FALSE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_radio_button_new_with_label ( - gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "button6"); - gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (button), FALSE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - table = create_widget_grid (GTK_TYPE_RADIO_BUTTON); - gtk_container_set_border_width (GTK_CONTAINER (table), 10); - gtk_box_pack_start (GTK_BOX (box1), table, TRUE, TRUE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkButtonBox - */ - -static GtkWidget * -create_bbox (gint horizontal, - char* title, - gint spacing, - gint child_w, - gint child_h, - gint layout) -{ - GtkWidget *frame; - GtkWidget *bbox; - GtkWidget *button; - - frame = gtk_frame_new (title); - - if (horizontal) - bbox = gtk_hbutton_box_new (); - else - bbox = gtk_vbutton_box_new (); - - gtk_container_set_border_width (GTK_CONTAINER (bbox), 5); - gtk_container_add (GTK_CONTAINER (frame), bbox); - - gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), layout); - gtk_box_set_spacing (GTK_BOX (bbox), spacing); - gtk_button_box_set_child_size (GTK_BUTTON_BOX (bbox), child_w, child_h); - - button = gtk_button_new_with_label ("OK"); - gtk_container_add (GTK_CONTAINER (bbox), button); - - button = gtk_button_new_with_label ("Cancel"); - gtk_container_add (GTK_CONTAINER (bbox), button); - - button = gtk_button_new_with_label ("Help"); - gtk_container_add (GTK_CONTAINER (bbox), button); - - return frame; -} - -static void -create_button_box (GtkWidget *widget) -{ - static GtkWidget* window = NULL; - GtkWidget *main_vbox; - GtkWidget *vbox; - GtkWidget *hbox; - GtkWidget *frame_horz; - GtkWidget *frame_vert; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), gtk_widget_get_screen (widget)); - gtk_window_set_title (GTK_WINDOW (window), "Button Boxes"); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - - main_vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), main_vbox); - - frame_horz = gtk_frame_new ("Horizontal Button Boxes"); - gtk_box_pack_start (GTK_BOX (main_vbox), frame_horz, TRUE, TRUE, 10); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - gtk_container_add (GTK_CONTAINER (frame_horz), vbox); - - gtk_box_pack_start (GTK_BOX (vbox), - create_bbox (TRUE, "Spread", 40, 85, 20, GTK_BUTTONBOX_SPREAD), - TRUE, TRUE, 0); - - gtk_box_pack_start (GTK_BOX (vbox), - create_bbox (TRUE, "Edge", 40, 85, 20, GTK_BUTTONBOX_EDGE), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (vbox), - create_bbox (TRUE, "Start", 40, 85, 20, GTK_BUTTONBOX_START), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (vbox), - create_bbox (TRUE, "End", 40, 85, 20, GTK_BUTTONBOX_END), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (vbox), - create_bbox (TRUE, "Center", 40, 85, 20, GTK_BUTTONBOX_CENTER), - TRUE, TRUE, 5); - - frame_vert = gtk_frame_new ("Vertical Button Boxes"); - gtk_box_pack_start (GTK_BOX (main_vbox), frame_vert, TRUE, TRUE, 10); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 10); - gtk_container_add (GTK_CONTAINER (frame_vert), hbox); - - gtk_box_pack_start (GTK_BOX (hbox), - create_bbox (FALSE, "Spread", 30, 85, 20, GTK_BUTTONBOX_SPREAD), - TRUE, TRUE, 0); - - gtk_box_pack_start (GTK_BOX (hbox), - create_bbox (FALSE, "Edge", 30, 85, 20, GTK_BUTTONBOX_EDGE), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (hbox), - create_bbox (FALSE, "Start", 30, 85, 20, GTK_BUTTONBOX_START), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (hbox), - create_bbox (FALSE, "End", 30, 85, 20, GTK_BUTTONBOX_END), - TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (hbox), - create_bbox (FALSE, "Center", 30, 85, 20, GTK_BUTTONBOX_CENTER), - TRUE, TRUE, 5); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkToolBar - */ - -static GtkWidget* -new_pixmap (char *filename, - GdkWindow *window, - GdkColor *background) -{ - GtkWidget *wpixmap; - GdkPixmap *pixmap; - GdkBitmap *mask; - - if (strcmp (filename, "test.xpm") == 0 || - !file_exists (filename)) - { - pixmap = gdk_pixmap_create_from_xpm_d (window, &mask, - background, - openfile); - } - else - pixmap = gdk_pixmap_create_from_xpm (window, &mask, - background, - filename); - - wpixmap = gtk_image_new_from_pixmap (pixmap, mask); - - return wpixmap; -} - - -static void -set_toolbar_small_stock (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_icon_size (GTK_TOOLBAR (data), GTK_ICON_SIZE_SMALL_TOOLBAR); -} - -static void -set_toolbar_large_stock (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_icon_size (GTK_TOOLBAR (data), GTK_ICON_SIZE_LARGE_TOOLBAR); -} - -static void -set_toolbar_horizontal (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_orientation (GTK_TOOLBAR (data), GTK_ORIENTATION_HORIZONTAL); -} - -static void -set_toolbar_vertical (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_orientation (GTK_TOOLBAR (data), GTK_ORIENTATION_VERTICAL); -} - -static void -set_toolbar_icons (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_ICONS); -} - -static void -set_toolbar_text (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_TEXT); -} - -static void -set_toolbar_both (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_BOTH); -} - -static void -set_toolbar_both_horiz (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_BOTH_HORIZ); -} - -static void -set_toolbar_enable (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_tooltips (GTK_TOOLBAR (data), TRUE); -} - -static void -set_toolbar_disable (GtkWidget *widget, - gpointer data) -{ - gtk_toolbar_set_tooltips (GTK_TOOLBAR (data), FALSE); -} - -static void -create_toolbar (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *toolbar; - GtkWidget *entry; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_title (GTK_WINDOW (window), "Toolbar test"); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - gtk_widget_realize (window); - - toolbar = gtk_toolbar_new (); - - gtk_toolbar_insert_stock (GTK_TOOLBAR (toolbar), - GTK_STOCK_NEW, - "Stock icon: New", "Toolbar/New", - G_CALLBACK (set_toolbar_small_stock), toolbar, -1); - - gtk_toolbar_insert_stock (GTK_TOOLBAR (toolbar), - GTK_STOCK_OPEN, - "Stock icon: Open", "Toolbar/Open", - G_CALLBACK (set_toolbar_large_stock), toolbar, -1); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Horizontal", "Horizontal toolbar layout", "Toolbar/Horizontal", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_horizontal), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Vertical", "Vertical toolbar layout", "Toolbar/Vertical", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_vertical), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR(toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Icons", "Only show toolbar icons", "Toolbar/IconsOnly", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_icons), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Text", "Only show toolbar text", "Toolbar/TextOnly", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_text), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Both", "Show toolbar icons and text", "Toolbar/Both", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_both), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Both (horizontal)", - "Show toolbar icons and text in a horizontal fashion", - "Toolbar/BothHoriz", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_both_horiz), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - entry = gtk_entry_new (); - - gtk_toolbar_append_widget (GTK_TOOLBAR (toolbar), entry, "This is an unusable GtkEntry ;)", "Hey don't click me!!!"); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Enable", "Enable tooltips", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_enable), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Disable", "Disable tooltips", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_disable), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Frobate", "Frobate tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Baz", "Baz tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Blah", "Blah tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Bar", "Bar tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - - gtk_container_add (GTK_CONTAINER (window), toolbar); - - gtk_widget_set_size_request (toolbar, 200, -1); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -static GtkWidget* -make_toolbar (GtkWidget *window) -{ - GtkWidget *toolbar; - - if (!GTK_WIDGET_REALIZED (window)) - gtk_widget_realize (window); - - toolbar = gtk_toolbar_new (); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Horizontal", "Horizontal toolbar layout", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_horizontal), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Vertical", "Vertical toolbar layout", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_vertical), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR(toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Icons", "Only show toolbar icons", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_icons), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Text", "Only show toolbar text", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_text), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Both", "Show toolbar icons and text", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_both), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Woot", "Woot woot woot", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Blah", "Blah blah blah", "Toolbar/Big", - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Enable", "Enable tooltips", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_enable), toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Disable", "Disable tooltips", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - G_CALLBACK (set_toolbar_disable), toolbar); - - gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); - - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Hoo", "Hoo tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), - "Woo", "Woo tooltip", NULL, - new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), - NULL, toolbar); - - return toolbar; -} - -/* - * GtkStatusBar - */ - -static guint statusbar_counter = 1; - -static void -statusbar_push (GtkWidget *button, - GtkStatusbar *statusbar) -{ - gchar text[1024]; - - sprintf (text, "something %d", statusbar_counter++); - - gtk_statusbar_push (statusbar, 1, text); -} - -static void -statusbar_push_long (GtkWidget *button, - GtkStatusbar *statusbar) -{ - gchar text[1024]; - - sprintf (text, "Just because a system has menu choices written with English words, phrases or sentences, that is no guarantee, that it is comprehensible. Individual words may not be familiar to some users (for example, \"repaginate\"), and two menu items may appear to satisfy the users's needs, whereas only one does (for example, \"put away\" or \"eject\")."); - - gtk_statusbar_push (statusbar, 1, text); -} - -static void -statusbar_pop (GtkWidget *button, - GtkStatusbar *statusbar) -{ - gtk_statusbar_pop (statusbar, 1); -} - -static void -statusbar_steal (GtkWidget *button, - GtkStatusbar *statusbar) -{ - gtk_statusbar_remove (statusbar, 1, 4); -} - -static void -statusbar_popped (GtkStatusbar *statusbar, - guint context_id, - const gchar *text) -{ - if (!statusbar->messages) - statusbar_counter = 1; -} - -static void -statusbar_contexts (GtkStatusbar *statusbar) -{ - gchar *string; - - string = "any context"; - g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n", - string, - gtk_statusbar_get_context_id (statusbar, string)); - - string = "idle messages"; - g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n", - string, - gtk_statusbar_get_context_id (statusbar, string)); - - string = "some text"; - g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n", - string, - gtk_statusbar_get_context_id (statusbar, string)); - - string = "hit the mouse"; - g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n", - string, - gtk_statusbar_get_context_id (statusbar, string)); - - string = "hit the mouse2"; - g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n", - string, - gtk_statusbar_get_context_id (statusbar, string)); -} - -static void -create_statusbar (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *statusbar; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "statusbar"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - statusbar = gtk_statusbar_new (); - gtk_box_pack_end (GTK_BOX (box1), statusbar, TRUE, TRUE, 0); - g_signal_connect (statusbar, - "text_popped", - G_CALLBACK (statusbar_popped), - NULL); - - button = gtk_widget_new (gtk_button_get_type (), - "label", "push something", - "visible", TRUE, - "parent", box2, - NULL); - g_object_connect (button, - "signal::clicked", statusbar_push, statusbar, - NULL); - - button = g_object_connect (gtk_widget_new (gtk_button_get_type (), - "label", "pop", - "visible", TRUE, - "parent", box2, - NULL), - "signal_after::clicked", statusbar_pop, statusbar, - NULL); - - button = g_object_connect (gtk_widget_new (gtk_button_get_type (), - "label", "steal #4", - "visible", TRUE, - "parent", box2, - NULL), - "signal_after::clicked", statusbar_steal, statusbar, - NULL); - - button = g_object_connect (gtk_widget_new (gtk_button_get_type (), - "label", "test contexts", - "visible", TRUE, - "parent", box2, - NULL), - "swapped_signal_after::clicked", statusbar_contexts, statusbar, - NULL); - - button = g_object_connect (gtk_widget_new (gtk_button_get_type (), - "label", "push something long", - "visible", TRUE, - "parent", box2, - NULL), - "signal_after::clicked", statusbar_push_long, statusbar, - NULL); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkTree - */ - -static void -cb_tree_destroy_event(GtkWidget* w) -{ - sTreeButtons* tree_buttons; - - /* free buttons structure associate at this tree */ - tree_buttons = g_object_get_data (G_OBJECT (w), "user_data"); - g_free (tree_buttons); -} - -static void -cb_add_new_item(GtkWidget* w, GtkTree* tree) -{ - sTreeButtons* tree_buttons; - GList* selected_list; - GtkWidget* selected_item; - GtkWidget* subtree; - GtkWidget* item_new; - char buffer[255]; - - tree_buttons = g_object_get_data (G_OBJECT (tree), "user_data"); - - selected_list = GTK_TREE_SELECTION_OLD(tree); - - if(selected_list == NULL) - { - /* there is no item in tree */ - subtree = GTK_WIDGET(tree); - } - else - { - /* list can have only one element */ - selected_item = GTK_WIDGET(selected_list->data); - - subtree = GTK_TREE_ITEM_SUBTREE(selected_item); - - if(subtree == NULL) - { - /* current selected item have not subtree ... create it */ - subtree = gtk_tree_new(); - gtk_tree_item_set_subtree(GTK_TREE_ITEM(selected_item), - subtree); - } - } - - /* at this point, we know which subtree will be used to add new item */ - /* create a new item */ - sprintf(buffer, "item add %d", tree_buttons->nb_item_add); - item_new = gtk_tree_item_new_with_label(buffer); - gtk_tree_append(GTK_TREE(subtree), item_new); - gtk_widget_show(item_new); - - tree_buttons->nb_item_add++; -} - -static void -cb_remove_item(GtkWidget*w, GtkTree* tree) -{ - GList* selected_list; - GList* clear_list; - - selected_list = GTK_TREE_SELECTION_OLD(tree); - - clear_list = NULL; - - while (selected_list) - { - clear_list = g_list_prepend (clear_list, selected_list->data); - selected_list = selected_list->next; - } - - clear_list = g_list_reverse (clear_list); - gtk_tree_remove_items(tree, clear_list); - - g_list_free (clear_list); -} - -static void -cb_remove_subtree(GtkWidget*w, GtkTree* tree) -{ - GList* selected_list; - GtkTreeItem *item; - - selected_list = GTK_TREE_SELECTION_OLD(tree); - - if (selected_list) - { - item = GTK_TREE_ITEM (selected_list->data); - if (item->subtree) - gtk_tree_item_remove_subtree (item); - } -} - -static void -cb_tree_changed(GtkTree* tree) -{ - sTreeButtons* tree_buttons; - GList* selected_list; - guint nb_selected; - - tree_buttons = g_object_get_data (G_OBJECT (tree), "user_data"); - - selected_list = GTK_TREE_SELECTION_OLD(tree); - nb_selected = g_list_length(selected_list); - - if(nb_selected == 0) - { - if(tree->children == NULL) - gtk_widget_set_sensitive(tree_buttons->add_button, TRUE); - else - gtk_widget_set_sensitive(tree_buttons->add_button, FALSE); - gtk_widget_set_sensitive(tree_buttons->remove_button, FALSE); - gtk_widget_set_sensitive(tree_buttons->subtree_button, FALSE); - } - else - { - gtk_widget_set_sensitive(tree_buttons->remove_button, TRUE); - gtk_widget_set_sensitive(tree_buttons->add_button, (nb_selected == 1)); - gtk_widget_set_sensitive(tree_buttons->subtree_button, (nb_selected == 1)); - } -} - -static void -create_subtree(GtkWidget* item, guint level, guint nb_item_max, guint recursion_level_max) -{ - GtkWidget* item_subtree; - GtkWidget* item_new; - guint nb_item; - char buffer[255]; - int no_root_item; - - if(level == recursion_level_max) return; - - if(level == -1) - { - /* query with no root item */ - level = 0; - item_subtree = item; - no_root_item = 1; - } - else - { - /* query with no root item */ - /* create subtree and associate it with current item */ - item_subtree = gtk_tree_new(); - no_root_item = 0; - } - - for(nb_item = 0; nb_item < nb_item_max; nb_item++) - { - sprintf(buffer, "item %d-%d", level, nb_item); - item_new = gtk_tree_item_new_with_label(buffer); - gtk_tree_append(GTK_TREE(item_subtree), item_new); - create_subtree(item_new, level+1, nb_item_max, recursion_level_max); - gtk_widget_show(item_new); - } - - if(!no_root_item) - gtk_tree_item_set_subtree(GTK_TREE_ITEM(item), item_subtree); -} - -static void -create_tree_sample(GdkScreen *screen, guint selection_mode, - guint draw_line, guint view_line, guint no_root_item, - guint nb_item_max, guint recursion_level_max) -{ - GtkWidget* window; - GtkWidget* box1; - GtkWidget* box2; - GtkWidget* separator; - GtkWidget* button; - GtkWidget* scrolled_win; - GtkWidget* root_tree; - GtkWidget* root_item; - sTreeButtons* tree_buttons; - - /* create tree buttons struct */ - if ((tree_buttons = g_malloc (sizeof (sTreeButtons))) == NULL) - { - g_error("can't allocate memory for tree structure !\n"); - return; - } - tree_buttons->nb_item_add = 0; - - /* create top level window */ - window = gtk_window_new(GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), screen); - gtk_window_set_title(GTK_WINDOW(window), "Tree Sample"); - g_signal_connect (window, "destroy", - G_CALLBACK (cb_tree_destroy_event), NULL); - g_object_set_data (G_OBJECT (window), "user_data", tree_buttons); - - box1 = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(window), box1); - gtk_widget_show(box1); - - /* create tree box */ - box2 = gtk_vbox_new(FALSE, 0); - gtk_box_pack_start(GTK_BOX(box1), box2, TRUE, TRUE, 0); - gtk_container_set_border_width(GTK_CONTAINER(box2), 5); - gtk_widget_show(box2); - - /* create scrolled window */ - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); - gtk_box_pack_start (GTK_BOX (box2), scrolled_win, TRUE, TRUE, 0); - gtk_widget_set_size_request (scrolled_win, 200, 200); - gtk_widget_show (scrolled_win); - - /* create root tree widget */ - root_tree = gtk_tree_new(); - g_signal_connect (root_tree, "selection_changed", - G_CALLBACK (cb_tree_changed), - NULL); - g_object_set_data (G_OBJECT (root_tree), "user_data", tree_buttons); - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_win), root_tree); - gtk_tree_set_selection_mode(GTK_TREE(root_tree), selection_mode); - gtk_tree_set_view_lines(GTK_TREE(root_tree), draw_line); - gtk_tree_set_view_mode(GTK_TREE(root_tree), !view_line); - gtk_widget_show(root_tree); - - if ( no_root_item ) - { - /* set root tree to subtree function with root item variable */ - root_item = GTK_WIDGET(root_tree); - } - else - { - /* create root tree item widget */ - root_item = gtk_tree_item_new_with_label("root item"); - gtk_tree_append(GTK_TREE(root_tree), root_item); - gtk_widget_show(root_item); - } - create_subtree(root_item, -no_root_item, nb_item_max, recursion_level_max); - - box2 = gtk_vbox_new(FALSE, 0); - gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0); - gtk_container_set_border_width(GTK_CONTAINER(box2), 5); - gtk_widget_show(box2); - - button = gtk_button_new_with_label("Add Item"); - gtk_widget_set_sensitive(button, FALSE); - g_signal_connect (button, "clicked", - G_CALLBACK (cb_add_new_item), - root_tree); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - gtk_widget_show(button); - tree_buttons->add_button = button; - - button = gtk_button_new_with_label("Remove Item(s)"); - gtk_widget_set_sensitive(button, FALSE); - g_signal_connect (button, "clicked", - G_CALLBACK (cb_remove_item), - root_tree); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - gtk_widget_show(button); - tree_buttons->remove_button = button; - - button = gtk_button_new_with_label("Remove Subtree"); - gtk_widget_set_sensitive(button, FALSE); - g_signal_connect (button, "clicked", - G_CALLBACK (cb_remove_subtree), - root_tree); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - gtk_widget_show(button); - tree_buttons->subtree_button = button; - - /* create separator */ - separator = gtk_hseparator_new(); - gtk_box_pack_start(GTK_BOX(box1), separator, FALSE, FALSE, 0); - gtk_widget_show(separator); - - /* create button box */ - box2 = gtk_vbox_new(FALSE, 0); - gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0); - gtk_container_set_border_width(GTK_CONTAINER(box2), 5); - gtk_widget_show(box2); - - button = gtk_button_new_with_label("Close"); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_widget_show(button); - - gtk_widget_show(window); -} - -static void -cb_create_tree(GtkWidget* w) -{ - guint selection_mode = GTK_SELECTION_SINGLE; - guint view_line; - guint draw_line; - guint no_root_item; - guint nb_item; - guint recursion_level; - - /* get selection mode choice */ - if(GTK_TOGGLE_BUTTON(sTreeSampleSelection.single_button)->active) - selection_mode = GTK_SELECTION_SINGLE; - else - if(GTK_TOGGLE_BUTTON(sTreeSampleSelection.browse_button)->active) - selection_mode = GTK_SELECTION_BROWSE; - else - selection_mode = GTK_SELECTION_MULTIPLE; - - /* get options choice */ - draw_line = GTK_TOGGLE_BUTTON(sTreeSampleSelection.draw_line_button)->active; - view_line = GTK_TOGGLE_BUTTON(sTreeSampleSelection.view_line_button)->active; - no_root_item = GTK_TOGGLE_BUTTON(sTreeSampleSelection.no_root_item_button)->active; - - /* get levels */ - nb_item = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(sTreeSampleSelection.nb_item_spinner)); - recursion_level = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(sTreeSampleSelection.recursion_spinner)); - - if (pow (nb_item, recursion_level) > 10000) - { - g_print ("%g total items? That will take a very long time. Try less\n", - pow (nb_item, recursion_level)); - return; - } - - create_tree_sample(gtk_widget_get_screen (w), - selection_mode, draw_line, - view_line, no_root_item, nb_item, recursion_level); -} - -void -create_tree_mode_window(GtkWidget *widget) -{ - static GtkWidget* window; - GtkWidget* box1; - GtkWidget* box2; - GtkWidget* box3; - GtkWidget* box4; - GtkWidget* box5; - GtkWidget* button; - GtkWidget* frame; - GtkWidget* separator; - GtkWidget* label; - GtkWidget* spinner; - GtkAdjustment *adj; - - if (!window) - { - /* create toplevel window */ - window = gtk_window_new(GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - gtk_window_set_title(GTK_WINDOW(window), "Set Tree Parameters"); - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - box1 = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(window), box1); - - /* create upper box - selection box */ - box2 = gtk_vbox_new(FALSE, 5); - gtk_box_pack_start(GTK_BOX(box1), box2, TRUE, TRUE, 0); - gtk_container_set_border_width(GTK_CONTAINER(box2), 5); - - box3 = gtk_hbox_new(FALSE, 5); - gtk_box_pack_start(GTK_BOX(box2), box3, TRUE, TRUE, 0); - - /* create selection mode frame */ - frame = gtk_frame_new("Selection Mode"); - gtk_box_pack_start(GTK_BOX(box3), frame, TRUE, TRUE, 0); - - box4 = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(frame), box4); - gtk_container_set_border_width(GTK_CONTAINER(box4), 5); - - /* create radio button */ - button = gtk_radio_button_new_with_label(NULL, "SINGLE"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - sTreeSampleSelection.single_button = button; - - button = gtk_radio_button_new_with_label(gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "BROWSE"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - sTreeSampleSelection.browse_button = button; - - button = gtk_radio_button_new_with_label(gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)), - "MULTIPLE"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - sTreeSampleSelection.multiple_button = button; - - sTreeSampleSelection.selection_mode_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (button)); - - /* create option mode frame */ - frame = gtk_frame_new("Options"); - gtk_box_pack_start(GTK_BOX(box3), frame, TRUE, TRUE, 0); - - box4 = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(frame), box4); - gtk_container_set_border_width(GTK_CONTAINER(box4), 5); - - /* create check button */ - button = gtk_check_button_new_with_label("Draw line"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), TRUE); - sTreeSampleSelection.draw_line_button = button; - - button = gtk_check_button_new_with_label("View Line mode"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), TRUE); - sTreeSampleSelection.view_line_button = button; - - button = gtk_check_button_new_with_label("Without Root item"); - gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0); - sTreeSampleSelection.no_root_item_button = button; - - /* create recursion parameter */ - frame = gtk_frame_new("Size Parameters"); - gtk_box_pack_start(GTK_BOX(box2), frame, TRUE, TRUE, 0); - - box4 = gtk_hbox_new(FALSE, 5); - gtk_container_add(GTK_CONTAINER(frame), box4); - gtk_container_set_border_width(GTK_CONTAINER(box4), 5); - - /* create number of item spin button */ - box5 = gtk_hbox_new(FALSE, 5); - gtk_box_pack_start(GTK_BOX(box4), box5, FALSE, FALSE, 0); - - label = gtk_label_new("Number of items : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (box5), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (DEFAULT_NUMBER_OF_ITEM, 1.0, 255.0, 1.0, - 5.0, 0.0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (box5), spinner, FALSE, TRUE, 0); - sTreeSampleSelection.nb_item_spinner = spinner; - - /* create recursion level spin button */ - box5 = gtk_hbox_new(FALSE, 5); - gtk_box_pack_start(GTK_BOX(box4), box5, FALSE, FALSE, 0); - - label = gtk_label_new("Depth : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (box5), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (DEFAULT_RECURSION_LEVEL, 0.0, 255.0, 1.0, - 5.0, 0.0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (box5), spinner, FALSE, TRUE, 0); - sTreeSampleSelection.recursion_spinner = spinner; - - /* create horizontal separator */ - separator = gtk_hseparator_new(); - gtk_box_pack_start(GTK_BOX(box1), separator, FALSE, FALSE, 0); - - /* create bottom button box */ - box2 = gtk_hbox_new(TRUE, 10); - gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0); - gtk_container_set_border_width(GTK_CONTAINER(box2), 5); - - button = gtk_button_new_with_label("Create Tree"); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (cb_create_tree), NULL); - - button = gtk_button_new_with_label("Close"); - gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - } - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Gridded geometry - */ -#define GRID_SIZE 20 -#define DEFAULT_GEOMETRY "10x10" - -static gboolean -gridded_geometry_expose (GtkWidget *widget, - GdkEventExpose *event) -{ - int i, j; - - gdk_draw_rectangle (widget->window, widget->style->base_gc[widget->state], TRUE, - 0, 0, widget->allocation.width, widget->allocation.height); - - for (i = 0 ; i * GRID_SIZE < widget->allocation.width; i++) - for (j = 0 ; j * GRID_SIZE < widget->allocation.height; j++) - { - if ((i + j) % 2 == 0) - gdk_draw_rectangle (widget->window, widget->style->text_gc[widget->state], TRUE, - i * GRID_SIZE, j * GRID_SIZE, GRID_SIZE, GRID_SIZE); - } - - return FALSE; -} - -static void -gridded_geometry_subresponse (GtkDialog *dialog, - gint response_id, - gchar *geometry_string) -{ - if (response_id == GTK_RESPONSE_NONE) - { - gtk_widget_destroy (GTK_WIDGET (dialog)); - } - else - { - if (!gtk_window_parse_geometry (GTK_WINDOW (dialog), geometry_string)) - { - g_print ("Can't parse geometry string %s\n", geometry_string); - gtk_window_parse_geometry (GTK_WINDOW (dialog), DEFAULT_GEOMETRY); - } - } -} - -static void -gridded_geometry_response (GtkDialog *dialog, - gint response_id, - GtkEntry *entry) -{ - if (response_id == GTK_RESPONSE_NONE) - { - gtk_widget_destroy (GTK_WIDGET (dialog)); - } - else - { - gchar *geometry_string = g_strdup (gtk_entry_get_text (entry)); - gchar *title = g_strdup_printf ("Gridded window at: %s", geometry_string); - GtkWidget *window; - GtkWidget *drawing_area; - GtkWidget *box; - GdkGeometry geometry; - - window = gtk_dialog_new_with_buttons (title, - NULL, 0, - "Reset", 1, - GTK_STOCK_CLOSE, GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (GTK_WIDGET (dialog))); - g_free (title); - g_signal_connect (window, "response", - G_CALLBACK (gridded_geometry_subresponse), geometry_string); - - box = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), box, TRUE, TRUE, 0); - - gtk_container_set_border_width (GTK_CONTAINER (box), 7); - - drawing_area = gtk_drawing_area_new (); - g_signal_connect (drawing_area, "expose_event", - G_CALLBACK (gridded_geometry_expose), NULL); - gtk_box_pack_start (GTK_BOX (box), drawing_area, TRUE, TRUE, 0); - - /* Gross hack to work around bug 68668... if we set the size request - * large enough, then the current - * - * request_of_window - request_of_geometry_widget - * - * method of getting the base size works more or less works. - */ - gtk_widget_set_size_request (drawing_area, 2000, 2000); - - geometry.base_width = 0; - geometry.base_height = 0; - geometry.min_width = 2 * GRID_SIZE; - geometry.min_height = 2 * GRID_SIZE; - geometry.width_inc = GRID_SIZE; - geometry.height_inc = GRID_SIZE; - - gtk_window_set_geometry_hints (GTK_WINDOW (window), drawing_area, - &geometry, - GDK_HINT_BASE_SIZE | GDK_HINT_MIN_SIZE | GDK_HINT_RESIZE_INC); - - if (!gtk_window_parse_geometry (GTK_WINDOW (window), geometry_string)) - { - g_print ("Can't parse geometry string %s\n", geometry_string); - gtk_window_parse_geometry (GTK_WINDOW (window), DEFAULT_GEOMETRY); - } - - gtk_widget_show_all (window); - } -} - -static void -create_gridded_geometry (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *entry; - GtkWidget *label; - - if (!window) - { - window = gtk_dialog_new_with_buttons ("Gridded Geometry", - NULL, 0, - "Create", 1, - GTK_STOCK_CLOSE, GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - label = gtk_label_new ("Geometry string:"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), label, FALSE, FALSE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), DEFAULT_GEOMETRY); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), entry, FALSE, FALSE, 0); - - g_signal_connect (window, "response", - G_CALLBACK (gridded_geometry_response), entry); - g_object_add_weak_pointer (G_OBJECT (window), (gpointer) &window); - - gtk_widget_show_all (window); - } - else - gtk_widget_destroy (window); -} - -/* - * GtkHandleBox - */ - -static void -handle_box_child_signal (GtkHandleBox *hb, - GtkWidget *child, - const gchar *action) -{ - printf ("%s: child <%s> %sed\n", - g_type_name (G_OBJECT_TYPE (hb)), - g_type_name (G_OBJECT_TYPE (child)), - action); -} - -static void -create_handle_box (GtkWidget *widget) -{ - static GtkWidget* window = NULL; - GtkWidget *handle_box; - GtkWidget *handle_box2; - GtkWidget *vbox; - GtkWidget *hbox; - GtkWidget *toolbar; - GtkWidget *label; - GtkWidget *separator; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - gtk_window_set_modal (GTK_WINDOW (window), FALSE); - gtk_window_set_title (GTK_WINDOW (window), - "Handle Box Test"); - gtk_window_set_resizable (GTK_WINDOW (window), TRUE); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_container_set_border_width (GTK_CONTAINER (window), 20); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - gtk_widget_show (vbox); - - label = gtk_label_new ("Above"); - gtk_container_add (GTK_CONTAINER (vbox), label); - gtk_widget_show (label); - - separator = gtk_hseparator_new (); - gtk_container_add (GTK_CONTAINER (vbox), separator); - gtk_widget_show (separator); - - hbox = gtk_hbox_new (FALSE, 10); - gtk_container_add (GTK_CONTAINER (vbox), hbox); - gtk_widget_show (hbox); - - separator = gtk_hseparator_new (); - gtk_container_add (GTK_CONTAINER (vbox), separator); - gtk_widget_show (separator); - - label = gtk_label_new ("Below"); - gtk_container_add (GTK_CONTAINER (vbox), label); - gtk_widget_show (label); - - handle_box = gtk_handle_box_new (); - gtk_box_pack_start (GTK_BOX (hbox), handle_box, FALSE, FALSE, 0); - g_signal_connect (handle_box, - "child_attached", - G_CALLBACK (handle_box_child_signal), - "attached"); - g_signal_connect (handle_box, - "child_detached", - G_CALLBACK (handle_box_child_signal), - "detached"); - gtk_widget_show (handle_box); - - toolbar = make_toolbar (window); - - gtk_container_add (GTK_CONTAINER (handle_box), toolbar); - gtk_widget_show (toolbar); - - handle_box = gtk_handle_box_new (); - gtk_box_pack_start (GTK_BOX (hbox), handle_box, FALSE, FALSE, 0); - g_signal_connect (handle_box, - "child_attached", - G_CALLBACK (handle_box_child_signal), - "attached"); - g_signal_connect (handle_box, - "child_detached", - G_CALLBACK (handle_box_child_signal), - "detached"); - gtk_widget_show (handle_box); - - handle_box2 = gtk_handle_box_new (); - gtk_container_add (GTK_CONTAINER (handle_box), handle_box2); - g_signal_connect (handle_box2, - "child_attached", - G_CALLBACK (handle_box_child_signal), - "attached"); - g_signal_connect (handle_box2, - "child_detached", - G_CALLBACK (handle_box_child_signal), - "detached"); - gtk_widget_show (handle_box2); - - hbox = g_object_new (GTK_TYPE_HBOX, "visible", 1, "parent", handle_box2, NULL); - label = gtk_label_new ("Fooo!"); - gtk_container_add (GTK_CONTAINER (hbox), label); - gtk_widget_show (label); - g_object_new (GTK_TYPE_ARROW, "visible", 1, "parent", hbox, NULL); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Test for getting an image from a drawable - */ - -struct GetImageData -{ - GtkWidget *src; - GtkWidget *snap; - GtkWidget *sw; -}; - -static void -take_snapshot (GtkWidget *button, - gpointer data) -{ - struct GetImageData *gid = data; - GdkRectangle visible; - int width_fraction; - int height_fraction; - GdkGC *gc; - GdkGC *black_gc; - GdkColor color = { 0, 30000, 0, 0 }; - GdkRectangle target; - GdkImage *shot; - - /* Do some begin_paint_rect on some random rects, draw some - * distinctive stuff into those rects, then take the snapshot. - * figure out whether any rects were overlapped and report to - * user. - */ - - visible = gid->sw->allocation; - - visible.x = gtk_scrolled_window_get_hadjustment (GTK_SCROLLED_WINDOW (gid->sw))->value; - visible.y = gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (gid->sw))->value; - - width_fraction = visible.width / 4; - height_fraction = visible.height / 4; - - gc = gdk_gc_new (gid->src->window); - black_gc = gid->src->style->black_gc; - - gdk_gc_set_rgb_fg_color (gc, &color); - - - target.x = visible.x + width_fraction; - target.y = visible.y + height_fraction * 3; - target.width = width_fraction; - target.height = height_fraction / 2; - - gdk_window_begin_paint_rect (gid->src->window, - &target); - - gdk_draw_rectangle (gid->src->window, - gc, - TRUE, - target.x, target.y, - target.width, target.height); - - gdk_draw_rectangle (gid->src->window, - black_gc, - FALSE, - target.x + 10, target.y + 10, - target.width - 20, target.height - 20); - - target.x = visible.x + width_fraction; - target.y = visible.y + height_fraction; - target.width = width_fraction; - target.height = height_fraction; - - gdk_window_begin_paint_rect (gid->src->window, - &target); - - gdk_draw_rectangle (gid->src->window, - gc, - TRUE, - target.x, target.y, - target.width, target.height); - - gdk_draw_rectangle (gid->src->window, - black_gc, - FALSE, - target.x + 10, target.y + 10, - target.width - 20, target.height - 20); - - target.x = visible.x + width_fraction * 3; - target.y = visible.y + height_fraction; - target.width = width_fraction / 2; - target.height = height_fraction; - - gdk_window_begin_paint_rect (gid->src->window, - &target); - - gdk_draw_rectangle (gid->src->window, - gc, - TRUE, - target.x, target.y, - target.width, target.height); - - gdk_draw_rectangle (gid->src->window, - black_gc, - FALSE, - target.x + 10, target.y + 10, - target.width - 20, target.height - 20); - - target.x = visible.x + width_fraction * 2; - target.y = visible.y + height_fraction * 2; - target.width = width_fraction / 4; - target.height = height_fraction / 4; - - gdk_window_begin_paint_rect (gid->src->window, - &target); - - gdk_draw_rectangle (gid->src->window, - gc, - TRUE, - target.x, target.y, - target.width, target.height); - - gdk_draw_rectangle (gid->src->window, - black_gc, - FALSE, - target.x + 10, target.y + 10, - target.width - 20, target.height - 20); - - target.x += target.width / 2; - target.y += target.width / 2; - - gdk_window_begin_paint_rect (gid->src->window, - &target); - - gdk_draw_rectangle (gid->src->window, - gc, - TRUE, - target.x, target.y, - target.width, target.height); - - gdk_draw_rectangle (gid->src->window, - black_gc, - FALSE, - target.x + 10, target.y + 10, - target.width - 20, target.height - 20); - - /* Screen shot area */ - - target.x = visible.x + width_fraction * 1.5; - target.y = visible.y + height_fraction * 1.5; - target.width = width_fraction * 2; - target.height = height_fraction * 2; - - shot = gdk_drawable_get_image (gid->src->window, - target.x, target.y, - target.width, target.height); - - gtk_image_set_from_image (GTK_IMAGE (gid->snap), - shot, NULL); - - g_object_unref (shot); - - gdk_window_end_paint (gid->src->window); - gdk_window_end_paint (gid->src->window); - gdk_window_end_paint (gid->src->window); - gdk_window_end_paint (gid->src->window); - gdk_window_end_paint (gid->src->window); - - gdk_draw_rectangle (gid->src->window, - gid->src->style->black_gc, - FALSE, - target.x, target.y, - target.width, target.height); - - g_object_unref (gc); -} - -static gint -image_source_expose (GtkWidget *da, - GdkEventExpose *event, - gpointer data) -{ - int x = event->area.x; - GdkColor red = { 0, 65535, 0, 0 }; - GdkColor green = { 0, 0, 65535, 0 }; - GdkColor blue = { 0, 0, 0, 65535 }; - GdkGC *gc; - - gc = gdk_gc_new (event->window); - - while (x < (event->area.x + event->area.width)) - { - switch (x % 7) - { - case 0: - case 1: - case 2: - gdk_gc_set_rgb_fg_color (gc, &red); - break; - - case 3: - case 4: - case 5: - gdk_gc_set_rgb_fg_color (gc, &green); - break; - - case 6: - case 7: - case 8: - gdk_gc_set_rgb_fg_color (gc, &blue); - break; - - default: - g_assert_not_reached (); - break; - } - - gdk_draw_line (event->window, - gc, - x, event->area.y, - x, event->area.y + event->area.height); - - ++x; - } - - g_object_unref (gc); - - return TRUE; -} - -static void -create_get_image (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (window) - gtk_widget_destroy (window); - else - { - GtkWidget *sw; - GtkWidget *src; - GtkWidget *snap; - GtkWidget *hbox; - GtkWidget *vbox; - GtkWidget *button; - struct GetImageData *gid; - - gid = g_new (struct GetImageData, 1); - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, - "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - g_object_set_data_full (G_OBJECT (window), - "testgtk-get-image-data", - gid, - g_free); - - hbox = gtk_hbox_new (FALSE, 0); - - gtk_container_add (GTK_CONTAINER (window), hbox); - - sw = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - - gid->sw = sw; - - gtk_widget_set_size_request (sw, 400, 400); - - src = gtk_drawing_area_new (); - gtk_widget_set_size_request (src, 10000, 10000); - - g_signal_connect (src, - "expose_event", - G_CALLBACK (image_source_expose), - gid); - - gid->src = src; - - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sw), - src); - - gtk_box_pack_start (GTK_BOX (hbox), - sw, TRUE, TRUE, 0); - - - vbox = gtk_vbox_new (FALSE, 3); - - snap = gtk_widget_new (GTK_TYPE_IMAGE, NULL); - - gid->snap = snap; - - sw = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - gtk_widget_set_size_request (sw, 300, 300); - - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sw), snap); - - gtk_box_pack_end (GTK_BOX (vbox), sw, FALSE, FALSE, 5); - - button = gtk_button_new_with_label ("Get image from drawable"); - - g_signal_connect (button, - "clicked", - G_CALLBACK (take_snapshot), - gid); - - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - gtk_box_pack_end (GTK_BOX (hbox), vbox, FALSE, FALSE, 0); - - gtk_widget_show_all (window); - } -} - -/* - * Label Demo - */ -static void -sensitivity_toggled (GtkWidget *toggle, - GtkWidget *widget) -{ - gtk_widget_set_sensitive (widget, GTK_TOGGLE_BUTTON (toggle)->active); -} - -static GtkWidget* -create_sensitivity_control (GtkWidget *widget) -{ - GtkWidget *button; - - button = gtk_toggle_button_new_with_label ("Sensitive"); - - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), - GTK_WIDGET_IS_SENSITIVE (widget)); - - g_signal_connect (button, - "toggled", - G_CALLBACK (sensitivity_toggled), - widget); - - gtk_widget_show_all (button); - - return button; -} - -static void -set_selectable_recursive (GtkWidget *widget, - gboolean setting) -{ - if (GTK_IS_CONTAINER (widget)) - { - GList *children; - GList *tmp; - - children = gtk_container_get_children (GTK_CONTAINER (widget)); - tmp = children; - while (tmp) - { - set_selectable_recursive (tmp->data, setting); - - tmp = tmp->next; - } - g_list_free (children); - } - else if (GTK_IS_LABEL (widget)) - { - gtk_label_set_selectable (GTK_LABEL (widget), setting); - } -} - -static void -selectable_toggled (GtkWidget *toggle, - GtkWidget *widget) -{ - set_selectable_recursive (widget, - GTK_TOGGLE_BUTTON (toggle)->active); -} - -static GtkWidget* -create_selectable_control (GtkWidget *widget) -{ - GtkWidget *button; - - button = gtk_toggle_button_new_with_label ("Selectable"); - - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), - FALSE); - - g_signal_connect (button, - "toggled", - G_CALLBACK (selectable_toggled), - widget); - - gtk_widget_show_all (button); - - return button; -} - -void create_labels (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *hbox; - GtkWidget *vbox; - GtkWidget *frame; - GtkWidget *label; - GtkWidget *button; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Label"); - - vbox = gtk_vbox_new (FALSE, 5); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_add (GTK_CONTAINER (window), vbox); - - gtk_box_pack_end (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - button = create_sensitivity_control (hbox); - - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = create_selectable_control (hbox); - - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - vbox = gtk_vbox_new (FALSE, 5); - - gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (window), 5); - - frame = gtk_frame_new ("Normal Label"); - label = gtk_label_new ("This is a Normal label"); - gtk_label_set_ellipsize (GTK_LABEL (label), PANGO_ELLIPSIZE_START); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Multi-line Label"); - label = gtk_label_new ("This is a Multi-line label.\nSecond line\nThird line"); - gtk_label_set_ellipsize (GTK_LABEL (label), PANGO_ELLIPSIZE_END); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Left Justified Label"); - label = gtk_label_new ("This is a Left-Justified\nMulti-line label.\nThird line"); - gtk_label_set_ellipsize (GTK_LABEL (label), PANGO_ELLIPSIZE_MIDDLE); - gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Right Justified Label"); - gtk_label_set_ellipsize (GTK_LABEL (label), PANGO_ELLIPSIZE_START); - label = gtk_label_new ("This is a Right-Justified\nMulti-line label.\nFourth line, (j/k)"); - gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_RIGHT); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Internationalized Label"); - label = gtk_label_new (NULL); - gtk_label_set_markup (GTK_LABEL (label), - "French (Fran\303\247ais) Bonjour, Salut\n" - "Korean (\355\225\234\352\270\200) \354\225\210\353\205\225\355\225\230\354\204\270\354\232\224, \354\225\210\353\205\225\355\225\230\354\213\255\353\213\210\352\271\214\n" - "Russian (\320\240\321\203\321\201\321\201\320\272\320\270\320\271) \320\227\320\264\321\200\320\260\320\262\321\201\321\202\320\262\321\203\320\271\321\202\320\265!\n" - "Chinese (Simplified) <span lang=\"zh-cn\">\345\205\203\346\260\224 \345\274\200\345\217\221</span>\n" - "Chinese (Traditional) <span lang=\"zh-tw\">\345\205\203\346\260\243 \351\226\213\347\231\274</span>\n" - "Japanese <span lang=\"ja\">\345\205\203\346\260\227 \351\226\213\347\231\272</span>"); - gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Bidirection Label"); - label = gtk_label_new ("\342\200\217Arabic \330\247\331\204\330\263\331\204\330\247\331\205 \330\271\331\204\331\212\331\203\331\205\n" - "\342\200\217Hebrew \327\251\327\234\327\225\327\235"); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - vbox = gtk_vbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0); - frame = gtk_frame_new ("Line wrapped label"); - label = gtk_label_new ("This is an example of a line-wrapped label. It should not be taking "\ - "up the entire "/* big space to test spacing */\ - "width allocated to it, but automatically wraps the words to fit. "\ - "The time has come, for all good men, to come to the aid of their party. "\ - "The sixth sheik's six sheep's sick.\n"\ - " It supports multiple paragraphs correctly, and correctly adds "\ - "many extra spaces. "); - - gtk_label_set_line_wrap (GTK_LABEL (label), TRUE); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Filled, wrapped label"); - label = gtk_label_new ("This is an example of a line-wrapped, filled label. It should be taking "\ - "up the entire width allocated to it. Here is a seneance to prove "\ - "my point. Here is another sentence. "\ - "Here comes the sun, do de do de do.\n"\ - " This is a new paragraph.\n"\ - " This is another newer, longer, better paragraph. It is coming to an end, "\ - "unfortunately."); - gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_FILL); - gtk_label_set_line_wrap (GTK_LABEL (label), TRUE); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Underlined label"); - label = gtk_label_new ("This label is underlined!\n" - "This one is underlined (\343\201\223\343\202\223\343\201\253\343\201\241\343\201\257) in quite a funky fashion"); - gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT); - gtk_label_set_pattern (GTK_LABEL (label), "_________________________ _ _________ _ _____ _ __ __ ___ ____ _____"); - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - - frame = gtk_frame_new ("Markup label"); - label = gtk_label_new (NULL); - - /* There's also a gtk_label_set_markup() without accel if you - * don't have an accelerator key - */ - gtk_label_set_markup_with_mnemonic (GTK_LABEL (label), - "This <span foreground=\"blue\" background=\"orange\">label</span> has " - "<b>markup</b> _such as " - "<big><i>Big Italics</i></big>\n" - "<tt>Monospace font</tt>\n" - "<u>Underline!</u>\n" - "foo\n" - "<span foreground=\"green\" background=\"red\">Ugly colors</span>\n" - "and nothing on this line,\n" - "or this.\n" - "or this either\n" - "or even on this one\n" - "la <big>la <big>la <big>la <big>la</big></big></big></big>\n" - "but this _word is <span foreground=\"purple\"><big>purple</big></span>\n" - "<span underline=\"double\">We like <sup>superscript</sup> and <sub>subscript</sub> too</span>"); - - g_assert (gtk_label_get_mnemonic_keyval (GTK_LABEL (label)) == GDK_s); - - gtk_container_add (GTK_CONTAINER (frame), label); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -static void -on_angle_scale_changed (GtkRange *range, - GtkLabel *label) -{ - gtk_label_set_angle (GTK_LABEL (label), gtk_range_get_value (range)); -} - -static void -create_rotated_label (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *vbox; - GtkWidget *hscale; - GtkWidget *label; - GtkWidget *scale_label; - GtkWidget *scale_hbox; - - if (!window) - { - window = gtk_dialog_new_with_buttons ("Rotated Label", - GTK_WINDOW (gtk_widget_get_toplevel (widget)), 0, - GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE, - NULL); - - gtk_window_set_resizable (GTK_WINDOW (window), TRUE); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_object_destroy), NULL); - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), &window); - - vbox = gtk_vbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox, TRUE, TRUE, 0); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - - label = gtk_label_new (NULL); - gtk_label_set_markup (GTK_LABEL (label), "Hello World\n<i>Rotate</i> <span underline='single' foreground='blue'>me</span>"); - gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0); - - scale_hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), scale_hbox, FALSE, FALSE, 0); - - scale_label = gtk_label_new (NULL); - gtk_label_set_markup (GTK_LABEL (scale_label), "<i>Angle: </i>"); - gtk_box_pack_start (GTK_BOX (scale_hbox), scale_label, FALSE, FALSE, 0); - - hscale = gtk_hscale_new_with_range (0, 360, 5); - g_signal_connect (hscale, "value-changed", - G_CALLBACK (on_angle_scale_changed), label); - - gtk_range_set_value (GTK_RANGE (hscale), 45); - gtk_widget_set_usize (hscale, 200, -1); - gtk_box_pack_start (GTK_BOX (scale_hbox), hscale, TRUE, TRUE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -#define DEFAULT_TEXT_RADIUS 200 - -static void -on_rotated_text_unrealize (GtkWidget *widget) -{ - g_object_set_data (G_OBJECT (widget), "text-gc", NULL); -} - -static gboolean -on_rotated_text_expose (GtkWidget *widget, - GdkEventExpose *event, - GdkPixbuf *tile_pixbuf) -{ - static const gchar *words[] = { "The", "grand", "old", "Duke", "of", "York", - "had", "10,000", "men" }; - PangoRenderer *renderer; - GdkGC *gc; - int n_words; - int i; - double radius; - PangoMatrix matrix = PANGO_MATRIX_INIT; - PangoLayout *layout; - PangoContext *context; - PangoFontDescription *desc; - - gc = g_object_get_data (G_OBJECT (widget), "text-gc"); - if (!gc) - { - static GdkColor black = { 0, 0, 0, 0 }; - - gc = gdk_gc_new (widget->window); - gdk_gc_set_rgb_fg_color (gc, &black); - - if (tile_pixbuf) - { - GdkPixmap *tile; - - gint width = gdk_pixbuf_get_width (tile_pixbuf); - gint height = gdk_pixbuf_get_height (tile_pixbuf); - - tile = gdk_pixmap_new (widget->window, width, height, -1); - gdk_draw_pixbuf (tile, gc, tile_pixbuf, - 0, 0, 0, 0, width, height, - GDK_RGB_DITHER_NORMAL, 0, 0); - - gdk_gc_set_tile (gc, tile); - gdk_gc_set_fill (gc, GDK_TILED); - - g_object_unref (tile); - } - - g_object_set_data_full (G_OBJECT (widget), "text-gc", gc, (GDestroyNotify)g_object_unref); - } - - renderer = gdk_pango_renderer_get_default (gtk_widget_get_screen (widget)); - gdk_pango_renderer_set_drawable (GDK_PANGO_RENDERER (renderer), widget->window); - gdk_pango_renderer_set_gc (GDK_PANGO_RENDERER (renderer), gc); - - radius = MIN (widget->allocation.width, widget->allocation.height) / 2.; - - pango_matrix_translate (&matrix, - radius + (widget->allocation.width - 2 * radius) / 2, - radius + (widget->allocation.height - 2 * radius) / 2); - pango_matrix_scale (&matrix, radius / DEFAULT_TEXT_RADIUS, radius / DEFAULT_TEXT_RADIUS); - - context = gtk_widget_get_pango_context (widget); - layout = pango_layout_new (context); - desc = pango_font_description_from_string ("Sans Bold 30"); - pango_layout_set_font_description (layout, desc); - pango_font_description_free (desc); - - n_words = G_N_ELEMENTS (words); - for (i = 0; i < n_words; i++) - { - PangoMatrix rotated_matrix = matrix; - int width, height; - - pango_matrix_rotate (&rotated_matrix, - (360. * i) / n_words); - - pango_context_set_matrix (context, &rotated_matrix); - pango_layout_context_changed (layout); - pango_layout_set_text (layout, words[i], -1); - - pango_layout_get_size (layout, &width, &height); - - pango_renderer_draw_layout (renderer, layout, - - width / 2, - DEFAULT_TEXT_RADIUS * PANGO_SCALE); - } - - gdk_pango_renderer_set_drawable (GDK_PANGO_RENDERER (renderer), NULL); - gdk_pango_renderer_set_gc (GDK_PANGO_RENDERER (renderer), NULL); - - g_object_unref (layout); - - return FALSE; -} - -static void -create_rotated_text (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - const GdkColor white = { 0, 0xffff, 0xffff, 0xffff }; - GtkRequisition requisition; - GtkWidget *drawing_area; - GdkPixbuf *tile_pixbuf; - - window = gtk_dialog_new_with_buttons ("Rotated Text", - GTK_WINDOW (gtk_widget_get_toplevel (widget)), 0, - GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE, - NULL); - - gtk_window_set_resizable (GTK_WINDOW (window), TRUE); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_object_destroy), NULL); - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), &window); - - drawing_area = gtk_drawing_area_new (); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), drawing_area, TRUE, TRUE, 0); - gtk_widget_modify_bg (drawing_area, GTK_STATE_NORMAL, &white); - - tile_pixbuf = gdk_pixbuf_new_from_file ("marble.xpm", NULL); - - g_signal_connect (drawing_area, "expose-event", - G_CALLBACK (on_rotated_text_expose), tile_pixbuf); - g_signal_connect (drawing_area, "unrealize", - G_CALLBACK (on_rotated_text_unrealize), NULL); - - gtk_widget_show_all (GTK_BIN (window)->child); - - gtk_widget_set_size_request (drawing_area, DEFAULT_TEXT_RADIUS * 2, DEFAULT_TEXT_RADIUS * 2); - gtk_widget_size_request (window, &requisition); - gtk_widget_set_size_request (drawing_area, -1, -1); - gtk_window_resize (GTK_WINDOW (window), requisition.width, requisition.height); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Reparent demo - */ - -static void -reparent_label (GtkWidget *widget, - GtkWidget *new_parent) -{ - GtkWidget *label; - - label = g_object_get_data (G_OBJECT (widget), "user_data"); - - gtk_widget_reparent (label, new_parent); -} - -static void -set_parent_signal (GtkWidget *child, - GtkWidget *old_parent, - gpointer func_data) -{ - g_message ("set_parent for \"%s\": new parent: \"%s\", old parent: \"%s\", data: %d\n", - g_type_name (G_OBJECT_TYPE (child)), - child->parent ? g_type_name (G_OBJECT_TYPE (child->parent)) : "NULL", - old_parent ? g_type_name (G_OBJECT_TYPE (old_parent)) : "NULL", - GPOINTER_TO_INT (func_data)); -} - -static void -create_reparent (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *box3; - GtkWidget *frame; - GtkWidget *button; - GtkWidget *label; - GtkWidget *separator; - GtkWidget *event_box; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "reparent"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - box2 = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - label = gtk_label_new ("Hello World"); - - frame = gtk_frame_new ("Frame 1"); - gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0); - - box3 = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (box3), 5); - gtk_container_add (GTK_CONTAINER (frame), box3); - - button = gtk_button_new_with_label ("switch"); - g_object_set_data (G_OBJECT (button), "user_data", label); - gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0); - - event_box = gtk_event_box_new (); - gtk_box_pack_start (GTK_BOX (box3), event_box, FALSE, TRUE, 0); - gtk_container_add (GTK_CONTAINER (event_box), label); - - g_signal_connect (button, "clicked", - G_CALLBACK (reparent_label), - event_box); - - g_signal_connect (label, "parent_set", - G_CALLBACK (set_parent_signal), - GINT_TO_POINTER (42)); - - frame = gtk_frame_new ("Frame 2"); - gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0); - - box3 = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (box3), 5); - gtk_container_add (GTK_CONTAINER (frame), box3); - - button = gtk_button_new_with_label ("switch"); - g_object_set_data (G_OBJECT (button), "user_data", label); - gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0); - - event_box = gtk_event_box_new (); - gtk_box_pack_start (GTK_BOX (box3), event_box, FALSE, TRUE, 0); - - g_signal_connect (button, "clicked", - G_CALLBACK (reparent_label), - event_box); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Resize Grips - */ -static gboolean -grippy_button_press (GtkWidget *area, GdkEventButton *event, GdkWindowEdge edge) -{ - if (event->type == GDK_BUTTON_PRESS) - { - if (event->button == 1) - gtk_window_begin_resize_drag (GTK_WINDOW (gtk_widget_get_toplevel (area)), edge, - event->button, event->x_root, event->y_root, - event->time); - else if (event->button == 2) - gtk_window_begin_move_drag (GTK_WINDOW (gtk_widget_get_toplevel (area)), - event->button, event->x_root, event->y_root, - event->time); - } - return TRUE; -} - -static gboolean -grippy_expose (GtkWidget *area, GdkEventExpose *event, GdkWindowEdge edge) -{ - gtk_paint_resize_grip (area->style, - area->window, - GTK_WIDGET_STATE (area), - &event->area, - area, - "statusbar", - edge, - 0, 0, - area->allocation.width, - area->allocation.height); - - return TRUE; -} - -static void -create_resize_grips (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *area; - GtkWidget *hbox, *vbox; - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_title (GTK_WINDOW (window), "resize grips"); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 0); - - /* North west */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH_WEST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH_WEST)); - - /* North */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH)); - - /* North east */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH_EAST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_NORTH_EAST)); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 0); - - /* West */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_WEST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_WEST)); - - /* Middle */ - area = gtk_drawing_area_new (); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - - /* East */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_EAST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_EAST)); - - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 0); - - /* South west */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH_WEST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH_WEST)); - /* South */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH)); - - /* South east */ - area = gtk_drawing_area_new (); - gtk_widget_add_events (area, GDK_BUTTON_PRESS_MASK); - gtk_box_pack_start (GTK_BOX (hbox), area, TRUE, TRUE, 0); - g_signal_connect (area, "expose_event", G_CALLBACK (grippy_expose), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH_EAST)); - g_signal_connect (area, "button_press_event", G_CALLBACK (grippy_button_press), - GINT_TO_POINTER (GDK_WINDOW_EDGE_SOUTH_EAST)); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Saved Position - */ -gint upositionx = 0; -gint upositiony = 0; - -static gint -uposition_configure (GtkWidget *window) -{ - GtkLabel *lx; - GtkLabel *ly; - gchar buffer[64]; - - lx = g_object_get_data (G_OBJECT (window), "x"); - ly = g_object_get_data (G_OBJECT (window), "y"); - - gdk_window_get_root_origin (window->window, &upositionx, &upositiony); - sprintf (buffer, "%d", upositionx); - gtk_label_set_text (lx, buffer); - sprintf (buffer, "%d", upositiony); - gtk_label_set_text (ly, buffer); - - return FALSE; -} - -static void -uposition_stop_configure (GtkToggleButton *toggle, - GtkObject *window) -{ - if (toggle->active) - g_signal_handlers_block_by_func (window, G_CALLBACK (uposition_configure), NULL); - else - g_signal_handlers_unblock_by_func (window, G_CALLBACK (uposition_configure), NULL); -} - -static void -create_saved_position (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *hbox; - GtkWidget *main_vbox; - GtkWidget *vbox; - GtkWidget *x_label; - GtkWidget *y_label; - GtkWidget *button; - GtkWidget *label; - GtkWidget *any; - - window = g_object_connect (gtk_widget_new (GTK_TYPE_WINDOW, - "type", GTK_WINDOW_TOPLEVEL, - "title", "Saved Position", - NULL), - "signal::configure_event", uposition_configure, NULL, - NULL); - - gtk_window_move (GTK_WINDOW (window), upositionx, upositiony); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - main_vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 0); - gtk_container_add (GTK_CONTAINER (window), main_vbox); - - vbox = - gtk_widget_new (gtk_vbox_get_type (), - "GtkBox::homogeneous", FALSE, - "GtkBox::spacing", 5, - "GtkContainer::border_width", 10, - "GtkWidget::parent", main_vbox, - "GtkWidget::visible", TRUE, - "child", g_object_connect (gtk_widget_new (GTK_TYPE_TOGGLE_BUTTON, - "label", "Stop Events", - "active", FALSE, - "visible", TRUE, - NULL), - "signal::clicked", uposition_stop_configure, window, - NULL), - NULL); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - label = gtk_label_new ("X Origin : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - x_label = gtk_label_new (""); - gtk_box_pack_start (GTK_BOX (hbox), x_label, TRUE, TRUE, 0); - g_object_set_data (G_OBJECT (window), "x", x_label); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - label = gtk_label_new ("Y Origin : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - y_label = gtk_label_new (""); - gtk_box_pack_start (GTK_BOX (hbox), y_label, TRUE, TRUE, 0); - g_object_set_data (G_OBJECT (window), "y", y_label); - - any = - gtk_widget_new (gtk_hseparator_get_type (), - "GtkWidget::visible", TRUE, - NULL); - gtk_box_pack_start (GTK_BOX (main_vbox), any, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 10); - gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - - gtk_widget_show_all (window); - } - else - gtk_widget_destroy (window); -} - -/* - * GtkPixmap - */ - -static void -create_pixmap (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *box3; - GtkWidget *button; - GtkWidget *label; - GtkWidget *separator; - GtkWidget *pixmapwid; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkPixmap"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - gtk_widget_realize(window); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_button_new (); - gtk_box_pack_start (GTK_BOX (box2), button, FALSE, FALSE, 0); - - pixmapwid = new_pixmap ("test.xpm", window->window, NULL); - - label = gtk_label_new ("Pixmap\ntest"); - box3 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (box3), 2); - gtk_container_add (GTK_CONTAINER (box3), pixmapwid); - gtk_container_add (GTK_CONTAINER (box3), label); - gtk_container_add (GTK_CONTAINER (button), box3); - - button = gtk_button_new (); - gtk_box_pack_start (GTK_BOX (box2), button, FALSE, FALSE, 0); - - pixmapwid = new_pixmap ("test.xpm", window->window, NULL); - - label = gtk_label_new ("Pixmap\ntest"); - box3 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (box3), 2); - gtk_container_add (GTK_CONTAINER (box3), pixmapwid); - gtk_container_add (GTK_CONTAINER (box3), label); - gtk_container_add (GTK_CONTAINER (button), box3); - - gtk_widget_set_sensitive (button, FALSE); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -static void -tips_query_widget_entered (GtkTipsQuery *tips_query, - GtkWidget *widget, - const gchar *tip_text, - const gchar *tip_private, - GtkWidget *toggle) -{ - if (GTK_TOGGLE_BUTTON (toggle)->active) - { - gtk_label_set_text (GTK_LABEL (tips_query), tip_text ? "There is a Tip!" : "There is no Tip!"); - /* don't let GtkTipsQuery reset its label */ - g_signal_stop_emission_by_name (tips_query, "widget_entered"); - } -} - -static gint -tips_query_widget_selected (GtkWidget *tips_query, - GtkWidget *widget, - const gchar *tip_text, - const gchar *tip_private, - GdkEventButton *event, - gpointer func_data) -{ - if (widget) - g_print ("Help \"%s\" requested for <%s>\n", - tip_private ? tip_private : "None", - g_type_name (G_OBJECT_TYPE (widget))); - return TRUE; -} - -static void -create_tooltips (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *box3; - GtkWidget *button; - GtkWidget *toggle; - GtkWidget *frame; - GtkWidget *tips_query; - GtkWidget *separator; - GtkTooltips *tooltips; - - if (!window) - { - window = - gtk_widget_new (gtk_window_get_type (), - "GtkWindow::type", GTK_WINDOW_TOPLEVEL, - "GtkContainer::border_width", 0, - "GtkWindow::title", "Tooltips", - "GtkWindow::allow_shrink", TRUE, - "GtkWindow::allow_grow", FALSE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (destroy_tooltips), - &window); - - tooltips=gtk_tooltips_new(); - g_object_ref (tooltips); - gtk_object_sink (GTK_OBJECT (tooltips)); - g_object_set_data (G_OBJECT (window), "tooltips", tooltips); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - button = gtk_toggle_button_new_with_label ("button1"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - gtk_tooltips_set_tip (tooltips, - button, - "This is button 1", - "ContextHelp/buttons/1"); - - button = gtk_toggle_button_new_with_label ("button2"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - gtk_tooltips_set_tip (tooltips, - button, - "This is button 2. This is also a really long tooltip which probably won't fit on a single line and will therefore need to be wrapped. Hopefully the wrapping will work correctly.", - "ContextHelp/buttons/2_long"); - - toggle = gtk_toggle_button_new_with_label ("Override TipsQuery Label"); - gtk_box_pack_start (GTK_BOX (box2), toggle, TRUE, TRUE, 0); - - gtk_tooltips_set_tip (tooltips, - toggle, - "Toggle TipsQuery view.", - "Hi msw! ;)"); - - box3 = - gtk_widget_new (gtk_vbox_get_type (), - "homogeneous", FALSE, - "spacing", 5, - "border_width", 5, - "visible", TRUE, - NULL); - - tips_query = gtk_tips_query_new (); - - button = - gtk_widget_new (gtk_button_get_type (), - "label", "[?]", - "visible", TRUE, - "parent", box3, - NULL); - g_object_connect (button, - "swapped_signal::clicked", gtk_tips_query_start_query, tips_query, - NULL); - gtk_box_set_child_packing (GTK_BOX (box3), button, FALSE, FALSE, 0, GTK_PACK_START); - gtk_tooltips_set_tip (tooltips, - button, - "Start the Tooltips Inspector", - "ContextHelp/buttons/?"); - - - g_object_set (g_object_connect (tips_query, - "signal::widget_entered", tips_query_widget_entered, toggle, - "signal::widget_selected", tips_query_widget_selected, NULL, - NULL), - "visible", TRUE, - "parent", box3, - "caller", button, - NULL); - - frame = gtk_widget_new (gtk_frame_get_type (), - "label", "ToolTips Inspector", - "label_xalign", (double) 0.5, - "border_width", 0, - "visible", TRUE, - "parent", box2, - "child", box3, - NULL); - gtk_box_set_child_packing (GTK_BOX (box2), frame, TRUE, TRUE, 10, GTK_PACK_START); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - - gtk_tooltips_set_tip (tooltips, button, "Push this button to close window", "ContextHelp/buttons/Close"); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkImage - */ - -static void -pack_image (GtkWidget *box, - const gchar *text, - GtkWidget *image) -{ - gtk_box_pack_start (GTK_BOX (box), - gtk_label_new (text), - FALSE, FALSE, 0); - - gtk_box_pack_start (GTK_BOX (box), - image, - TRUE, TRUE, 0); -} - -static void -create_image (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (window == NULL) - { - GtkWidget *vbox; - GdkPixmap *pixmap; - GdkBitmap *mask; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - /* this is bogus for testing drawing when allocation < request, - * don't copy into real code - */ - g_object_set (window, "allow_shrink", TRUE, "allow_grow", TRUE, NULL); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - vbox = gtk_vbox_new (FALSE, 5); - - gtk_container_add (GTK_CONTAINER (window), vbox); - - pack_image (vbox, "Stock Warning Dialog", - gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING, - GTK_ICON_SIZE_DIALOG)); - - pixmap = gdk_pixmap_colormap_create_from_xpm_d (NULL, - gtk_widget_get_colormap (window), - &mask, - NULL, - openfile); - - pack_image (vbox, "Pixmap", - gtk_image_new_from_pixmap (pixmap, mask)); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Menu demo - */ - -static GtkWidget* -create_menu (GdkScreen *screen, gint depth, gint length, gboolean tearoff) -{ - GtkWidget *menu; - GtkWidget *menuitem; - GtkWidget *image; - GSList *group; - char buf[32]; - int i, j; - - if (depth < 1) - return NULL; - - menu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (menu), screen); - - group = NULL; - - if (tearoff) - { - menuitem = gtk_tearoff_menu_item_new (); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - } - - image = gtk_image_new_from_stock (GTK_STOCK_OPEN, - GTK_ICON_SIZE_MENU); - gtk_widget_show (image); - menuitem = gtk_image_menu_item_new_with_label ("Image item"); - gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (menuitem), image); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - - for (i = 0, j = 1; i < length; i++, j++) - { - sprintf (buf, "item %2d - %d", depth, j); - - menuitem = gtk_radio_menu_item_new_with_label (group, buf); - group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menuitem)); - -#if 0 - if (depth % 2) - gtk_check_menu_item_set_show_toggle (GTK_CHECK_MENU_ITEM (menuitem), TRUE); -#endif - - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - if (i == 3) - gtk_widget_set_sensitive (menuitem, FALSE); - - if (i == 5) - gtk_check_menu_item_set_inconsistent (GTK_CHECK_MENU_ITEM (menuitem), - TRUE); - - if (i < 5) - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), - create_menu (screen, depth - 1, 5, TRUE)); - } - - return menu; -} - -static GtkWidget* -create_table_menu (GdkScreen *screen, gint cols, gint rows, gboolean tearoff) -{ - GtkWidget *menu; - GtkWidget *menuitem; - GtkWidget *submenu; - GtkWidget *image; - char buf[32]; - int i, j; - - menu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (menu), screen); - - j = 0; - if (tearoff) - { - menuitem = gtk_tearoff_menu_item_new (); - gtk_menu_attach (GTK_MENU (menu), menuitem, 0, cols, j, j + 1); - gtk_widget_show (menuitem); - j++; - } - - menuitem = gtk_menu_item_new_with_label ("items"); - gtk_menu_attach (GTK_MENU (menu), menuitem, 0, cols, j, j + 1); - - submenu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (submenu), screen); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_widget_show (menuitem); - j++; - - /* now fill the items submenu */ - image = gtk_image_new_from_stock (GTK_STOCK_HELP, - GTK_ICON_SIZE_MENU); - gtk_widget_show (image); - menuitem = gtk_image_menu_item_new_with_label ("Image"); - gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (menuitem), image); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 0, 1); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 0, 1); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 1, 2); - gtk_widget_show (menuitem); - - image = gtk_image_new_from_stock (GTK_STOCK_HELP, - GTK_ICON_SIZE_MENU); - gtk_widget_show (image); - menuitem = gtk_image_menu_item_new_with_label ("Image"); - gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (menuitem), image); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 1, 2); - gtk_widget_show (menuitem); - - menuitem = gtk_radio_menu_item_new_with_label (NULL, "Radio"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 2, 3); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 2, 3); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 3, 4); - gtk_widget_show (menuitem); - - menuitem = gtk_radio_menu_item_new_with_label (NULL, "Radio"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 3, 4); - gtk_widget_show (menuitem); - - menuitem = gtk_check_menu_item_new_with_label ("Check"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 4, 5); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 4, 5); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("x"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 5, 6); - gtk_widget_show (menuitem); - - menuitem = gtk_check_menu_item_new_with_label ("Check"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 5, 6); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("1. Inserted normally (8)"); - gtk_widget_show (menuitem); - gtk_menu_shell_insert (GTK_MENU_SHELL (submenu), menuitem, 8); - - menuitem = gtk_menu_item_new_with_label ("2. Inserted normally (2)"); - gtk_widget_show (menuitem); - gtk_menu_shell_insert (GTK_MENU_SHELL (submenu), menuitem, 2); - - menuitem = gtk_menu_item_new_with_label ("3. Inserted normally (0)"); - gtk_widget_show (menuitem); - gtk_menu_shell_insert (GTK_MENU_SHELL (submenu), menuitem, 0); - - menuitem = gtk_menu_item_new_with_label ("4. Inserted normally (-1)"); - gtk_widget_show (menuitem); - gtk_menu_shell_insert (GTK_MENU_SHELL (submenu), menuitem, -1); - - /* end of items submenu */ - - menuitem = gtk_menu_item_new_with_label ("spanning"); - gtk_menu_attach (GTK_MENU (menu), menuitem, 0, cols, j, j + 1); - - submenu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (submenu), screen); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_widget_show (menuitem); - j++; - - /* now fill the spanning submenu */ - menuitem = gtk_menu_item_new_with_label ("a"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 2, 0, 1); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("b"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 2, 3, 0, 2); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("c"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 1, 3); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("d"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 2, 1, 2); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("e"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 1, 3, 2, 3); - gtk_widget_show (menuitem); - /* end of spanning submenu */ - - menuitem = gtk_menu_item_new_with_label ("left"); - gtk_menu_attach (GTK_MENU (menu), menuitem, 0, 1, j, j + 1); - submenu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (submenu), screen); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("Empty"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 0, 1); - submenu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (submenu), screen); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("right"); - gtk_menu_attach (GTK_MENU (menu), menuitem, 1, 2, j, j + 1); - submenu = gtk_menu_new (); - gtk_menu_set_screen (GTK_MENU (submenu), screen); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), submenu); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("Empty"); - gtk_menu_attach (GTK_MENU (submenu), menuitem, 0, 1, 0, 1); - gtk_widget_show (menuitem); - - j++; - - for (; j < rows; j++) - for (i = 0; i < cols; i++) - { - sprintf (buf, "(%d %d)", i, j); - menuitem = gtk_menu_item_new_with_label (buf); - gtk_menu_attach (GTK_MENU (menu), menuitem, i, i + 1, j, j + 1); - gtk_widget_show (menuitem); - } - - menuitem = gtk_menu_item_new_with_label ("1. Inserted normally (8)"); - gtk_menu_shell_insert (GTK_MENU_SHELL (menu), menuitem, 8); - gtk_widget_show (menuitem); - menuitem = gtk_menu_item_new_with_label ("2. Inserted normally (2)"); - gtk_menu_shell_insert (GTK_MENU_SHELL (menu), menuitem, 2); - gtk_widget_show (menuitem); - menuitem = gtk_menu_item_new_with_label ("3. Inserted normally (0)"); - gtk_menu_shell_insert (GTK_MENU_SHELL (menu), menuitem, 0); - gtk_widget_show (menuitem); - menuitem = gtk_menu_item_new_with_label ("4. Inserted normally (-1)"); - gtk_menu_shell_insert (GTK_MENU_SHELL (menu), menuitem, -1); - gtk_widget_show (menuitem); - - return menu; -} - -static void -create_menus (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *optionmenu; - GtkWidget *separator; - - if (!window) - { - GtkWidget *menubar; - GtkWidget *menu; - GtkWidget *menuitem; - GtkAccelGroup *accel_group; - GtkWidget *image; - GdkScreen *screen = gtk_widget_get_screen (widget); - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), screen); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - g_signal_connect (window, "delete-event", - G_CALLBACK (gtk_true), - NULL); - - accel_group = gtk_accel_group_new (); - gtk_window_add_accel_group (GTK_WINDOW (window), accel_group); - - gtk_window_set_title (GTK_WINDOW (window), "menus"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_widget_show (box1); - - menubar = gtk_menu_bar_new (); - gtk_box_pack_start (GTK_BOX (box1), menubar, FALSE, TRUE, 0); - gtk_widget_show (menubar); - - menu = create_menu (screen, 2, 50, TRUE); - - menuitem = gtk_menu_item_new_with_label ("test\nline2"); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), menu); - gtk_menu_shell_append (GTK_MENU_SHELL (menubar), menuitem); - gtk_widget_show (menuitem); - - menu = create_table_menu (screen, 2, 50, TRUE); - - menuitem = gtk_menu_item_new_with_label ("table"); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), menu); - gtk_menu_shell_append (GTK_MENU_SHELL (menubar), menuitem); - gtk_widget_show (menuitem); - - menuitem = gtk_menu_item_new_with_label ("foo"); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (screen, 3, 5, TRUE)); - gtk_menu_shell_append (GTK_MENU_SHELL (menubar), menuitem); - gtk_widget_show (menuitem); - - image = gtk_image_new_from_stock (GTK_STOCK_HELP, - GTK_ICON_SIZE_MENU); - gtk_widget_show (image); - menuitem = gtk_image_menu_item_new_with_label ("Help"); - gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (menuitem), image); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (screen, 4, 5, TRUE)); - gtk_menu_item_set_right_justified (GTK_MENU_ITEM (menuitem), TRUE); - gtk_menu_shell_append (GTK_MENU_SHELL (menubar), menuitem); - gtk_widget_show (menuitem); - - menubar = gtk_menu_bar_new (); - gtk_box_pack_start (GTK_BOX (box1), menubar, FALSE, TRUE, 0); - gtk_widget_show (menubar); - - menu = create_menu (screen, 2, 10, TRUE); - - menuitem = gtk_menu_item_new_with_label ("Second menu bar"); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), menu); - gtk_menu_shell_append (GTK_MENU_SHELL (menubar), menuitem); - gtk_widget_show (menuitem); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - gtk_widget_show (box2); - - menu = create_menu (screen, 1, 5, FALSE); - gtk_menu_set_accel_group (GTK_MENU (menu), accel_group); - - menuitem = gtk_image_menu_item_new_from_stock (GTK_STOCK_NEW, accel_group); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - - menuitem = gtk_check_menu_item_new_with_label ("Accelerate Me"); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - gtk_widget_add_accelerator (menuitem, - "activate", - accel_group, - GDK_F1, - 0, - GTK_ACCEL_VISIBLE); - menuitem = gtk_check_menu_item_new_with_label ("Accelerator Locked"); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - gtk_widget_add_accelerator (menuitem, - "activate", - accel_group, - GDK_F2, - 0, - GTK_ACCEL_VISIBLE | GTK_ACCEL_LOCKED); - menuitem = gtk_check_menu_item_new_with_label ("Accelerators Frozen"); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem); - gtk_widget_show (menuitem); - gtk_widget_add_accelerator (menuitem, - "activate", - accel_group, - GDK_F2, - 0, - GTK_ACCEL_VISIBLE); - gtk_widget_add_accelerator (menuitem, - "activate", - accel_group, - GDK_F3, - 0, - GTK_ACCEL_VISIBLE); - - optionmenu = gtk_option_menu_new (); - gtk_option_menu_set_menu (GTK_OPTION_MENU (optionmenu), menu); - gtk_option_menu_set_history (GTK_OPTION_MENU (optionmenu), 3); - gtk_box_pack_start (GTK_BOX (box2), optionmenu, TRUE, TRUE, 0); - gtk_widget_show (optionmenu); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - gtk_widget_show (separator); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - gtk_widget_show (box2); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -static void -gtk_ifactory_cb (gpointer callback_data, - guint callback_action, - GtkWidget *widget) -{ - g_message ("ItemFactory: activated \"%s\"", gtk_item_factory_path_from_widget (widget)); -} - -/* GdkPixbuf RGBA C-Source image dump */ - -static const guint8 apple[] = -{ "" - /* Pixbuf magic (0x47646b50) */ - "GdkP" - /* length: header (24) + pixel_data (2304) */ - "\0\0\11\30" - /* pixdata_type (0x1010002) */ - "\1\1\0\2" - /* rowstride (96) */ - "\0\0\0`" - /* width (24) */ - "\0\0\0\30" - /* height (24) */ - "\0\0\0\30" - /* pixel_data: */ - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\26\24" - "\17\11\0\0\0\2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0`m" - "[pn{a\344hv_\345_k[`\0\0\0\0\0\0\0\0\0\0\0\0D>/\305\0\0\0_\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0`l[Blza\373s\202d\354w\206g\372p~c" - "\374`l[y\0\0\0\0[S\77/\27\25\17\335\0\0\0\20\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0`l\\\20iw_\356y\211h\373x\207g\364~\216i\364u\204e\366gt" - "_\374^jX\241A;-_\0\0\0~\0\0\0\0SM4)SM21B9&\22\320\270\204\1\320\270\204" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0eq" - "]\212r\200c\366v\205f\371jx_\323_kY\232_kZH^jY\26]iW\211@G9\272:6%j\220" - "\211]\320\221\211`\377\212\203Z\377~xP\377mkE\331]^;|/0\37\21\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0ly`\40p~b\360lz`\353^kY\246[" - "eT<\216\200Z\203\227\211_\354\234\217c\377\232\217b\362\232\220c\337" - "\243\233k\377\252\241p\377\250\236p\377\241\225h\377\231\214_\377\210" - "\202U\377srI\377[]:\355KO0U\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0i" - "v^\200`lY\211^jY\"\0\0\0\0\221\204\\\273\250\233r\377\302\267\224\377" - "\311\300\237\377\272\256\204\377\271\256\177\377\271\257\200\377\267" - "\260\177\377\260\251x\377\250\236l\377\242\225e\377\226\213]\377~zP\377" - "ff@\377QT5\377LR2d\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0]iW(\0\0\0\0\0\0\0" - "\0\213\203[v\253\240t\377\334\326\301\377\344\340\317\377\321\312\253" - "\377\303\271\217\377\300\270\213\377\277\267\210\377\272\264\203\377" - "\261\255z\377\250\242n\377\243\232h\377\232\220`\377\210\202V\377nnE" - "\377SW6\377RX6\364Za<\34\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0b]@\20" - "\234\222e\362\304\274\232\377\337\333\306\377\332\325\273\377\311\302" - "\232\377\312\303\236\377\301\273\216\377\300\271\212\377\270\264\200" - "\377\256\253v\377\246\243n\377\236\232h\377\230\220`\377\213\203V\377" - "wvL\377X]:\377KR0\377NU5v\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\212" - "\203Zl\242\234l\377\321\315\260\377\331\324\271\377\320\313\251\377\307" - "\301\232\377\303\276\224\377\300\272\214\377\274\267\206\377\264\260" - "|\377\253\251s\377\244\243n\377\232\230e\377\223\216^\377\207\200U\377" - "ttJ\377[_<\377HO/\377GN0\200\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\210\204Y\240\245\237o\377\316\310\253\377\310\303\237\377\304\300\230" - "\377\303\277\225\377\277\272\216\377\274\270\210\377\266\263\200\377" - "\256\254v\377\247\246p\377\237\236j\377\227\226d\377\215\212[\377\203" - "\177T\377qsH\377X]8\377FN.\377DK-\200\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\207\204X\257\244\240o\377\300\275\231\377\301\275\226\377\274" - "\270\213\377\274\270\214\377\267\264\205\377\264\262\200\377\260\256" - "z\377\251\251s\377\243\244n\377\231\232g\377\220\222`\377\210\211Y\377" - "|}Q\377hlC\377PU3\377CK,\377DL/Y\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\205\204X\220\232\230h\377\261\260\204\377\266\264\212\377\261\260" - "\201\377\263\260\200\377\260\257}\377\256\256x\377\253\254t\377\244\246" - "o\377\233\236i\377\221\224b\377\211\214\\\377\202\204V\377txM\377]b>" - "\377HP0\377@H+\373CJ-\25\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0xxO>" - "\215\215_\377\237\237r\377\247\247x\377\247\247t\377\252\252w\377\252" - "\252u\377\252\253t\377\243\246o\377\235\240j\377\223\230c\377\213\217" - "]\377\201\206V\377x}P\377gkD\377RY5\377BI,\377AI,\262\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\202\205W\312\216\220`\377\230" - "\232g\377\234\236i\377\236\241l\377\241\244n\377\240\244m\377\232\237" - "i\377\223\230c\377\212\221]\377\200\210W\377v|P\377jnG\377Za>\377HP2" - "\377=D)\377HQ1:\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0wzQ6\177\201U\371\206\211Z\377\216\222`\377\220\225a\377\220\225b\377" - "\220\226a\377\213\221_\377\204\213Z\377{\203R\377ryN\377iqH\377^fA\377" - "R[;\377BJ-\3778@'\317\0\0\0>\0\0\0\36\0\0\0\7\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0ptJTw|Q\371z\177R\377}\202T\377|\203T\377z\200" - "R\377v|O\377pwL\377jpF\377dlB\377`hB\377Yb@\377LT6\377<C*\377\11\12\6" - "\376\0\0\0\347\0\0\0\262\0\0\0Y\0\0\0\32\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\\`=UgnE\370hnG\377gmE\377djB\377]d>\377[c<\377Y" - "b<\377Zc>\377V_>\377OW8\377BK/\377\16\20\12\377\0\0\0\377\0\0\0\377\0" - "\0\0\374\0\0\0\320\0\0\0I\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\1\0\0\0\40\22\24\15\260@D+\377W`;\377OV5\377.3\36\377.3\37\377IP0" - "\377RZ7\377PZ8\3776=&\377\14\15\10\377\0\0\0\377\0\0\0\377\0\0\0\377" - "\0\0\0\347\0\0\0\217\0\0\0""4\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\20\0\0\0P\0\0\0\252\7\10\5\346\7\7\5\375\0\0\0\377\0\0" - "\0\377\0\0\0\377\0\0\0\377\0\0\0\377\0\0\0\377\0\0\0\377\0\0\0\374\0" - "\0\0\336\0\0\0\254\0\0\0i\0\0\0""2\0\0\0\10\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\11\0\0\0\40\0\0\0D\0\0\0m\0\0\0" - "\226\0\0\0\234\0\0\0\234\0\0\0\244\0\0\0\246\0\0\0\232\0\0\0\202\0\0" - "\0i\0\0\0T\0\0\0,\0\0\0\15\0\0\0\2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\2\0\0\0\6\0\0\0" - "\16\0\0\0\22\0\0\0\24\0\0\0\23\0\0\0\17\0\0\0\14\0\0\0\13\0\0\0\10\0" - "\0\0\5\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"}; - - -static void -dump_accels (gpointer callback_data, - guint callback_action, - GtkWidget *widget) -{ - gtk_accel_map_save_fd (1 /* stdout */); -} - -static GtkItemFactoryEntry menu_items[] = -{ - { "/_File", NULL, NULL, 0, "<Branch>" }, - { "/File/tearoff1", NULL, gtk_ifactory_cb, 0, "<Tearoff>" }, - { "/File/_New", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_NEW }, - { "/File/_Open", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_OPEN }, - { "/File/_Save", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_SAVE }, - { "/File/Save _As...", "<control>A", gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_SAVE }, - { "/File/_Dump \"_Accels\"", NULL, dump_accels, 0 }, - { "/File/\\/Test__Escaping/And\\/\n\tWei\\\\rdly", - NULL, gtk_ifactory_cb, 0 }, - { "/File/sep1", NULL, gtk_ifactory_cb, 0, "<Separator>" }, - { "/File/_Quit", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_QUIT }, - - { "/_Preferences", NULL, 0, 0, "<Branch>" }, - { "/_Preferences/_Color", NULL, 0, 0, "<Branch>" }, - { "/_Preferences/Color/_Red", NULL, gtk_ifactory_cb, 0, "<RadioItem>" }, - { "/_Preferences/Color/_Green", NULL, gtk_ifactory_cb, 0, "/Preferences/Color/Red" }, - { "/_Preferences/Color/_Blue", NULL, gtk_ifactory_cb, 0, "/Preferences/Color/Red" }, - { "/_Preferences/_Shape", NULL, 0, 0, "<Branch>" }, - { "/_Preferences/Shape/_Square", NULL, gtk_ifactory_cb, 0, "<RadioItem>" }, - { "/_Preferences/Shape/_Rectangle", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Square" }, - { "/_Preferences/Shape/_Oval", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Rectangle" }, - { "/_Preferences/Shape/_Rectangle", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Square" }, - { "/_Preferences/Shape/_Oval", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Rectangle" }, - { "/_Preferences/Shape/_Image", NULL, gtk_ifactory_cb, 0, "<ImageItem>", apple }, - { "/_Preferences/Coffee", NULL, gtk_ifactory_cb, 0, "<CheckItem>" }, - { "/_Preferences/Toast", NULL, gtk_ifactory_cb, 0, "<CheckItem>" }, - { "/_Preferences/Marshmallow Froot Loops", NULL, gtk_ifactory_cb, 0, "<CheckItem>" }, - - /* For testing deletion of menus */ - { "/_Preferences/Should_NotAppear", NULL, 0, 0, "<Branch>" }, - { "/Preferences/ShouldNotAppear/SubItem1", NULL, gtk_ifactory_cb, 0 }, - { "/Preferences/ShouldNotAppear/SubItem2", NULL, gtk_ifactory_cb, 0 }, - - { "/_Help", NULL, 0, 0, "<LastBranch>" }, - { "/Help/_Help", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_HELP}, - { "/Help/_About", NULL, gtk_ifactory_cb, 0 }, -}; - - -static int nmenu_items = sizeof (menu_items) / sizeof (menu_items[0]); - -static void -create_item_factory (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *separator; - GtkWidget *label; - GtkWidget *button; - GtkAccelGroup *accel_group; - GtkItemFactory *item_factory; - GtkTooltips *tooltips; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK(gtk_widget_destroyed), - &window); - g_signal_connect (window, "delete-event", - G_CALLBACK (gtk_true), - NULL); - - accel_group = gtk_accel_group_new (); - item_factory = gtk_item_factory_new (GTK_TYPE_MENU_BAR, "<main>", accel_group); - g_object_set_data_full (G_OBJECT (window), - "<main>", - item_factory, - g_object_unref); - gtk_window_add_accel_group (GTK_WINDOW (window), accel_group); - gtk_window_set_title (GTK_WINDOW (window), "Item Factory"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - gtk_item_factory_create_items (item_factory, nmenu_items, menu_items, NULL); - - /* preselect /Preferences/Shape/Oval over the other radios - */ - gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (gtk_item_factory_get_item (item_factory, - "/Preferences/Shape/Oval")), - TRUE); - - /* preselect /Preferences/Coffee - */ - gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (gtk_item_factory_get_item (item_factory, - "/Preferences/Coffee")), - TRUE); - - /* preselect /Preferences/Marshmallow Froot Loops and set it insensitive - */ - gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (gtk_item_factory_get_item (item_factory, - "/Preferences/Marshmallow Froot Loops")), - TRUE); - gtk_widget_set_sensitive (GTK_WIDGET (gtk_item_factory_get_item (item_factory, - "/Preferences/Marshmallow Froot Loops")), - FALSE); - - /* Test how tooltips (ugh) work on menu items - */ - tooltips = gtk_tooltips_new (); - g_object_ref (tooltips); - gtk_object_sink (GTK_OBJECT (tooltips)); - g_object_set_data_full (G_OBJECT (window), "testgtk-tooltips", - tooltips, (GDestroyNotify)g_object_unref); - - gtk_tooltips_set_tip (tooltips, gtk_item_factory_get_item (item_factory, "/File/New"), - "Create a new file", NULL); - gtk_tooltips_set_tip (tooltips, gtk_item_factory_get_item (item_factory, "/File/Open"), - "Open a file", NULL); - gtk_tooltips_set_tip (tooltips, gtk_item_factory_get_item (item_factory, "/File/Save"), - "Safe file", NULL); - gtk_tooltips_set_tip (tooltips, gtk_item_factory_get_item (item_factory, "/Preferences/Color"), - "Modify color", NULL); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - gtk_box_pack_start (GTK_BOX (box1), - gtk_item_factory_get_widget (item_factory, "<main>"), - FALSE, FALSE, 0); - - label = gtk_label_new ("Type\n<alt>\nto start"); - gtk_widget_set_size_request (label, 200, 200); - gtk_misc_set_alignment (GTK_MISC (label), 0.5, 0.5); - gtk_box_pack_start (GTK_BOX (box1), label, TRUE, TRUE, 0); - - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - - gtk_item_factory_delete_item (item_factory, "/Preferences/ShouldNotAppear"); - - gtk_widget_show_all (window); - } - else - gtk_widget_destroy (window); -} - -static GtkWidget * -accel_button_new (GtkAccelGroup *accel_group, - const gchar *text, - const gchar *accel) -{ - guint keyval; - GdkModifierType modifiers; - GtkWidget *button; - GtkWidget *label; - - gtk_accelerator_parse (accel, &keyval, &modifiers); - g_assert (keyval); - - button = gtk_button_new (); - gtk_widget_add_accelerator (button, "activate", accel_group, - keyval, modifiers, GTK_ACCEL_VISIBLE | GTK_ACCEL_LOCKED); - - label = gtk_accel_label_new (text); - gtk_accel_label_set_accel_widget (GTK_ACCEL_LABEL (label), button); - gtk_widget_show (label); - - gtk_container_add (GTK_CONTAINER (button), label); - - return button; -} - -static void -create_key_lookup (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkAccelGroup *accel_group = gtk_accel_group_new (); - GtkWidget *button; - - window = gtk_dialog_new_with_buttons ("Key Lookup", NULL, 0, - GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - /* We have to expand it so the accel labels will draw their labels - */ - gtk_window_set_default_size (GTK_WINDOW (window), 300, -1); - - gtk_window_add_accel_group (GTK_WINDOW (window), accel_group); - - button = gtk_button_new_with_mnemonic ("Button 1 (_a)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 2 (_A)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 3 (_\321\204)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 4 (_\320\244)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 6 (_b)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 7", "<Alt><Shift>b"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 8", "<Alt>d"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 9", "<Alt>Cyrillic_ve"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 10 (_1)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = gtk_button_new_with_mnemonic ("Button 11 (_!)"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 12", "<Super>a"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 13", "<Hyper>a"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 14", "<Meta>a"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - button = accel_button_new (accel_group, "Button 15", "<Shift><Mod4>b"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), button, FALSE, FALSE, 0); - - g_object_add_weak_pointer (G_OBJECT (window), (gpointer) &window); - g_signal_connect (window, "response", G_CALLBACK (gtk_object_destroy), NULL); - - gtk_widget_show_all (window); - } - else - gtk_widget_destroy (window); -} - - -/* - create_modal_window - */ - -static gboolean -cmw_destroy_cb(GtkWidget *widget) -{ - /* This is needed to get out of gtk_main */ - gtk_main_quit (); - - return FALSE; -} - -static void -cmw_color (GtkWidget *widget, GtkWidget *parent) -{ - GtkWidget *csd; - - csd = gtk_color_selection_dialog_new ("This is a modal color selection dialog"); - - gtk_window_set_screen (GTK_WINDOW (csd), gtk_widget_get_screen (parent)); - - gtk_color_selection_set_has_palette (GTK_COLOR_SELECTION (GTK_COLOR_SELECTION_DIALOG (csd)->colorsel), - TRUE); - - /* Set as modal */ - gtk_window_set_modal (GTK_WINDOW(csd),TRUE); - - /* And mark it as a transient dialog */ - gtk_window_set_transient_for (GTK_WINDOW (csd), GTK_WINDOW (parent)); - - g_signal_connect (csd, "destroy", - G_CALLBACK (cmw_destroy_cb), NULL); - - g_signal_connect_swapped (GTK_COLOR_SELECTION_DIALOG (csd)->ok_button, - "clicked", G_CALLBACK (gtk_widget_destroy), csd); - g_signal_connect_swapped (GTK_COLOR_SELECTION_DIALOG (csd)->cancel_button, - "clicked", G_CALLBACK (gtk_widget_destroy), csd); - - /* wait until destroy calls gtk_main_quit */ - gtk_widget_show (csd); - gtk_main (); -} - -static void -cmw_file (GtkWidget *widget, GtkWidget *parent) -{ - GtkWidget *fs; - - fs = gtk_file_selection_new("This is a modal file selection dialog"); - - gtk_window_set_screen (GTK_WINDOW (fs), gtk_widget_get_screen (parent)); - - /* Set as modal */ - gtk_window_set_modal (GTK_WINDOW(fs),TRUE); - - /* And mark it as a transient dialog */ - gtk_window_set_transient_for (GTK_WINDOW (fs), GTK_WINDOW (parent)); - - g_signal_connect (fs, "destroy", - G_CALLBACK (cmw_destroy_cb), NULL); - - g_signal_connect_swapped (GTK_FILE_SELECTION (fs)->ok_button, - "clicked", G_CALLBACK (gtk_widget_destroy), fs); - g_signal_connect_swapped (GTK_FILE_SELECTION (fs)->cancel_button, - "clicked", G_CALLBACK (gtk_widget_destroy), fs); - - /* wait until destroy calls gtk_main_quit */ - gtk_widget_show (fs); - - gtk_main(); -} - - -static void -create_modal_window (GtkWidget *widget) -{ - GtkWidget *window = NULL; - GtkWidget *box1,*box2; - GtkWidget *frame1; - GtkWidget *btnColor,*btnFile,*btnClose; - - /* Create modal window (Here you can use any window descendent )*/ - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_title (GTK_WINDOW(window),"This window is modal"); - - /* Set window as modal */ - gtk_window_set_modal (GTK_WINDOW(window),TRUE); - - /* Create widgets */ - box1 = gtk_vbox_new (FALSE,5); - frame1 = gtk_frame_new ("Standard dialogs in modal form"); - box2 = gtk_vbox_new (TRUE,5); - btnColor = gtk_button_new_with_label ("Color"); - btnFile = gtk_button_new_with_label ("File Selection"); - btnClose = gtk_button_new_with_label ("Close"); - - /* Init widgets */ - gtk_container_set_border_width (GTK_CONTAINER (box1), 3); - gtk_container_set_border_width (GTK_CONTAINER (box2), 3); - - /* Pack widgets */ - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_box_pack_start (GTK_BOX (box1), frame1, TRUE, TRUE, 4); - gtk_container_add (GTK_CONTAINER (frame1), box2); - gtk_box_pack_start (GTK_BOX (box2), btnColor, FALSE, FALSE, 4); - gtk_box_pack_start (GTK_BOX (box2), btnFile, FALSE, FALSE, 4); - gtk_box_pack_start (GTK_BOX (box1), gtk_hseparator_new (), FALSE, FALSE, 4); - gtk_box_pack_start (GTK_BOX (box1), btnClose, FALSE, FALSE, 4); - - /* connect signals */ - g_signal_connect_swapped (btnClose, "clicked", - G_CALLBACK (gtk_widget_destroy), window); - - g_signal_connect (window, "destroy", - G_CALLBACK (cmw_destroy_cb), NULL); - - g_signal_connect (btnColor, "clicked", - G_CALLBACK (cmw_color), window); - g_signal_connect (btnFile, "clicked", - G_CALLBACK (cmw_file), window); - - /* Show widgets */ - gtk_widget_show_all (window); - - /* wait until dialog get destroyed */ - gtk_main(); -} - -/* - * GtkMessageDialog - */ - -static void -make_message_dialog (GdkScreen *screen, - GtkWidget **dialog, - GtkMessageType type, - GtkButtonsType buttons, - guint default_response) -{ - if (*dialog) - { - gtk_widget_destroy (*dialog); - - return; - } - - *dialog = gtk_message_dialog_new (NULL, 0, type, buttons, - "This is a message dialog; it can wrap long lines. This is a long line. La la la. Look this line is wrapped. Blah blah blah blah blah blah. (Note: testgtk has a nonstandard gtkrc that changes some of the message dialog icons.)"); - - gtk_window_set_screen (GTK_WINDOW (*dialog), screen); - - g_signal_connect_swapped (*dialog, - "response", - G_CALLBACK (gtk_widget_destroy), - *dialog); - - g_signal_connect (*dialog, - "destroy", - G_CALLBACK (gtk_widget_destroyed), - dialog); - - gtk_dialog_set_default_response (GTK_DIALOG (*dialog), default_response); - - gtk_widget_show (*dialog); -} - -static void -create_message_dialog (GtkWidget *widget) -{ - static GtkWidget *info = NULL; - static GtkWidget *warning = NULL; - static GtkWidget *error = NULL; - static GtkWidget *question = NULL; - GdkScreen *screen = gtk_widget_get_screen (widget); - - make_message_dialog (screen, &info, GTK_MESSAGE_INFO, GTK_BUTTONS_OK, GTK_RESPONSE_OK); - make_message_dialog (screen, &warning, GTK_MESSAGE_WARNING, GTK_BUTTONS_CLOSE, GTK_RESPONSE_CLOSE); - make_message_dialog (screen, &error, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK_CANCEL, GTK_RESPONSE_OK); - make_message_dialog (screen, &question, GTK_MESSAGE_QUESTION, GTK_BUTTONS_YES_NO, GTK_RESPONSE_NO); -} - -/* - * GtkScrolledWindow - */ - -static GtkWidget *sw_parent = NULL; -static GtkWidget *sw_float_parent; -static guint sw_destroyed_handler = 0; - -static gboolean -scrolled_windows_delete_cb (GtkWidget *widget, GdkEventAny *event, GtkWidget *scrollwin) -{ - gtk_widget_reparent (scrollwin, sw_parent); - - g_signal_handler_disconnect (sw_parent, sw_destroyed_handler); - sw_float_parent = NULL; - sw_parent = NULL; - sw_destroyed_handler = 0; - - return FALSE; -} - -static void -scrolled_windows_destroy_cb (GtkWidget *widget, GtkWidget *scrollwin) -{ - gtk_widget_destroy (sw_float_parent); - - sw_float_parent = NULL; - sw_parent = NULL; - sw_destroyed_handler = 0; -} - -static void -scrolled_windows_remove (GtkWidget *widget, GtkWidget *scrollwin) -{ - if (sw_parent) - { - gtk_widget_reparent (scrollwin, sw_parent); - gtk_widget_destroy (sw_float_parent); - - g_signal_handler_disconnect (sw_parent, sw_destroyed_handler); - sw_float_parent = NULL; - sw_parent = NULL; - sw_destroyed_handler = 0; - } - else - { - sw_parent = scrollwin->parent; - sw_float_parent = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (sw_float_parent), - gtk_widget_get_screen (widget)); - - gtk_window_set_default_size (GTK_WINDOW (sw_float_parent), 200, 200); - - gtk_widget_reparent (scrollwin, sw_float_parent); - gtk_widget_show (sw_float_parent); - - sw_destroyed_handler = - g_signal_connect (sw_parent, "destroy", - G_CALLBACK (scrolled_windows_destroy_cb), scrollwin); - g_signal_connect (sw_float_parent, "delete_event", - G_CALLBACK (scrolled_windows_delete_cb), scrollwin); - } -} - -static void -create_scrolled_windows (GtkWidget *widget) -{ - static GtkWidget *window; - GtkWidget *scrolled_window; - GtkWidget *table; - GtkWidget *button; - char buffer[32]; - int i, j; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "dialog"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - - scrolled_window = gtk_scrolled_window_new (NULL, NULL); - gtk_container_set_border_width (GTK_CONTAINER (scrolled_window), 10); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - scrolled_window, TRUE, TRUE, 0); - gtk_widget_show (scrolled_window); - - table = gtk_table_new (20, 20, FALSE); - gtk_table_set_row_spacings (GTK_TABLE (table), 10); - gtk_table_set_col_spacings (GTK_TABLE (table), 10); - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_window), table); - gtk_container_set_focus_hadjustment (GTK_CONTAINER (table), - gtk_scrolled_window_get_hadjustment (GTK_SCROLLED_WINDOW (scrolled_window))); - gtk_container_set_focus_vadjustment (GTK_CONTAINER (table), - gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (scrolled_window))); - gtk_widget_show (table); - - for (i = 0; i < 20; i++) - for (j = 0; j < 20; j++) - { - sprintf (buffer, "button (%d,%d)\n", i, j); - button = gtk_toggle_button_new_with_label (buffer); - gtk_table_attach_defaults (GTK_TABLE (table), button, - i, i+1, j, j+1); - gtk_widget_show (button); - } - - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("Reparent Out"); - g_signal_connect (button, "clicked", - G_CALLBACK (scrolled_windows_remove), - scrolled_window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - - gtk_window_set_default_size (GTK_WINDOW (window), 300, 300); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkEntry - */ - -static void -entry_toggle_frame (GtkWidget *checkbutton, - GtkWidget *entry) -{ - gtk_entry_set_has_frame (GTK_ENTRY(entry), - GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -static void -entry_toggle_sensitive (GtkWidget *checkbutton, - GtkWidget *entry) -{ - gtk_widget_set_sensitive (entry, GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -static void -entry_props_clicked (GtkWidget *button, - GObject *entry) -{ - GtkWidget *window = create_prop_editor (entry, 0); - - gtk_window_set_title (GTK_WINDOW (window), "Entry Properties"); -} - -static void -create_entry (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *hbox; - GtkWidget *has_frame_check; - GtkWidget *sensitive_check; - GtkWidget *entry, *cb; - GtkWidget *button; - GtkWidget *separator; - GList *cbitems = NULL; - - if (!window) - { - cbitems = g_list_append(cbitems, "item0"); - cbitems = g_list_append(cbitems, "item1 item1"); - cbitems = g_list_append(cbitems, "item2 item2 item2"); - cbitems = g_list_append(cbitems, "item3 item3 item3 item3"); - cbitems = g_list_append(cbitems, "item4 item4 item4 item4 item4"); - cbitems = g_list_append(cbitems, "item5 item5 item5 item5 item5 item5"); - cbitems = g_list_append(cbitems, "item6 item6 item6 item6 item6"); - cbitems = g_list_append(cbitems, "item7 item7 item7 item7"); - cbitems = g_list_append(cbitems, "item8 item8 item8"); - cbitems = g_list_append(cbitems, "item9 item9"); - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "entry"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (box2), hbox, TRUE, TRUE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), "hello world \330\247\331\204\330\263\331\204\330\247\331\205 \330\271\331\204\331\212\331\203\331\205"); - gtk_editable_select_region (GTK_EDITABLE (entry), 0, 5); - gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0); - - button = gtk_button_new_with_mnemonic ("_Props"); - gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, FALSE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (entry_props_clicked), - entry); - - cb = gtk_combo_new (); - gtk_combo_set_popdown_strings (GTK_COMBO (cb), cbitems); - gtk_entry_set_text (GTK_ENTRY (GTK_COMBO(cb)->entry), "hello world \n\n\n foo"); - gtk_editable_select_region (GTK_EDITABLE (GTK_COMBO(cb)->entry), - 0, -1); - gtk_box_pack_start (GTK_BOX (box2), cb, TRUE, TRUE, 0); - - sensitive_check = gtk_check_button_new_with_label("Sensitive"); - gtk_box_pack_start (GTK_BOX (box2), sensitive_check, FALSE, TRUE, 0); - g_signal_connect (sensitive_check, "toggled", - G_CALLBACK (entry_toggle_sensitive), entry); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sensitive_check), TRUE); - - has_frame_check = gtk_check_button_new_with_label("Has Frame"); - gtk_box_pack_start (GTK_BOX (box2), has_frame_check, FALSE, TRUE, 0); - g_signal_connect (has_frame_check, "toggled", - G_CALLBACK (entry_toggle_frame), entry); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (has_frame_check), TRUE); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -static void -create_expander (GtkWidget *widget) -{ - GtkWidget *box1; - GtkWidget *expander; - GtkWidget *hidden; - static GtkWidget *window = NULL; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "expander"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - expander = gtk_expander_new ("The Hidden"); - - gtk_box_pack_start (GTK_BOX (box1), expander, TRUE, TRUE, 0); - - hidden = gtk_label_new ("Revealed!"); - - gtk_container_add (GTK_CONTAINER (expander), hidden); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - - -/* GtkEventBox */ - - -static void -event_box_label_pressed (GtkWidget *widget, - GdkEventButton *event, - gpointer user_data) -{ - g_print ("clicked on event box\n"); -} - -static void -event_box_button_clicked (GtkWidget *widget, - GtkWidget *button, - gpointer user_data) -{ - g_print ("pushed button\n"); -} - -static void -event_box_toggle_visible_window (GtkWidget *checkbutton, - GtkEventBox *event_box) -{ - gtk_event_box_set_visible_window (event_box, - GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -static void -event_box_toggle_above_child (GtkWidget *checkbutton, - GtkEventBox *event_box) -{ - gtk_event_box_set_above_child (event_box, - GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -static void -create_event_box (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *hbox; - GtkWidget *vbox; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *event_box; - GtkWidget *label; - GtkWidget *visible_window_check; - GtkWidget *above_child_check; - GdkColor color; - - if (!window) - { - color.red = 0; - color.blue = 65535; - color.green = 0; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "event box"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_widget_modify_bg (window, GTK_STATE_NORMAL, &color); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (box1), hbox, TRUE, FALSE, 0); - - event_box = gtk_event_box_new (); - gtk_box_pack_start (GTK_BOX (hbox), event_box, TRUE, FALSE, 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (event_box), vbox); - g_signal_connect (event_box, "button_press_event", - G_CALLBACK (event_box_label_pressed), - NULL); - - label = gtk_label_new ("Click on this label"); - gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, FALSE, 0); - - button = gtk_button_new_with_label ("button in eventbox"); - gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, FALSE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (event_box_button_clicked), - NULL); - - - visible_window_check = gtk_check_button_new_with_label("Visible Window"); - gtk_box_pack_start (GTK_BOX (box1), visible_window_check, FALSE, TRUE, 0); - g_signal_connect (visible_window_check, "toggled", - G_CALLBACK (event_box_toggle_visible_window), event_box); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (visible_window_check), FALSE); - - above_child_check = gtk_check_button_new_with_label("Above Child"); - gtk_box_pack_start (GTK_BOX (box1), above_child_check, FALSE, TRUE, 0); - g_signal_connect (above_child_check, "toggled", - G_CALLBACK (event_box_toggle_above_child), event_box); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (above_child_check), FALSE); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - - -/* - * GtkSizeGroup - */ - -#define SIZE_GROUP_INITIAL_SIZE 50 - -static void -size_group_hsize_changed (GtkSpinButton *spin_button, - GtkWidget *button) -{ - gtk_widget_set_size_request (GTK_BIN (button)->child, - gtk_spin_button_get_value_as_int (spin_button), - -1); -} - -static void -size_group_vsize_changed (GtkSpinButton *spin_button, - GtkWidget *button) -{ - gtk_widget_set_size_request (GTK_BIN (button)->child, - -1, - gtk_spin_button_get_value_as_int (spin_button)); -} - -static GtkWidget * -create_size_group_window (GdkScreen *screen, - GtkSizeGroup *master_size_group) -{ - GtkWidget *window; - GtkWidget *table; - GtkWidget *main_button; - GtkWidget *button; - GtkWidget *spin_button; - GtkWidget *hbox; - GtkSizeGroup *hgroup1; - GtkSizeGroup *hgroup2; - GtkSizeGroup *vgroup1; - GtkSizeGroup *vgroup2; - - window = gtk_dialog_new_with_buttons ("GtkSizeGroup", - NULL, 0, - GTK_STOCK_CLOSE, - GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), screen); - - gtk_window_set_resizable (GTK_WINDOW (window), TRUE); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - - table = gtk_table_new (2, 2, FALSE); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), table, TRUE, TRUE, 0); - - gtk_table_set_row_spacings (GTK_TABLE (table), 5); - gtk_table_set_col_spacings (GTK_TABLE (table), 5); - gtk_container_set_border_width (GTK_CONTAINER (table), 5); - gtk_widget_set_size_request (table, 250, 250); - - hgroup1 = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL); - hgroup2 = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL); - vgroup1 = gtk_size_group_new (GTK_SIZE_GROUP_VERTICAL); - vgroup2 = gtk_size_group_new (GTK_SIZE_GROUP_VERTICAL); - - main_button = gtk_button_new_with_label ("X"); - - gtk_table_attach (GTK_TABLE (table), main_button, - 0, 1, 0, 1, - GTK_EXPAND, GTK_EXPAND, - 0, 0); - gtk_size_group_add_widget (master_size_group, main_button); - gtk_size_group_add_widget (hgroup1, main_button); - gtk_size_group_add_widget (vgroup1, main_button); - gtk_widget_set_size_request (GTK_BIN (main_button)->child, - SIZE_GROUP_INITIAL_SIZE, - SIZE_GROUP_INITIAL_SIZE); - - button = gtk_button_new (); - gtk_table_attach (GTK_TABLE (table), button, - 1, 2, 0, 1, - GTK_EXPAND, GTK_EXPAND, - 0, 0); - gtk_size_group_add_widget (vgroup1, button); - gtk_size_group_add_widget (vgroup2, button); - - button = gtk_button_new (); - gtk_table_attach (GTK_TABLE (table), button, - 0, 1, 1, 2, - GTK_EXPAND, GTK_EXPAND, - 0, 0); - gtk_size_group_add_widget (hgroup1, button); - gtk_size_group_add_widget (hgroup2, button); - - button = gtk_button_new (); - gtk_table_attach (GTK_TABLE (table), button, - 1, 2, 1, 2, - GTK_EXPAND, GTK_EXPAND, - 0, 0); - gtk_size_group_add_widget (hgroup2, button); - gtk_size_group_add_widget (vgroup2, button); - - g_object_unref (hgroup1); - g_object_unref (hgroup2); - g_object_unref (vgroup1); - g_object_unref (vgroup2); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), hbox, FALSE, FALSE, 0); - - spin_button = gtk_spin_button_new_with_range (1, 100, 1); - gtk_spin_button_set_value (GTK_SPIN_BUTTON (spin_button), SIZE_GROUP_INITIAL_SIZE); - gtk_box_pack_start (GTK_BOX (hbox), spin_button, TRUE, TRUE, 0); - g_signal_connect (spin_button, "value_changed", - G_CALLBACK (size_group_hsize_changed), main_button); - - spin_button = gtk_spin_button_new_with_range (1, 100, 1); - gtk_spin_button_set_value (GTK_SPIN_BUTTON (spin_button), SIZE_GROUP_INITIAL_SIZE); - gtk_box_pack_start (GTK_BOX (hbox), spin_button, TRUE, TRUE, 0); - g_signal_connect (spin_button, "value_changed", - G_CALLBACK (size_group_vsize_changed), main_button); - - return window; -} - -static void -create_size_groups (GtkWidget *widget) -{ - static GtkWidget *window1 = NULL; - static GtkWidget *window2 = NULL; - static GtkSizeGroup *master_size_group; - - if (!master_size_group) - master_size_group = gtk_size_group_new (GTK_SIZE_GROUP_BOTH); - - if (!window1) - { - window1 = create_size_group_window (gtk_widget_get_screen (widget), - master_size_group); - - g_signal_connect (window1, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window1); - } - - if (!window2) - { - window2 = create_size_group_window (gtk_widget_get_screen (widget), - master_size_group); - - g_signal_connect (window2, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window2); - } - - if (GTK_WIDGET_VISIBLE (window1) && GTK_WIDGET_VISIBLE (window2)) - { - gtk_widget_destroy (window1); - gtk_widget_destroy (window2); - } - else - { - if (!GTK_WIDGET_VISIBLE (window1)) - gtk_widget_show_all (window1); - if (!GTK_WIDGET_VISIBLE (window2)) - gtk_widget_show_all (window2); - } -} - -/* - * GtkSpinButton - */ - -static GtkWidget *spinner1; - -static void -toggle_snap (GtkWidget *widget, GtkSpinButton *spin) -{ - gtk_spin_button_set_snap_to_ticks (spin, GTK_TOGGLE_BUTTON (widget)->active); -} - -static void -toggle_numeric (GtkWidget *widget, GtkSpinButton *spin) -{ - gtk_spin_button_set_numeric (spin, GTK_TOGGLE_BUTTON (widget)->active); -} - -static void -change_digits (GtkWidget *widget, GtkSpinButton *spin) -{ - gtk_spin_button_set_digits (GTK_SPIN_BUTTON (spinner1), - gtk_spin_button_get_value_as_int (spin)); -} - -static void -get_value (GtkWidget *widget, gpointer data) -{ - gchar buf[32]; - GtkLabel *label; - GtkSpinButton *spin; - - spin = GTK_SPIN_BUTTON (spinner1); - label = GTK_LABEL (g_object_get_data (G_OBJECT (widget), "user_data")); - if (GPOINTER_TO_INT (data) == 1) - sprintf (buf, "%d", gtk_spin_button_get_value_as_int (spin)); - else - sprintf (buf, "%0.*f", spin->digits, gtk_spin_button_get_value (spin)); - gtk_label_set_text (label, buf); -} - -static void -get_spin_value (GtkWidget *widget, gpointer data) -{ - gchar *buffer; - GtkLabel *label; - GtkSpinButton *spin; - - spin = GTK_SPIN_BUTTON (widget); - label = GTK_LABEL (data); - - buffer = g_strdup_printf ("%0.*f", spin->digits, - gtk_spin_button_get_value (spin)); - gtk_label_set_text (label, buffer); - - g_free (buffer); -} - -static gint -spin_button_time_output_func (GtkSpinButton *spin_button) -{ - static gchar buf[6]; - gdouble hours; - gdouble minutes; - - hours = spin_button->adjustment->value / 60.0; - minutes = (fabs(floor (hours) - hours) < 1e-5) ? 0.0 : 30; - sprintf (buf, "%02.0f:%02.0f", floor (hours), minutes); - if (strcmp (buf, gtk_entry_get_text (GTK_ENTRY (spin_button)))) - gtk_entry_set_text (GTK_ENTRY (spin_button), buf); - return TRUE; -} - -static gint -spin_button_month_input_func (GtkSpinButton *spin_button, - gdouble *new_val) -{ - gint i; - static gchar *month[12] = { "January", "February", "March", "April", - "May", "June", "July", "August", - "September", "October", "November", "December" }; - gchar *tmp1, *tmp2; - gboolean found = FALSE; - - for (i = 1; i <= 12; i++) - { - tmp1 = g_ascii_strup (month[i - 1], -1); - tmp2 = g_ascii_strup (gtk_entry_get_text (GTK_ENTRY (spin_button)), -1); - if (strstr (tmp1, tmp2) == tmp1) - found = TRUE; - g_free (tmp1); - g_free (tmp2); - if (found) - break; - } - if (!found) - { - *new_val = 0.0; - return GTK_INPUT_ERROR; - } - *new_val = (gdouble) i; - return TRUE; -} - -static gint -spin_button_month_output_func (GtkSpinButton *spin_button) -{ - gint i; - static gchar *month[12] = { "January", "February", "March", "April", - "May", "June", "July", "August", "September", - "October", "November", "December" }; - - for (i = 1; i <= 12; i++) - if (fabs (spin_button->adjustment->value - (double)i) < 1e-5) - { - if (strcmp (month[i-1], gtk_entry_get_text (GTK_ENTRY (spin_button)))) - gtk_entry_set_text (GTK_ENTRY (spin_button), month[i-1]); - } - return TRUE; -} - -static gint -spin_button_hex_input_func (GtkSpinButton *spin_button, - gdouble *new_val) -{ - const gchar *buf; - gchar *err; - gdouble res; - - buf = gtk_entry_get_text (GTK_ENTRY (spin_button)); - res = strtol(buf, &err, 16); - *new_val = res; - if (*err) - return GTK_INPUT_ERROR; - else - return TRUE; -} - -static gint -spin_button_hex_output_func (GtkSpinButton *spin_button) -{ - static gchar buf[7]; - gint val; - - val = (gint) spin_button->adjustment->value; - if (fabs (val) < 1e-5) - sprintf (buf, "0x00"); - else - sprintf (buf, "0x%.2X", val); - if (strcmp (buf, gtk_entry_get_text (GTK_ENTRY (spin_button)))) - gtk_entry_set_text (GTK_ENTRY (spin_button), buf); - return TRUE; -} - -static void -create_spins (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *frame; - GtkWidget *hbox; - GtkWidget *main_vbox; - GtkWidget *vbox; - GtkWidget *vbox2; - GtkWidget *spinner2; - GtkWidget *spinner; - GtkWidget *button; - GtkWidget *label; - GtkWidget *val_label; - GtkAdjustment *adj; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkSpinButton"); - - main_vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 10); - gtk_container_add (GTK_CONTAINER (window), main_vbox); - - frame = gtk_frame_new ("Not accelerated"); - gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 5); - gtk_container_add (GTK_CONTAINER (frame), vbox); - - /* Time, month, hex spinners */ - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 5); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5); - - label = gtk_label_new ("Time :"); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (0, 0, 1410, 30, 60, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_editable_set_editable (GTK_EDITABLE (spinner), FALSE); - g_signal_connect (spinner, - "output", - G_CALLBACK (spin_button_time_output_func), - NULL); - gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE); - gtk_entry_set_width_chars (GTK_ENTRY (spinner), 5); - gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5); - - label = gtk_label_new ("Month :"); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (1.0, 1.0, 12.0, 1.0, - 5.0, 0.0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_spin_button_set_update_policy (GTK_SPIN_BUTTON (spinner), - GTK_UPDATE_IF_VALID); - g_signal_connect (spinner, - "input", - G_CALLBACK (spin_button_month_input_func), - NULL); - g_signal_connect (spinner, - "output", - G_CALLBACK (spin_button_month_output_func), - NULL); - gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE); - gtk_entry_set_width_chars (GTK_ENTRY (spinner), 9); - gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5); - - label = gtk_label_new ("Hex :"); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (0, 0, 255, 1, 16, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_editable_set_editable (GTK_EDITABLE (spinner), TRUE); - g_signal_connect (spinner, - "input", - G_CALLBACK (spin_button_hex_input_func), - NULL); - g_signal_connect (spinner, - "output", - G_CALLBACK (spin_button_hex_output_func), - NULL); - gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE); - gtk_entry_set_width_chars (GTK_ENTRY (spinner), 4); - gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0); - - frame = gtk_frame_new ("Accelerated"); - gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 5); - gtk_container_add (GTK_CONTAINER (frame), vbox); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 5); - - label = gtk_label_new ("Value :"); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (0.0, -10000.0, 10000.0, - 0.5, 100.0, 0.0); - spinner1 = gtk_spin_button_new (adj, 1.0, 2); - gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner1), TRUE); - gtk_box_pack_start (GTK_BOX (vbox2), spinner1, FALSE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 5); - - label = gtk_label_new ("Digits :"); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (2, 1, 15, 1, 1, 0); - spinner2 = gtk_spin_button_new (adj, 0.0, 0); - g_signal_connect (adj, "value_changed", - G_CALLBACK (change_digits), - spinner2); - gtk_box_pack_start (GTK_BOX (vbox2), spinner2, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 5); - - button = gtk_check_button_new_with_label ("Snap to 0.5-ticks"); - g_signal_connect (button, "clicked", - G_CALLBACK (toggle_snap), - spinner1); - gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, TRUE, 0); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - - button = gtk_check_button_new_with_label ("Numeric only input mode"); - g_signal_connect (button, "clicked", - G_CALLBACK (toggle_numeric), - spinner1); - gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, TRUE, 0); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - - val_label = gtk_label_new (""); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5); - - button = gtk_button_new_with_label ("Value as Int"); - g_object_set_data (G_OBJECT (button), "user_data", val_label); - g_signal_connect (button, "clicked", - G_CALLBACK (get_value), - GINT_TO_POINTER (1)); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - - button = gtk_button_new_with_label ("Value as Float"); - g_object_set_data (G_OBJECT (button), "user_data", val_label); - g_signal_connect (button, "clicked", - G_CALLBACK (get_value), - GINT_TO_POINTER (2)); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - - gtk_box_pack_start (GTK_BOX (vbox), val_label, TRUE, TRUE, 0); - gtk_label_set_text (GTK_LABEL (val_label), "0"); - - frame = gtk_frame_new ("Using Convenience Constructor"); - gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_container_add (GTK_CONTAINER (frame), hbox); - - val_label = gtk_label_new ("0.0"); - - spinner = gtk_spin_button_new_with_range (0.0, 10.0, 0.009); - gtk_spin_button_set_value (GTK_SPIN_BUTTON (spinner), 0.0); - g_signal_connect (spinner, "value_changed", - G_CALLBACK (get_spin_value), val_label); - gtk_box_pack_start (GTK_BOX (hbox), spinner, TRUE, TRUE, 5); - gtk_box_pack_start (GTK_BOX (hbox), val_label, TRUE, TRUE, 5); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - - -/* - * Cursors - */ - -static gint -cursor_expose_event (GtkWidget *widget, - GdkEvent *event, - gpointer user_data) -{ - GtkDrawingArea *darea; - GdkDrawable *drawable; - GdkGC *black_gc; - GdkGC *gray_gc; - GdkGC *white_gc; - guint max_width; - guint max_height; - - g_return_val_if_fail (widget != NULL, TRUE); - g_return_val_if_fail (GTK_IS_DRAWING_AREA (widget), TRUE); - - darea = GTK_DRAWING_AREA (widget); - drawable = widget->window; - white_gc = widget->style->white_gc; - gray_gc = widget->style->bg_gc[GTK_STATE_NORMAL]; - black_gc = widget->style->black_gc; - max_width = widget->allocation.width; - max_height = widget->allocation.height; - - gdk_draw_rectangle (drawable, white_gc, - TRUE, - 0, - 0, - max_width, - max_height / 2); - - gdk_draw_rectangle (drawable, black_gc, - TRUE, - 0, - max_height / 2, - max_width, - max_height / 2); - - gdk_draw_rectangle (drawable, gray_gc, - TRUE, - max_width / 3, - max_height / 3, - max_width / 3, - max_height / 3); - - return TRUE; -} - -static void -set_cursor (GtkWidget *spinner, - GtkWidget *widget) -{ - guint c; - GdkCursor *cursor; - GtkWidget *label; - GEnumClass *class; - GEnumValue *vals; - - c = CLAMP (gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spinner)), 0, 152); - c &= 0xfe; - - label = g_object_get_data (G_OBJECT (spinner), "user_data"); - - class = gtk_type_class (GDK_TYPE_CURSOR_TYPE); - vals = class->values; - - while (vals && vals->value != c) - vals++; - if (vals) - gtk_label_set_text (GTK_LABEL (label), vals->value_nick); - else - gtk_label_set_text (GTK_LABEL (label), "<unknown>"); - - cursor = gdk_cursor_new_for_display (gtk_widget_get_display (widget), c); - gdk_window_set_cursor (widget->window, cursor); - gdk_cursor_unref (cursor); -} - -static gint -cursor_event (GtkWidget *widget, - GdkEvent *event, - GtkSpinButton *spinner) -{ - if ((event->type == GDK_BUTTON_PRESS) && - ((event->button.button == 1) || - (event->button.button == 3))) - { - gtk_spin_button_spin (spinner, event->button.button == 1 ? - GTK_SPIN_STEP_FORWARD : GTK_SPIN_STEP_BACKWARD, 0); - return TRUE; - } - - return FALSE; -} - -#ifdef GDK_WINDOWING_X11 -#include "x11/gdkx.h" - -static void -change_cursor_theme (GtkWidget *widget, - gpointer data) -{ - const gchar *theme; - gint size; - GList *children; - - children = gtk_container_get_children (GTK_CONTAINER (data)); - - theme = gtk_entry_get_text (GTK_ENTRY (children->next->data)); - size = (gint) gtk_spin_button_get_value (GTK_SPIN_BUTTON (children->next->next->data)); - - g_list_free (children); - - gdk_x11_display_set_cursor_theme (gtk_widget_get_display (widget), - theme, size); -} -#endif - - -static void -create_cursors (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *frame; - GtkWidget *hbox; - GtkWidget *main_vbox; - GtkWidget *vbox; - GtkWidget *darea; - GtkWidget *spinner; - GtkWidget *button; - GtkWidget *label; - GtkWidget *any; - GtkAdjustment *adj; - GtkWidget *entry; - GtkWidget *size; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Cursors"); - - main_vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 0); - gtk_container_add (GTK_CONTAINER (window), main_vbox); - - vbox = - gtk_widget_new (gtk_vbox_get_type (), - "GtkBox::homogeneous", FALSE, - "GtkBox::spacing", 5, - "GtkContainer::border_width", 10, - "GtkWidget::parent", main_vbox, - "GtkWidget::visible", TRUE, - NULL); - -#ifdef GDK_WINDOWING_X11 - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - label = gtk_label_new ("Cursor Theme : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), "default"); - gtk_box_pack_start (GTK_BOX (hbox), entry, FALSE, TRUE, 0); - - size = gtk_spin_button_new_with_range (1.0, 64.0, 1.0); - gtk_spin_button_set_value (GTK_SPIN_BUTTON (size), 24.0); - gtk_box_pack_start (GTK_BOX (hbox), size, TRUE, TRUE, 0); - - g_signal_connect (entry, "changed", - G_CALLBACK (change_cursor_theme), hbox); - g_signal_connect (size, "changed", - G_CALLBACK (change_cursor_theme), hbox); -#endif - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - label = gtk_label_new ("Cursor Value : "); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (0, - 0, 152, - 2, - 10, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (hbox), spinner, TRUE, TRUE, 0); - - frame = - gtk_widget_new (gtk_frame_get_type (), - "GtkFrame::shadow", GTK_SHADOW_ETCHED_IN, - "GtkFrame::label_xalign", 0.5, - "GtkFrame::label", "Cursor Area", - "GtkContainer::border_width", 10, - "GtkWidget::parent", vbox, - "GtkWidget::visible", TRUE, - NULL); - - darea = gtk_drawing_area_new (); - gtk_widget_set_size_request (darea, 80, 80); - gtk_container_add (GTK_CONTAINER (frame), darea); - g_signal_connect (darea, - "expose_event", - G_CALLBACK (cursor_expose_event), - NULL); - gtk_widget_set_events (darea, GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK); - g_signal_connect (darea, - "button_press_event", - G_CALLBACK (cursor_event), - spinner); - gtk_widget_show (darea); - - g_signal_connect (spinner, "changed", - G_CALLBACK (set_cursor), - darea); - - label = gtk_widget_new (GTK_TYPE_LABEL, - "visible", TRUE, - "label", "XXX", - "parent", vbox, - NULL); - gtk_container_child_set (GTK_CONTAINER (vbox), label, - "expand", FALSE, - NULL); - g_object_set_data (G_OBJECT (spinner), "user_data", label); - - any = - gtk_widget_new (gtk_hseparator_get_type (), - "GtkWidget::visible", TRUE, - NULL); - gtk_box_pack_start (GTK_BOX (main_vbox), any, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 10); - gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - - gtk_widget_show_all (window); - - set_cursor (spinner, darea); - } - else - gtk_widget_destroy (window); -} - -/* - * GtkList - */ - -static void -list_add (GtkWidget *widget, - GtkWidget *list) -{ - static int i = 1; - gchar buffer[64]; - GtkWidget *list_item; - GtkContainer *container; - - container = GTK_CONTAINER (list); - - sprintf (buffer, "added item %d", i++); - list_item = gtk_list_item_new_with_label (buffer); - gtk_widget_show (list_item); - - gtk_container_add (container, list_item); -} - -static void -list_remove (GtkWidget *widget, - GtkList *list) -{ - GList *clear_list = NULL; - GList *sel_row = NULL; - GList *work = NULL; - - if (list->selection_mode == GTK_SELECTION_EXTENDED) - { - GtkWidget *item; - - item = GTK_CONTAINER (list)->focus_child; - if (!item && list->selection) - item = list->selection->data; - - if (item) - { - work = g_list_find (list->children, item); - for (sel_row = work; sel_row; sel_row = sel_row->next) - if (GTK_WIDGET (sel_row->data)->state != GTK_STATE_SELECTED) - break; - - if (!sel_row) - { - for (sel_row = work; sel_row; sel_row = sel_row->prev) - if (GTK_WIDGET (sel_row->data)->state != GTK_STATE_SELECTED) - break; - } - } - } - - for (work = list->selection; work; work = work->next) - clear_list = g_list_prepend (clear_list, work->data); - - clear_list = g_list_reverse (clear_list); - gtk_list_remove_items (GTK_LIST (list), clear_list); - g_list_free (clear_list); - - if (list->selection_mode == GTK_SELECTION_EXTENDED && sel_row) - gtk_list_select_child (list, GTK_WIDGET(sel_row->data)); -} - -static void -list_clear (GtkWidget *widget, - GtkWidget *list) -{ - gtk_list_clear_items (GTK_LIST (list), 0, -1); -} - -static gchar *selection_mode_items[] = -{ - "Single", - "Browse", - "Multiple" -}; - -static const GtkSelectionMode selection_modes[] = { - GTK_SELECTION_SINGLE, - GTK_SELECTION_BROWSE, - GTK_SELECTION_MULTIPLE -}; - -static GtkWidget *list_omenu; - -static void -list_toggle_sel_mode (GtkWidget *widget, gpointer data) -{ - GtkList *list; - gint i; - - list = GTK_LIST (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_list_set_selection_mode (list, selection_modes[i]); -} - -static void -create_list (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *cbox; - GtkWidget *vbox; - GtkWidget *hbox; - GtkWidget *label; - GtkWidget *scrolled_win; - GtkWidget *list; - GtkWidget *button; - GtkWidget *separator; - FILE *infile; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "list"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5); - gtk_widget_set_size_request (scrolled_win, -1, 300); - gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - - list = gtk_list_new (); - gtk_list_set_selection_mode (GTK_LIST (list), GTK_SELECTION_SINGLE); - gtk_scrolled_window_add_with_viewport - (GTK_SCROLLED_WINDOW (scrolled_win), list); - gtk_container_set_focus_vadjustment - (GTK_CONTAINER (list), - gtk_scrolled_window_get_vadjustment - (GTK_SCROLLED_WINDOW (scrolled_win))); - gtk_container_set_focus_hadjustment - (GTK_CONTAINER (list), - gtk_scrolled_window_get_hadjustment - (GTK_SCROLLED_WINDOW (scrolled_win))); - - if ((infile = fopen("../gtk/gtkenums.h", "r"))) - { - char buffer[256]; - char *pos; - GtkWidget *item; - - while (fgets (buffer, 256, infile)) - { - if ((pos = strchr (buffer, '\n'))) - *pos = 0; - item = gtk_list_item_new_with_label (buffer); - gtk_container_add (GTK_CONTAINER (list), item); - } - - fclose (infile); - } - - - hbox = gtk_hbox_new (TRUE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("Insert Row"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (list_add), - list); - - button = gtk_button_new_with_label ("Clear List"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (list_clear), - list); - - button = gtk_button_new_with_label ("Remove Selection"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (list_remove), - list); - - cbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), cbox, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (cbox), hbox, TRUE, FALSE, 0); - - label = gtk_label_new ("Selection Mode :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - list_omenu = build_option_menu (selection_mode_items, 3, 3, - list_toggle_sel_mode, - list); - gtk_box_pack_start (GTK_BOX (hbox), list_omenu, FALSE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, TRUE, 0); - - cbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), cbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - gtk_container_set_border_width (GTK_CONTAINER (button), 10); - gtk_box_pack_start (GTK_BOX (cbox), button, TRUE, TRUE, 0); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkCList - */ - -static char * book_open_xpm[] = { -"16 16 4 1", -" c None s None", -". c black", -"X c #808080", -"o c white", -" ", -" .. ", -" .Xo. ... ", -" .Xoo. ..oo. ", -" .Xooo.Xooo... ", -" .Xooo.oooo.X. ", -" .Xooo.Xooo.X. ", -" .Xooo.oooo.X. ", -" .Xooo.Xooo.X. ", -" .Xooo.oooo.X. ", -" .Xoo.Xoo..X. ", -" .Xo.o..ooX. ", -" .X..XXXXX. ", -" ..X....... ", -" .. ", -" "}; - -static char * book_closed_xpm[] = { -"16 16 6 1", -" c None s None", -". c black", -"X c red", -"o c yellow", -"O c #808080", -"# c white", -" ", -" .. ", -" ..XX. ", -" ..XXXXX. ", -" ..XXXXXXXX. ", -".ooXXXXXXXXX. ", -"..ooXXXXXXXXX. ", -".X.ooXXXXXXXXX. ", -".XX.ooXXXXXX.. ", -" .XX.ooXXX..#O ", -" .XX.oo..##OO. ", -" .XX..##OO.. ", -" .X.#OO.. ", -" ..O.. ", -" .. ", -" "}; - -static char * mini_page_xpm[] = { -"16 16 4 1", -" c None s None", -". c black", -"X c white", -"o c #808080", -" ", -" ....... ", -" .XXXXX.. ", -" .XoooX.X. ", -" .XXXXX.... ", -" .XooooXoo.o ", -" .XXXXXXXX.o ", -" .XooooooX.o ", -" .XXXXXXXX.o ", -" .XooooooX.o ", -" .XXXXXXXX.o ", -" .XooooooX.o ", -" .XXXXXXXX.o ", -" ..........o ", -" oooooooooo ", -" "}; - -static char * gtk_mini_xpm[] = { -"15 20 17 1", -" c None", -". c #14121F", -"+ c #278828", -"@ c #9B3334", -"# c #284C72", -"$ c #24692A", -"% c #69282E", -"& c #37C539", -"* c #1D2F4D", -"= c #6D7076", -"- c #7D8482", -"; c #E24A49", -"> c #515357", -", c #9B9C9B", -"' c #2FA232", -") c #3CE23D", -"! c #3B6CCB", -" ", -" ***> ", -" >.*!!!* ", -" ***....#*= ", -" *!*.!!!**!!# ", -" .!!#*!#*!!!!# ", -" @%#!.##.*!!$& ", -" @;%*!*.#!#')) ", -" @;;@%!!*$&)'' ", -" @%.%@%$'&)$+' ", -" @;...@$'*'*)+ ", -" @;%..@$+*.')$ ", -" @;%%;;$+..$)# ", -" @;%%;@$$$'.$# ", -" %;@@;;$$+))&* ", -" %;;;@+$&)&* ", -" %;;@'))+> ", -" %;@'&# ", -" >%$$ ", -" >= "}; - -#define TESTGTK_CLIST_COLUMNS 12 -static gint clist_rows = 0; -static GtkWidget *clist_omenu; - -static void -add1000_clist (GtkWidget *widget, gpointer data) -{ - gint i, row; - char text[TESTGTK_CLIST_COLUMNS][50]; - char *texts[TESTGTK_CLIST_COLUMNS]; - GdkBitmap *mask; - GdkPixmap *pixmap; - GtkCList *clist; - - clist = GTK_CLIST (data); - - pixmap = gdk_pixmap_create_from_xpm_d (clist->clist_window, - &mask, - >K_WIDGET (data)->style->white, - gtk_mini_xpm); - - for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++) - { - texts[i] = text[i]; - sprintf (text[i], "Column %d", i); - } - - texts[3] = NULL; - sprintf (text[1], "Right"); - sprintf (text[2], "Center"); - - gtk_clist_freeze (GTK_CLIST (data)); - for (i = 0; i < 1000; i++) - { - sprintf (text[0], "CListRow %d", rand() % 10000); - row = gtk_clist_append (clist, texts); - gtk_clist_set_pixtext (clist, row, 3, "gtk+", 5, pixmap, mask); - } - - gtk_clist_thaw (GTK_CLIST (data)); - - g_object_unref (pixmap); - g_object_unref (mask); -} - -static void -add10000_clist (GtkWidget *widget, gpointer data) -{ - gint i; - char text[TESTGTK_CLIST_COLUMNS][50]; - char *texts[TESTGTK_CLIST_COLUMNS]; - - for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++) - { - texts[i] = text[i]; - sprintf (text[i], "Column %d", i); - } - - sprintf (text[1], "Right"); - sprintf (text[2], "Center"); - - gtk_clist_freeze (GTK_CLIST (data)); - for (i = 0; i < 10000; i++) - { - sprintf (text[0], "CListRow %d", rand() % 10000); - gtk_clist_append (GTK_CLIST (data), texts); - } - gtk_clist_thaw (GTK_CLIST (data)); -} - -void -clear_clist (GtkWidget *widget, gpointer data) -{ - gtk_clist_clear (GTK_CLIST (data)); - clist_rows = 0; -} - -void clist_remove_selection (GtkWidget *widget, GtkCList *clist) -{ - gtk_clist_freeze (clist); - - while (clist->selection) - { - gint row; - - clist_rows--; - row = GPOINTER_TO_INT (clist->selection->data); - - gtk_clist_remove (clist, row); - - if (clist->selection_mode == GTK_SELECTION_BROWSE) - break; - } - - if (clist->selection_mode == GTK_SELECTION_EXTENDED && !clist->selection && - clist->focus_row >= 0) - gtk_clist_select_row (clist, clist->focus_row, -1); - - gtk_clist_thaw (clist); -} - -void toggle_title_buttons (GtkWidget *widget, GtkCList *clist) -{ - if (GTK_TOGGLE_BUTTON (widget)->active) - gtk_clist_column_titles_show (clist); - else - gtk_clist_column_titles_hide (clist); -} - -void toggle_reorderable (GtkWidget *widget, GtkCList *clist) -{ - gtk_clist_set_reorderable (clist, GTK_TOGGLE_BUTTON (widget)->active); -} - -static void -insert_row_clist (GtkWidget *widget, gpointer data) -{ - static char *text[] = - { - "This", "is an", "inserted", "row.", - "This", "is an", "inserted", "row.", - "This", "is an", "inserted", "row." - }; - - static GtkStyle *style1 = NULL; - static GtkStyle *style2 = NULL; - static GtkStyle *style3 = NULL; - gint row; - - if (GTK_CLIST (data)->focus_row >= 0) - row = gtk_clist_insert (GTK_CLIST (data), GTK_CLIST (data)->focus_row, - text); - else - row = gtk_clist_prepend (GTK_CLIST (data), text); - - if (!style1) - { - GdkColor col1 = { 0, }; - GdkColor col2 = { 0, }; - - col1.red = 0; - col1.green = 56000; - col1.blue = 0; - col2.red = 32000; - col2.green = 0; - col2.blue = 56000; - - style1 = gtk_style_copy (GTK_WIDGET (data)->style); - style1->base[GTK_STATE_NORMAL] = col1; - style1->base[GTK_STATE_SELECTED] = col2; - - style2 = gtk_style_copy (GTK_WIDGET (data)->style); - style2->fg[GTK_STATE_NORMAL] = col1; - style2->fg[GTK_STATE_SELECTED] = col2; - - style3 = gtk_style_copy (GTK_WIDGET (data)->style); - style3->fg[GTK_STATE_NORMAL] = col1; - style3->base[GTK_STATE_NORMAL] = col2; - pango_font_description_free (style3->font_desc); - style3->font_desc = pango_font_description_from_string ("courier 12"); - } - - gtk_clist_set_cell_style (GTK_CLIST (data), row, 3, style1); - gtk_clist_set_cell_style (GTK_CLIST (data), row, 4, style2); - gtk_clist_set_cell_style (GTK_CLIST (data), row, 0, style3); - - clist_rows++; -} - -static void -clist_warning_test (GtkWidget *button, - GtkWidget *clist) -{ - GtkWidget *child; - static gboolean add_remove = FALSE; - - add_remove = !add_remove; - - child = gtk_label_new ("Test"); - g_object_ref (child); - gtk_object_sink (GTK_OBJECT (child)); - - if (add_remove) - gtk_container_add (GTK_CONTAINER (clist), child); - else - { - child->parent = clist; - gtk_container_remove (GTK_CONTAINER (clist), child); - child->parent = NULL; - } - - gtk_widget_destroy (child); - gtk_widget_unref (child); -} - -static void -undo_selection (GtkWidget *button, GtkCList *clist) -{ - gtk_clist_undo_selection (clist); -} - -static void -clist_toggle_sel_mode (GtkWidget *widget, gpointer data) -{ - GtkCList *clist; - gint i; - - clist = GTK_CLIST (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_clist_set_selection_mode (clist, selection_modes[i]); -} - -static void -clist_click_column (GtkCList *clist, gint column, gpointer data) -{ - if (column == 4) - gtk_clist_set_column_visibility (clist, column, FALSE); - else if (column == clist->sort_column) - { - if (clist->sort_type == GTK_SORT_ASCENDING) - clist->sort_type = GTK_SORT_DESCENDING; - else - clist->sort_type = GTK_SORT_ASCENDING; - } - else - gtk_clist_set_sort_column (clist, column); - - gtk_clist_sort (clist); -} - -static void -create_clist (GtkWidget *widget) -{ - gint i; - static GtkWidget *window = NULL; - - static char *titles[] = - { - "auto resize", "not resizeable", "max width 100", "min width 50", - "hide column", "Title 5", "Title 6", "Title 7", - "Title 8", "Title 9", "Title 10", "Title 11" - }; - - char text[TESTGTK_CLIST_COLUMNS][50]; - char *texts[TESTGTK_CLIST_COLUMNS]; - - GtkWidget *vbox; - GtkWidget *hbox; - GtkWidget *clist; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *scrolled_win; - GtkWidget *check; - - GtkWidget *undo_button; - GtkWidget *label; - - GtkStyle *style; - GdkColor col1 = { 0, }; - GdkColor col2 = { 0, }; - - if (!window) - { - clist_rows = 0; - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), &window); - - gtk_window_set_title (GTK_WINDOW (window), "clist"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - - /* create GtkCList here so we have a pointer to throw at the - * button callbacks -- more is done with it later */ - clist = gtk_clist_new_with_titles (TESTGTK_CLIST_COLUMNS, titles); - gtk_container_add (GTK_CONTAINER (scrolled_win), clist); - g_signal_connect (clist, "click_column", - G_CALLBACK (clist_click_column), NULL); - - /* control buttons */ - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Insert Row"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (insert_row_clist), clist); - - button = gtk_button_new_with_label ("Add 1,000 Rows With Pixmaps"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (add1000_clist), clist); - - button = gtk_button_new_with_label ("Add 10,000 Rows"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (add10000_clist), clist); - - /* second layer of buttons */ - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Clear List"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (clear_clist), clist); - - button = gtk_button_new_with_label ("Remove Selection"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (clist_remove_selection), clist); - - undo_button = gtk_button_new_with_label ("Undo Selection"); - gtk_box_pack_start (GTK_BOX (hbox), undo_button, TRUE, TRUE, 0); - g_signal_connect (undo_button, "clicked", - G_CALLBACK (undo_selection), clist); - - button = gtk_button_new_with_label ("Warning Test"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (clist_warning_test), clist); - - /* third layer of buttons */ - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - check = gtk_check_button_new_with_label ("Show Title Buttons"); - gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0); - g_signal_connect (check, "clicked", - G_CALLBACK (toggle_title_buttons), clist); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE); - - check = gtk_check_button_new_with_label ("Reorderable"); - gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0); - g_signal_connect (check, "clicked", - G_CALLBACK (toggle_reorderable), clist); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE); - - label = gtk_label_new ("Selection Mode :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - clist_omenu = build_option_menu (selection_mode_items, 3, 3, - clist_toggle_sel_mode, - clist); - gtk_box_pack_start (GTK_BOX (hbox), clist_omenu, FALSE, TRUE, 0); - - /* - * the rest of the clist configuration - */ - - gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0); - gtk_clist_set_row_height (GTK_CLIST (clist), 18); - gtk_widget_set_size_request (clist, -1, 300); - - for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++) - gtk_clist_set_column_width (GTK_CLIST (clist), i, 80); - - gtk_clist_set_column_auto_resize (GTK_CLIST (clist), 0, TRUE); - gtk_clist_set_column_resizeable (GTK_CLIST (clist), 1, FALSE); - gtk_clist_set_column_max_width (GTK_CLIST (clist), 2, 100); - gtk_clist_set_column_min_width (GTK_CLIST (clist), 3, 50); - gtk_clist_set_selection_mode (GTK_CLIST (clist), GTK_SELECTION_EXTENDED); - gtk_clist_set_column_justification (GTK_CLIST (clist), 1, - GTK_JUSTIFY_RIGHT); - gtk_clist_set_column_justification (GTK_CLIST (clist), 2, - GTK_JUSTIFY_CENTER); - - for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++) - { - texts[i] = text[i]; - sprintf (text[i], "Column %d", i); - } - - sprintf (text[1], "Right"); - sprintf (text[2], "Center"); - - col1.red = 56000; - col1.green = 0; - col1.blue = 0; - col2.red = 0; - col2.green = 56000; - col2.blue = 32000; - - style = gtk_style_new (); - style->fg[GTK_STATE_NORMAL] = col1; - style->base[GTK_STATE_NORMAL] = col2; - - pango_font_description_set_size (style->font_desc, 14 * PANGO_SCALE); - pango_font_description_set_weight (style->font_desc, PANGO_WEIGHT_BOLD); - - for (i = 0; i < 10; i++) - { - sprintf (text[0], "CListRow %d", clist_rows++); - gtk_clist_append (GTK_CLIST (clist), texts); - - switch (i % 4) - { - case 2: - gtk_clist_set_row_style (GTK_CLIST (clist), i, style); - break; - default: - gtk_clist_set_cell_style (GTK_CLIST (clist), i, i % 4, style); - break; - } - } - - gtk_style_unref (style); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("close"); - gtk_container_set_border_width (GTK_CONTAINER (button), 10); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - { - clist_rows = 0; - gtk_widget_destroy (window); - } -} - -/* - * GtkCTree - */ - -typedef struct -{ - GdkPixmap *pixmap1; - GdkPixmap *pixmap2; - GdkPixmap *pixmap3; - GdkBitmap *mask1; - GdkBitmap *mask2; - GdkBitmap *mask3; -} CTreePixmaps; - -static gint books = 0; -static gint pages = 0; - -static GtkWidget *book_label; -static GtkWidget *page_label; -static GtkWidget *sel_label; -static GtkWidget *vis_label; -static GtkWidget *omenu1; -static GtkWidget *omenu2; -static GtkWidget *omenu3; -static GtkWidget *omenu4; -static GtkWidget *spin1; -static GtkWidget *spin2; -static GtkWidget *spin3; -static gint line_style; - - -static CTreePixmaps * -get_ctree_pixmaps (GtkCTree *ctree) -{ - GdkScreen *screen = gtk_widget_get_screen (GTK_WIDGET (ctree)); - CTreePixmaps *pixmaps = g_object_get_data (G_OBJECT (screen), "ctree-pixmaps"); - - if (!pixmaps) - { - GdkColormap *colormap = gdk_screen_get_rgb_colormap (screen); - pixmaps = g_new (CTreePixmaps, 1); - - pixmaps->pixmap1 = gdk_pixmap_colormap_create_from_xpm_d (NULL, colormap, - &pixmaps->mask1, - NULL, book_closed_xpm); - pixmaps->pixmap2 = gdk_pixmap_colormap_create_from_xpm_d (NULL, colormap, - &pixmaps->mask2, - NULL, book_open_xpm); - pixmaps->pixmap3 = gdk_pixmap_colormap_create_from_xpm_d (NULL, colormap, - &pixmaps->mask3, - NULL, mini_page_xpm); - - g_object_set_data (G_OBJECT (screen), "ctree-pixmaps", pixmaps); - } - - return pixmaps; -} - -void after_press (GtkCTree *ctree, gpointer data) -{ - char buf[80]; - - sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->selection)); - gtk_label_set_text (GTK_LABEL (sel_label), buf); - - sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->row_list)); - gtk_label_set_text (GTK_LABEL (vis_label), buf); - - sprintf (buf, "%d", books); - gtk_label_set_text (GTK_LABEL (book_label), buf); - - sprintf (buf, "%d", pages); - gtk_label_set_text (GTK_LABEL (page_label), buf); -} - -void after_move (GtkCTree *ctree, GtkCTreeNode *child, GtkCTreeNode *parent, - GtkCTreeNode *sibling, gpointer data) -{ - char *source; - char *target1; - char *target2; - - gtk_ctree_get_node_info (ctree, child, &source, - NULL, NULL, NULL, NULL, NULL, NULL, NULL); - if (parent) - gtk_ctree_get_node_info (ctree, parent, &target1, - NULL, NULL, NULL, NULL, NULL, NULL, NULL); - if (sibling) - gtk_ctree_get_node_info (ctree, sibling, &target2, - NULL, NULL, NULL, NULL, NULL, NULL, NULL); - - g_print ("Moving \"%s\" to \"%s\" with sibling \"%s\".\n", source, - (parent) ? target1 : "nil", (sibling) ? target2 : "nil"); -} - -void count_items (GtkCTree *ctree, GtkCTreeNode *list) -{ - if (GTK_CTREE_ROW (list)->is_leaf) - pages--; - else - books--; -} - -void expand_all (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_expand_recursive (ctree, NULL); - after_press (ctree, NULL); -} - -void collapse_all (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_collapse_recursive (ctree, NULL); - after_press (ctree, NULL); -} - -void select_all (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_select_recursive (ctree, NULL); - after_press (ctree, NULL); -} - -void change_style (GtkWidget *widget, GtkCTree *ctree) -{ - static GtkStyle *style1 = NULL; - static GtkStyle *style2 = NULL; - - GtkCTreeNode *node; - GdkColor col1 = { 0, }; - GdkColor col2 = { 0, }; - - if (GTK_CLIST (ctree)->focus_row >= 0) - node = GTK_CTREE_NODE - (g_list_nth (GTK_CLIST (ctree)->row_list,GTK_CLIST (ctree)->focus_row)); - else - node = GTK_CTREE_NODE (GTK_CLIST (ctree)->row_list); - - if (!node) - return; - - if (!style1) - { - col1.red = 0; - col1.green = 56000; - col1.blue = 0; - col2.red = 32000; - col2.green = 0; - col2.blue = 56000; - - style1 = gtk_style_new (); - style1->base[GTK_STATE_NORMAL] = col1; - style1->fg[GTK_STATE_SELECTED] = col2; - - style2 = gtk_style_new (); - style2->base[GTK_STATE_SELECTED] = col2; - style2->fg[GTK_STATE_NORMAL] = col1; - style2->base[GTK_STATE_NORMAL] = col2; - pango_font_description_free (style2->font_desc); - style2->font_desc = pango_font_description_from_string ("courier 30"); - } - - gtk_ctree_node_set_cell_style (ctree, node, 1, style1); - gtk_ctree_node_set_cell_style (ctree, node, 0, style2); - - if (GTK_CTREE_ROW (node)->children) - gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children, - style2); -} - -void unselect_all (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_unselect_recursive (ctree, NULL); - after_press (ctree, NULL); -} - -void remove_selection (GtkWidget *widget, GtkCTree *ctree) -{ - GtkCList *clist; - GtkCTreeNode *node; - - clist = GTK_CLIST (ctree); - - gtk_clist_freeze (clist); - - while (clist->selection) - { - node = clist->selection->data; - - if (GTK_CTREE_ROW (node)->is_leaf) - pages--; - else - gtk_ctree_post_recursive (ctree, node, - (GtkCTreeFunc) count_items, NULL); - - gtk_ctree_remove_node (ctree, node); - - if (clist->selection_mode == GTK_SELECTION_BROWSE) - break; - } - - if (clist->selection_mode == GTK_SELECTION_EXTENDED && !clist->selection && - clist->focus_row >= 0) - { - node = gtk_ctree_node_nth (ctree, clist->focus_row); - - if (node) - gtk_ctree_select (ctree, node); - } - - gtk_clist_thaw (clist); - after_press (ctree, NULL); -} - -struct _ExportStruct { - gchar *tree; - gchar *info; - gboolean is_leaf; -}; - -typedef struct _ExportStruct ExportStruct; - -gboolean -gnode2ctree (GtkCTree *ctree, - guint depth, - GNode *gnode, - GtkCTreeNode *cnode, - gpointer data) -{ - ExportStruct *es; - GdkPixmap *pixmap_closed; - GdkBitmap *mask_closed; - GdkPixmap *pixmap_opened; - GdkBitmap *mask_opened; - CTreePixmaps *pixmaps; - - if (!cnode || !gnode || (!(es = gnode->data))) - return FALSE; - - pixmaps = get_ctree_pixmaps (ctree); - - if (es->is_leaf) - { - pixmap_closed = pixmaps->pixmap3; - mask_closed = pixmaps->mask3; - pixmap_opened = NULL; - mask_opened = NULL; - } - else - { - pixmap_closed = pixmaps->pixmap1; - mask_closed = pixmaps->mask1; - pixmap_opened = pixmaps->pixmap2; - mask_opened = pixmaps->mask2; - } - - gtk_ctree_set_node_info (ctree, cnode, es->tree, 2, pixmap_closed, - mask_closed, pixmap_opened, mask_opened, - es->is_leaf, (depth < 3)); - gtk_ctree_node_set_text (ctree, cnode, 1, es->info); - g_free (es); - gnode->data = NULL; - - return TRUE; -} - -gboolean -ctree2gnode (GtkCTree *ctree, - guint depth, - GNode *gnode, - GtkCTreeNode *cnode, - gpointer data) -{ - ExportStruct *es; - - if (!cnode || !gnode) - return FALSE; - - es = g_new (ExportStruct, 1); - gnode->data = es; - es->is_leaf = GTK_CTREE_ROW (cnode)->is_leaf; - es->tree = GTK_CELL_PIXTEXT (GTK_CTREE_ROW (cnode)->row.cell[0])->text; - es->info = GTK_CELL_PIXTEXT (GTK_CTREE_ROW (cnode)->row.cell[1])->text; - return TRUE; -} - -void export_ctree (GtkWidget *widget, GtkCTree *ctree) -{ - char *title[] = { "Tree" , "Info" }; - static GtkWidget *export_window = NULL; - static GtkCTree *export_ctree; - GtkWidget *vbox; - GtkWidget *scrolled_win; - GtkWidget *button; - GtkWidget *sep; - GNode *gnode; - GtkCTreeNode *node; - - if (!export_window) - { - export_window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (export_window), - gtk_widget_get_screen (widget)); - - g_signal_connect (export_window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &export_window); - - gtk_window_set_title (GTK_WINDOW (export_window), "exported ctree"); - gtk_container_set_border_width (GTK_CONTAINER (export_window), 5); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (export_window), vbox); - - button = gtk_button_new_with_label ("Close"); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, TRUE, 0); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - export_window); - - sep = gtk_hseparator_new (); - gtk_box_pack_end (GTK_BOX (vbox), sep, FALSE, TRUE, 10); - - export_ctree = GTK_CTREE (gtk_ctree_new_with_titles (2, 0, title)); - gtk_ctree_set_line_style (export_ctree, GTK_CTREE_LINES_DOTTED); - - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_container_add (GTK_CONTAINER (scrolled_win), - GTK_WIDGET (export_ctree)); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0); - gtk_clist_set_selection_mode (GTK_CLIST (export_ctree), - GTK_SELECTION_EXTENDED); - gtk_clist_set_column_width (GTK_CLIST (export_ctree), 0, 200); - gtk_clist_set_column_width (GTK_CLIST (export_ctree), 1, 200); - gtk_widget_set_size_request (GTK_WIDGET (export_ctree), 300, 200); - } - - if (!GTK_WIDGET_VISIBLE (export_window)) - gtk_widget_show_all (export_window); - - gtk_clist_clear (GTK_CLIST (export_ctree)); - - node = GTK_CTREE_NODE (g_list_nth (GTK_CLIST (ctree)->row_list, - GTK_CLIST (ctree)->focus_row)); - if (!node) - return; - - gnode = gtk_ctree_export_to_gnode (ctree, NULL, NULL, node, - ctree2gnode, NULL); - if (gnode) - { - gtk_ctree_insert_gnode (export_ctree, NULL, NULL, gnode, - gnode2ctree, NULL); - g_node_destroy (gnode); - } -} - -void change_indent (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_set_indent (ctree, GTK_ADJUSTMENT (widget)->value); -} - -void change_spacing (GtkWidget *widget, GtkCTree *ctree) -{ - gtk_ctree_set_spacing (ctree, GTK_ADJUSTMENT (widget)->value); -} - -void change_row_height (GtkWidget *widget, GtkCList *clist) -{ - gtk_clist_set_row_height (clist, GTK_ADJUSTMENT (widget)->value); -} - -void set_background (GtkCTree *ctree, GtkCTreeNode *node, gpointer data) -{ - GtkStyle *style = NULL; - - if (!node) - return; - - if (ctree->line_style != GTK_CTREE_LINES_TABBED) - { - if (!GTK_CTREE_ROW (node)->is_leaf) - style = GTK_CTREE_ROW (node)->row.data; - else if (GTK_CTREE_ROW (node)->parent) - style = GTK_CTREE_ROW (GTK_CTREE_ROW (node)->parent)->row.data; - } - - gtk_ctree_node_set_row_style (ctree, node, style); -} - -void -ctree_toggle_line_style (GtkWidget *widget, gpointer data) -{ - GtkCTree *ctree; - gint i; - - ctree = GTK_CTREE (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - if ((ctree->line_style == GTK_CTREE_LINES_TABBED && - ((GtkCTreeLineStyle) i) != GTK_CTREE_LINES_TABBED) || - (ctree->line_style != GTK_CTREE_LINES_TABBED && - ((GtkCTreeLineStyle) i) == GTK_CTREE_LINES_TABBED)) - gtk_ctree_pre_recursive (ctree, NULL, set_background, NULL); - gtk_ctree_set_line_style (ctree, i); - line_style = i; -} - -void -ctree_toggle_expander_style (GtkWidget *widget, gpointer data) -{ - GtkCTree *ctree; - gint i; - - ctree = GTK_CTREE (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_ctree_set_expander_style (ctree, (GtkCTreeExpanderStyle) i); -} - -void -ctree_toggle_justify (GtkWidget *widget, gpointer data) -{ - GtkCTree *ctree; - gint i; - - ctree = GTK_CTREE (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_clist_set_column_justification (GTK_CLIST (ctree), ctree->tree_column, - (GtkJustification) i); -} - -void -ctree_toggle_sel_mode (GtkWidget *widget, gpointer data) -{ - GtkCTree *ctree; - gint i; - - ctree = GTK_CTREE (data); - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_clist_set_selection_mode (GTK_CLIST (ctree), selection_modes[i]); - after_press (ctree, NULL); -} - -void build_recursive (GtkCTree *ctree, gint cur_depth, gint depth, - gint num_books, gint num_pages, GtkCTreeNode *parent) -{ - gchar *text[2]; - gchar buf1[60]; - gchar buf2[60]; - GtkCTreeNode *sibling; - CTreePixmaps *pixmaps; - gint i; - - text[0] = buf1; - text[1] = buf2; - sibling = NULL; - - pixmaps = get_ctree_pixmaps (ctree); - - for (i = num_pages + num_books; i > num_books; i--) - { - pages++; - sprintf (buf1, "Page %02d", (gint) rand() % 100); - sprintf (buf2, "Item %d-%d", cur_depth, i); - sibling = gtk_ctree_insert_node (ctree, parent, sibling, text, 5, - pixmaps->pixmap3, pixmaps->mask3, NULL, NULL, - TRUE, FALSE); - - if (parent && ctree->line_style == GTK_CTREE_LINES_TABBED) - gtk_ctree_node_set_row_style (ctree, sibling, - GTK_CTREE_ROW (parent)->row.style); - } - - if (cur_depth == depth) - return; - - for (i = num_books; i > 0; i--) - { - GtkStyle *style; - - books++; - sprintf (buf1, "Book %02d", (gint) rand() % 100); - sprintf (buf2, "Item %d-%d", cur_depth, i); - sibling = gtk_ctree_insert_node (ctree, parent, sibling, text, 5, - pixmaps->pixmap1, pixmaps->mask1, pixmaps->pixmap2, pixmaps->mask2, - FALSE, FALSE); - - style = gtk_style_new (); - switch (cur_depth % 3) - { - case 0: - style->base[GTK_STATE_NORMAL].red = 10000 * (cur_depth % 6); - style->base[GTK_STATE_NORMAL].green = 0; - style->base[GTK_STATE_NORMAL].blue = 65535 - ((i * 10000) % 65535); - break; - case 1: - style->base[GTK_STATE_NORMAL].red = 10000 * (cur_depth % 6); - style->base[GTK_STATE_NORMAL].green = 65535 - ((i * 10000) % 65535); - style->base[GTK_STATE_NORMAL].blue = 0; - break; - default: - style->base[GTK_STATE_NORMAL].red = 65535 - ((i * 10000) % 65535); - style->base[GTK_STATE_NORMAL].green = 0; - style->base[GTK_STATE_NORMAL].blue = 10000 * (cur_depth % 6); - break; - } - gtk_ctree_node_set_row_data_full (ctree, sibling, style, - (GtkDestroyNotify) gtk_style_unref); - - if (ctree->line_style == GTK_CTREE_LINES_TABBED) - gtk_ctree_node_set_row_style (ctree, sibling, style); - - build_recursive (ctree, cur_depth + 1, depth, num_books, num_pages, - sibling); - } -} - -void rebuild_tree (GtkWidget *widget, GtkCTree *ctree) -{ - gchar *text [2]; - gchar label1[] = "Root"; - gchar label2[] = ""; - GtkCTreeNode *parent; - GtkStyle *style; - guint b, d, p, n; - CTreePixmaps *pixmaps; - - pixmaps = get_ctree_pixmaps (ctree); - - text[0] = label1; - text[1] = label2; - - d = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin1)); - b = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin2)); - p = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin3)); - - n = ((pow (b, d) - 1) / (b - 1)) * (p + 1); - - if (n > 100000) - { - g_print ("%d total items? Try less\n",n); - return; - } - - gtk_clist_freeze (GTK_CLIST (ctree)); - gtk_clist_clear (GTK_CLIST (ctree)); - - books = 1; - pages = 0; - - parent = gtk_ctree_insert_node (ctree, NULL, NULL, text, 5, pixmaps->pixmap1, - pixmaps->mask1, pixmaps->pixmap2, pixmaps->mask2, FALSE, TRUE); - - style = gtk_style_new (); - style->base[GTK_STATE_NORMAL].red = 0; - style->base[GTK_STATE_NORMAL].green = 45000; - style->base[GTK_STATE_NORMAL].blue = 55000; - gtk_ctree_node_set_row_data_full (ctree, parent, style, - (GtkDestroyNotify) gtk_style_unref); - - if (ctree->line_style == GTK_CTREE_LINES_TABBED) - gtk_ctree_node_set_row_style (ctree, parent, style); - - build_recursive (ctree, 1, d, b, p, parent); - gtk_clist_thaw (GTK_CLIST (ctree)); - after_press (ctree, NULL); -} - -static void -ctree_click_column (GtkCTree *ctree, gint column, gpointer data) -{ - GtkCList *clist; - - clist = GTK_CLIST (ctree); - - if (column == clist->sort_column) - { - if (clist->sort_type == GTK_SORT_ASCENDING) - clist->sort_type = GTK_SORT_DESCENDING; - else - clist->sort_type = GTK_SORT_ASCENDING; - } - else - gtk_clist_set_sort_column (clist, column); - - gtk_ctree_sort_recursive (ctree, NULL); -} - -void create_ctree (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkTooltips *tooltips; - GtkCTree *ctree; - GtkWidget *scrolled_win; - GtkWidget *vbox; - GtkWidget *bbox; - GtkWidget *mbox; - GtkWidget *hbox; - GtkWidget *hbox2; - GtkWidget *frame; - GtkWidget *label; - GtkWidget *button; - GtkWidget *check; - GtkAdjustment *adj; - GtkWidget *spinner; - - char *title[] = { "Tree" , "Info" }; - char buf[80]; - - static gchar *items1[] = - { - "No lines", - "Solid", - "Dotted", - "Tabbed" - }; - - static gchar *items2[] = - { - "None", - "Square", - "Triangle", - "Circular" - }; - - static gchar *items3[] = - { - "Left", - "Right" - }; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkCTree"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - tooltips = gtk_tooltips_new (); - g_object_ref (tooltips); - gtk_object_sink (GTK_OBJECT (tooltips)); - - g_object_set_data_full (G_OBJECT (window), "tooltips", tooltips, - g_object_unref); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0); - - label = gtk_label_new ("Depth :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (4, 1, 10, 1, 5, 0); - spin1 = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (hbox), spin1, FALSE, TRUE, 5); - - label = gtk_label_new ("Books :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (3, 1, 20, 1, 5, 0); - spin2 = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (hbox), spin2, FALSE, TRUE, 5); - - label = gtk_label_new ("Pages :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (5, 1, 20, 1, 5, 0); - spin3 = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (hbox), spin3, FALSE, TRUE, 5); - - button = gtk_button_new_with_label ("Close"); - gtk_box_pack_end (GTK_BOX (hbox), button, TRUE, TRUE, 0); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - button = gtk_button_new_with_label ("Rebuild Tree"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_ALWAYS); - gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0); - - ctree = GTK_CTREE (gtk_ctree_new_with_titles (2, 0, title)); - gtk_container_add (GTK_CONTAINER (scrolled_win), GTK_WIDGET (ctree)); - - gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE); - gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200); - gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED); - gtk_ctree_set_line_style (ctree, GTK_CTREE_LINES_DOTTED); - line_style = GTK_CTREE_LINES_DOTTED; - - g_signal_connect (button, "clicked", - G_CALLBACK (rebuild_tree), ctree); - g_signal_connect (ctree, "click_column", - G_CALLBACK (ctree_click_column), NULL); - - g_signal_connect_after (ctree, "button_press_event", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "button_release_event", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "tree_move", - G_CALLBACK (after_move), NULL); - g_signal_connect_after (ctree, "end_selection", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "toggle_focus_row", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "select_all", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "unselect_all", - G_CALLBACK (after_press), NULL); - g_signal_connect_after (ctree, "scroll_vertical", - G_CALLBACK (after_press), NULL); - - bbox = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (bbox), 5); - gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, TRUE, 0); - - mbox = gtk_vbox_new (TRUE, 5); - gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0); - - label = gtk_label_new ("Row Height :"); - gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0); - - label = gtk_label_new ("Indent :"); - gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0); - - label = gtk_label_new ("Spacing :"); - gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0); - - mbox = gtk_vbox_new (TRUE, 5); - gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0); - - adj = (GtkAdjustment *) gtk_adjustment_new (20, 12, 100, 1, 10, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5); - gtk_tooltips_set_tip (tooltips, spinner, - "Row height of list items", NULL); - g_signal_connect (adj, "value_changed", - G_CALLBACK (change_row_height), ctree); - gtk_clist_set_row_height ( GTK_CLIST (ctree), adj->value); - - adj = (GtkAdjustment *) gtk_adjustment_new (20, 0, 60, 1, 10, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5); - gtk_tooltips_set_tip (tooltips, spinner, "Tree Indentation.", NULL); - g_signal_connect (adj, "value_changed", - G_CALLBACK (change_indent), ctree); - - adj = (GtkAdjustment *) gtk_adjustment_new (5, 0, 60, 1, 10, 0); - spinner = gtk_spin_button_new (adj, 0, 0); - gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5); - gtk_tooltips_set_tip (tooltips, spinner, "Tree Spacing.", NULL); - g_signal_connect (adj, "value_changed", - G_CALLBACK (change_spacing), ctree); - - mbox = gtk_vbox_new (TRUE, 5); - gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Expand All"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (expand_all), ctree); - - button = gtk_button_new_with_label ("Collapse All"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (collapse_all), ctree); - - button = gtk_button_new_with_label ("Change Style"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (change_style), ctree); - - button = gtk_button_new_with_label ("Export Tree"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (export_ctree), ctree); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Select All"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (select_all), ctree); - - button = gtk_button_new_with_label ("Unselect All"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (unselect_all), ctree); - - button = gtk_button_new_with_label ("Remove Selection"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (remove_selection), ctree); - - check = gtk_check_button_new_with_label ("Reorderable"); - gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0); - gtk_tooltips_set_tip (tooltips, check, - "Tree items can be reordered by dragging.", NULL); - g_signal_connect (check, "clicked", - G_CALLBACK (toggle_reorderable), ctree); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE); - - hbox = gtk_hbox_new (TRUE, 5); - gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0); - - omenu1 = build_option_menu (items1, 4, 2, - ctree_toggle_line_style, - ctree); - gtk_box_pack_start (GTK_BOX (hbox), omenu1, FALSE, TRUE, 0); - gtk_tooltips_set_tip (tooltips, omenu1, "The tree's line style.", NULL); - - omenu2 = build_option_menu (items2, 4, 1, - ctree_toggle_expander_style, - ctree); - gtk_box_pack_start (GTK_BOX (hbox), omenu2, FALSE, TRUE, 0); - gtk_tooltips_set_tip (tooltips, omenu2, "The tree's expander style.", - NULL); - - omenu3 = build_option_menu (items3, 2, 0, - ctree_toggle_justify, ctree); - gtk_box_pack_start (GTK_BOX (hbox), omenu3, FALSE, TRUE, 0); - gtk_tooltips_set_tip (tooltips, omenu3, "The tree's justification.", - NULL); - - omenu4 = build_option_menu (selection_mode_items, 3, 3, - ctree_toggle_sel_mode, ctree); - gtk_box_pack_start (GTK_BOX (hbox), omenu4, FALSE, TRUE, 0); - gtk_tooltips_set_tip (tooltips, omenu4, "The list's selection mode.", - NULL); - - gtk_widget_realize (window); - - gtk_widget_set_size_request (GTK_WIDGET (ctree), -1, 300); - - frame = gtk_frame_new (NULL); - gtk_container_set_border_width (GTK_CONTAINER (frame), 0); - gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_OUT); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0); - - hbox = gtk_hbox_new (TRUE, 2); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 2); - gtk_container_add (GTK_CONTAINER (frame), hbox); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN); - gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0); - - hbox2 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2); - gtk_container_add (GTK_CONTAINER (frame), hbox2); - - label = gtk_label_new ("Books :"); - gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0); - - sprintf (buf, "%d", books); - book_label = gtk_label_new (buf); - gtk_box_pack_end (GTK_BOX (hbox2), book_label, FALSE, TRUE, 5); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN); - gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0); - - hbox2 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2); - gtk_container_add (GTK_CONTAINER (frame), hbox2); - - label = gtk_label_new ("Pages :"); - gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0); - - sprintf (buf, "%d", pages); - page_label = gtk_label_new (buf); - gtk_box_pack_end (GTK_BOX (hbox2), page_label, FALSE, TRUE, 5); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN); - gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0); - - hbox2 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2); - gtk_container_add (GTK_CONTAINER (frame), hbox2); - - label = gtk_label_new ("Selected :"); - gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0); - - sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->selection)); - sel_label = gtk_label_new (buf); - gtk_box_pack_end (GTK_BOX (hbox2), sel_label, FALSE, TRUE, 5); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN); - gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0); - - hbox2 = gtk_hbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2); - gtk_container_add (GTK_CONTAINER (frame), hbox2); - - label = gtk_label_new ("Visible :"); - gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0); - - sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->row_list)); - vis_label = gtk_label_new (buf); - gtk_box_pack_end (GTK_BOX (hbox2), vis_label, FALSE, TRUE, 5); - - rebuild_tree (NULL, ctree); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkColorSelection - */ - -void -color_selection_ok (GtkWidget *w, - GtkColorSelectionDialog *cs) -{ - GtkColorSelection *colorsel; - gdouble color[4]; - - colorsel=GTK_COLOR_SELECTION(cs->colorsel); - - gtk_color_selection_get_color(colorsel,color); - gtk_color_selection_set_color(colorsel,color); -} - -void -color_selection_changed (GtkWidget *w, - GtkColorSelectionDialog *cs) -{ - GtkColorSelection *colorsel; - gdouble color[4]; - - colorsel=GTK_COLOR_SELECTION(cs->colorsel); - gtk_color_selection_get_color(colorsel,color); -} - -#if 0 /* unused */ -static void -opacity_toggled_cb (GtkWidget *w, - GtkColorSelectionDialog *cs) -{ - GtkColorSelection *colorsel; - - colorsel = GTK_COLOR_SELECTION (cs->colorsel); - gtk_color_selection_set_has_opacity_control (colorsel, - gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (w))); -} - -static void -palette_toggled_cb (GtkWidget *w, - GtkColorSelectionDialog *cs) -{ - GtkColorSelection *colorsel; - - colorsel = GTK_COLOR_SELECTION (cs->colorsel); - gtk_color_selection_set_has_palette (colorsel, - gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (w))); -} -#endif - -void -create_color_selection (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *picker; - GtkWidget *hbox; - GtkWidget *label; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkColorButton"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - hbox = gtk_hbox_new (FALSE, 8); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 8); - gtk_container_add (GTK_CONTAINER (window), hbox); - - label = gtk_label_new ("Pick a color"); - gtk_container_add (GTK_CONTAINER (hbox), label); - - picker = gtk_color_button_new (); - gtk_color_button_set_use_alpha (GTK_COLOR_BUTTON (picker), TRUE); - gtk_container_add (GTK_CONTAINER (hbox), picker); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkFileSelection - */ - -void -show_fileops (GtkWidget *widget, - GtkFileSelection *fs) -{ - gboolean show_ops; - - show_ops = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)); - - if (show_ops) - gtk_file_selection_show_fileop_buttons (fs); - else - gtk_file_selection_hide_fileop_buttons (fs); -} - -void -select_multiple (GtkWidget *widget, - GtkFileSelection *fs) -{ - gboolean select_multiple; - - select_multiple = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)); - gtk_file_selection_set_select_multiple (fs, select_multiple); -} - -void -file_selection_ok (GtkFileSelection *fs) -{ - int i; - gchar **selections; - - selections = gtk_file_selection_get_selections (fs); - - for (i = 0; selections[i] != NULL; i++) - g_print ("%s\n", selections[i]); - - g_strfreev (selections); - - gtk_widget_destroy (GTK_WIDGET (fs)); -} - -void -create_file_selection (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - - if (!window) - { - window = gtk_file_selection_new ("file selection dialog"); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_file_selection_hide_fileop_buttons (GTK_FILE_SELECTION (window)); - - gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - g_signal_connect_swapped (GTK_FILE_SELECTION (window)->ok_button, - "clicked", - G_CALLBACK (file_selection_ok), - window); - g_signal_connect_swapped (GTK_FILE_SELECTION (window)->cancel_button, - "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - button = gtk_check_button_new_with_label ("Show Fileops"); - g_signal_connect (button, "toggled", - G_CALLBACK (show_fileops), - window); - gtk_box_pack_start (GTK_BOX (GTK_FILE_SELECTION (window)->action_area), - button, FALSE, FALSE, 0); - gtk_widget_show (button); - - button = gtk_check_button_new_with_label ("Select Multiple"); - g_signal_connect (button, "clicked", - G_CALLBACK (select_multiple), - window); - gtk_box_pack_start (GTK_BOX (GTK_FILE_SELECTION (window)->action_area), - button, FALSE, FALSE, 0); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -void -flipping_toggled_cb (GtkWidget *widget, gpointer data) -{ - int state = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)); - int new_direction = state ? GTK_TEXT_DIR_RTL : GTK_TEXT_DIR_LTR; - - gtk_widget_set_default_direction (new_direction); -} - -static void -set_direction_recurse (GtkWidget *widget, - gpointer data) -{ - GtkTextDirection *dir = data; - - gtk_widget_set_direction (widget, *dir); - if (GTK_IS_CONTAINER (widget)) - gtk_container_foreach (GTK_CONTAINER (widget), - set_direction_recurse, - data); -} - -static GtkWidget * -create_forward_back (const char *title, - GtkTextDirection text_dir) -{ - GtkWidget *frame = gtk_frame_new (title); - GtkWidget *bbox = gtk_hbutton_box_new (); - GtkWidget *back_button = gtk_button_new_from_stock (GTK_STOCK_GO_BACK); - GtkWidget *forward_button = gtk_button_new_from_stock (GTK_STOCK_GO_FORWARD); - - gtk_container_set_border_width (GTK_CONTAINER (bbox), 5); - - gtk_container_add (GTK_CONTAINER (frame), bbox); - gtk_container_add (GTK_CONTAINER (bbox), back_button); - gtk_container_add (GTK_CONTAINER (bbox), forward_button); - - set_direction_recurse (frame, &text_dir); - - return frame; -} - -void -create_flipping (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *check_button, *button; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Bidirectional Flipping"); - - check_button = gtk_check_button_new_with_label ("Right-to-left global direction"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - check_button, TRUE, TRUE, 0); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - create_forward_back ("Default", GTK_TEXT_DIR_NONE), - TRUE, TRUE, 0); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - create_forward_back ("Left-to-Right", GTK_TEXT_DIR_LTR), - TRUE, TRUE, 0); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - create_forward_back ("Right-to-Left", GTK_TEXT_DIR_RTL), - TRUE, TRUE, 0); - - if (gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL) - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button), TRUE); - - g_signal_connect (check_button, "toggled", - G_CALLBACK (flipping_toggled_cb), NULL); - - gtk_container_set_border_width (GTK_CONTAINER (check_button), 10); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), window); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Focus test - */ - -static GtkWidget* -make_focus_table (GList **list) -{ - GtkWidget *table; - gint i, j; - - table = gtk_table_new (5, 5, FALSE); - - i = 0; - j = 0; - - while (i < 5) - { - j = 0; - while (j < 5) - { - GtkWidget *widget; - - if ((i + j) % 2) - widget = gtk_entry_new (); - else - widget = gtk_button_new_with_label ("Foo"); - - *list = g_list_prepend (*list, widget); - - gtk_table_attach (GTK_TABLE (table), - widget, - i, i + 1, - j, j + 1, - GTK_EXPAND | GTK_FILL, - GTK_EXPAND | GTK_FILL, - 5, 5); - - ++j; - } - - ++i; - } - - *list = g_list_reverse (*list); - - return table; -} - -static void -create_focus (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *table; - GtkWidget *frame; - GList *list = NULL; - - window = gtk_dialog_new_with_buttons ("Keyboard focus navigation", - NULL, 0, - GTK_STOCK_CLOSE, - GTK_RESPONSE_NONE, - NULL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - g_signal_connect (window, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - - gtk_window_set_title (GTK_WINDOW (window), "Keyboard Focus Navigation"); - - frame = gtk_frame_new ("Weird tab focus chain"); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - frame, TRUE, TRUE, 0); - - table = make_focus_table (&list); - - gtk_container_add (GTK_CONTAINER (frame), table); - - gtk_container_set_focus_chain (GTK_CONTAINER (table), - list); - - g_list_free (list); - - frame = gtk_frame_new ("Default tab focus chain"); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - frame, TRUE, TRUE, 0); - - list = NULL; - table = make_focus_table (&list); - - g_list_free (list); - - gtk_container_add (GTK_CONTAINER (frame), table); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkFontSelection - */ - -void -font_selection_ok (GtkWidget *w, - GtkFontSelectionDialog *fs) -{ - gchar *s = gtk_font_selection_dialog_get_font_name (fs); - - g_print ("%s\n", s); - g_free (s); - gtk_widget_destroy (GTK_WIDGET (fs)); -} - -void -create_font_selection (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - - if (!window) - { - GtkWidget *picker; - GtkWidget *hbox; - GtkWidget *label; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "GtkFontButton"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - hbox = gtk_hbox_new (FALSE, 8); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 8); - gtk_container_add (GTK_CONTAINER (window), hbox); - - label = gtk_label_new ("Pick a font"); - gtk_container_add (GTK_CONTAINER (hbox), label); - - picker = gtk_font_button_new (); - gtk_font_button_set_use_font (GTK_FONT_BUTTON (picker), TRUE); - gtk_container_add (GTK_CONTAINER (hbox), picker); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkDialog - */ - -static GtkWidget *dialog_window = NULL; - -static void -label_toggle (GtkWidget *widget, - GtkWidget **label) -{ - if (!(*label)) - { - *label = gtk_label_new ("Dialog Test"); - g_signal_connect (*label, - "destroy", - G_CALLBACK (gtk_widget_destroyed), - label); - gtk_misc_set_padding (GTK_MISC (*label), 10, 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->vbox), - *label, TRUE, TRUE, 0); - gtk_widget_show (*label); - } - else - gtk_widget_destroy (*label); -} - -#define RESPONSE_TOGGLE_SEPARATOR 1 - -static void -print_response (GtkWidget *dialog, - gint response_id, - gpointer data) -{ - g_print ("response signal received (%d)\n", response_id); - - if (response_id == RESPONSE_TOGGLE_SEPARATOR) - { - gtk_dialog_set_has_separator (GTK_DIALOG (dialog), - !gtk_dialog_get_has_separator (GTK_DIALOG (dialog))); - } -} - -static void -create_dialog (GtkWidget *widget) -{ - static GtkWidget *label; - GtkWidget *button; - - if (!dialog_window) - { - /* This is a terrible example; it's much simpler to create - * dialogs than this. Don't use testgtk for example code, - * use gtk-demo ;-) - */ - - dialog_window = gtk_dialog_new (); - gtk_window_set_screen (GTK_WINDOW (dialog_window), - gtk_widget_get_screen (widget)); - - g_signal_connect (dialog_window, - "response", - G_CALLBACK (print_response), - NULL); - - g_signal_connect (dialog_window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &dialog_window); - - gtk_window_set_title (GTK_WINDOW (dialog_window), "GtkDialog"); - gtk_container_set_border_width (GTK_CONTAINER (dialog_window), 0); - - button = gtk_button_new_with_label ("OK"); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("Toggle"); - g_signal_connect (button, "clicked", - G_CALLBACK (label_toggle), - &label); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - - label = NULL; - - button = gtk_button_new_with_label ("Separator"); - - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - - gtk_dialog_add_action_widget (GTK_DIALOG (dialog_window), - button, - RESPONSE_TOGGLE_SEPARATOR); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (dialog_window)) - gtk_widget_show (dialog_window); - else - gtk_widget_destroy (dialog_window); -} - -/* Display & Screen test - */ - -typedef struct -{ - GtkEntry *entry; - GtkWidget *radio_dpy; - GtkWidget *toplevel; - GtkWidget *dialog_window; - GList *valid_display_list; -} ScreenDisplaySelection; - -static gint -display_name_cmp (gconstpointer a, - gconstpointer b) -{ - return g_ascii_strcasecmp (a,b); -} - -static void -screen_display_check (GtkWidget *widget, ScreenDisplaySelection *data) -{ - char *display_name; - GdkDisplay *display = gtk_widget_get_display (widget); - GtkWidget *dialog; - GdkScreen *new_screen = NULL; - GdkScreen *current_screen = gtk_widget_get_screen (widget); - - if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (data->radio_dpy))) - { - display_name = g_strdup (gtk_entry_get_text (data->entry)); - display = gdk_display_open (display_name); - - if (!display) - { - dialog = gtk_message_dialog_new (GTK_WINDOW (gtk_widget_get_toplevel (widget)), - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_OK, - "The display :\n%s\ncannot be opened", - display_name); - gtk_window_set_screen (GTK_WINDOW (dialog), current_screen); - gtk_widget_show (dialog); - g_signal_connect (dialog, "response", - G_CALLBACK (gtk_widget_destroy), - NULL); - } - else - { - if (!g_list_find_custom (data->valid_display_list, - display_name, - display_name_cmp)) - data->valid_display_list = g_list_append (data->valid_display_list, - display_name); - - new_screen = gdk_display_get_default_screen (display); - } - } - else - { - gint number_of_screens = gdk_display_get_n_screens (display); - gint screen_num = gdk_screen_get_number (current_screen); - if ((screen_num +1) < number_of_screens) - new_screen = gdk_display_get_screen (display, screen_num + 1); - else - new_screen = gdk_display_get_screen (display, 0); - } - - if (new_screen) - { - gtk_window_set_screen (GTK_WINDOW (data->toplevel), new_screen); - gtk_widget_destroy (data->dialog_window); - } -} - -void -screen_display_destroy_diag (GtkWidget *widget, GtkWidget *data) -{ - gtk_widget_destroy (data); -} - -void -create_display_screen (GtkWidget *widget) -{ - GtkWidget *table, *frame, *window, *combo_dpy, *vbox; - GtkWidget *radio_dpy, *radio_scr, *applyb, *cancelb; - GtkWidget *bbox; - ScreenDisplaySelection *scr_dpy_data; - GdkScreen *screen = gtk_widget_get_screen (widget); - static GList *valid_display_list = NULL; - - GdkDisplay *display = gdk_screen_get_display (screen); - - window = gtk_widget_new (gtk_window_get_type (), - "screen", screen, - "user_data", NULL, - "type", GTK_WINDOW_TOPLEVEL, - "title", - "Screen or Display selection", - "border_width", 10, NULL); - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroy), NULL); - - vbox = gtk_vbox_new (FALSE, 3); - gtk_container_add (GTK_CONTAINER (window), vbox); - - frame = gtk_frame_new ("Select screen or display"); - gtk_container_add (GTK_CONTAINER (vbox), frame); - - table = gtk_table_new (2, 2, TRUE); - gtk_table_set_row_spacings (GTK_TABLE (table), 3); - gtk_table_set_col_spacings (GTK_TABLE (table), 3); - - gtk_container_add (GTK_CONTAINER (frame), table); - - radio_dpy = gtk_radio_button_new_with_label (NULL, "move to another X display"); - if (gdk_display_get_n_screens(display) > 1) - radio_scr = gtk_radio_button_new_with_label - (gtk_radio_button_get_group (GTK_RADIO_BUTTON (radio_dpy)), "move to next screen"); - else - { - radio_scr = gtk_radio_button_new_with_label - (gtk_radio_button_get_group (GTK_RADIO_BUTTON (radio_dpy)), - "only one screen on the current display"); - gtk_widget_set_sensitive (radio_scr, FALSE); - } - combo_dpy = gtk_combo_new (); - if (!valid_display_list) - valid_display_list = g_list_append (valid_display_list, "diabolo:0.0"); - - gtk_combo_set_popdown_strings (GTK_COMBO (combo_dpy), valid_display_list); - - gtk_entry_set_text (GTK_ENTRY (GTK_COMBO (combo_dpy)->entry), - "<hostname>:<X Server Num>.<Screen Num>"); - - gtk_table_attach_defaults (GTK_TABLE (table), radio_dpy, 0, 1, 0, 1); - gtk_table_attach_defaults (GTK_TABLE (table), radio_scr, 0, 1, 1, 2); - gtk_table_attach_defaults (GTK_TABLE (table), combo_dpy, 1, 2, 0, 1); - - bbox = gtk_hbutton_box_new (); - applyb = gtk_button_new_from_stock (GTK_STOCK_APPLY); - cancelb = gtk_button_new_from_stock (GTK_STOCK_CANCEL); - - gtk_container_add (GTK_CONTAINER (vbox), bbox); - - gtk_container_add (GTK_CONTAINER (bbox), applyb); - gtk_container_add (GTK_CONTAINER (bbox), cancelb); - - scr_dpy_data = g_new0 (ScreenDisplaySelection, 1); - - scr_dpy_data->entry = GTK_ENTRY (GTK_COMBO (combo_dpy)->entry); - scr_dpy_data->radio_dpy = radio_dpy; - scr_dpy_data->toplevel = gtk_widget_get_toplevel (widget); - scr_dpy_data->dialog_window = window; - scr_dpy_data->valid_display_list = valid_display_list; - - g_signal_connect (cancelb, "clicked", - G_CALLBACK (screen_display_destroy_diag), window); - g_signal_connect (applyb, "clicked", - G_CALLBACK (screen_display_check), scr_dpy_data); - gtk_widget_show_all (window); -} - -/* Event Watcher - */ -static gboolean event_watcher_enter_id = 0; -static gboolean event_watcher_leave_id = 0; - -static gboolean -event_watcher (GSignalInvocationHint *ihint, - guint n_param_values, - const GValue *param_values, - gpointer data) -{ - g_print ("Watch: \"%s\" emitted for %s\n", - g_signal_name (ihint->signal_id), - G_OBJECT_TYPE_NAME (g_value_get_object (param_values + 0))); - - return TRUE; -} - -static void -event_watcher_down (void) -{ - if (event_watcher_enter_id) - { - guint signal_id; - - signal_id = g_signal_lookup ("enter_notify_event", GTK_TYPE_WIDGET); - g_signal_remove_emission_hook (signal_id, event_watcher_enter_id); - event_watcher_enter_id = 0; - signal_id = g_signal_lookup ("leave_notify_event", GTK_TYPE_WIDGET); - g_signal_remove_emission_hook (signal_id, event_watcher_leave_id); - event_watcher_leave_id = 0; - } -} - -static void -event_watcher_toggle (void) -{ - if (event_watcher_enter_id) - event_watcher_down (); - else - { - guint signal_id; - - signal_id = g_signal_lookup ("enter_notify_event", GTK_TYPE_WIDGET); - event_watcher_enter_id = g_signal_add_emission_hook (signal_id, 0, event_watcher, NULL, NULL); - signal_id = g_signal_lookup ("leave_notify_event", GTK_TYPE_WIDGET); - event_watcher_leave_id = g_signal_add_emission_hook (signal_id, 0, event_watcher, NULL, NULL); - } -} - -static void -create_event_watcher (GtkWidget *widget) -{ - GtkWidget *button; - - if (!dialog_window) - { - dialog_window = gtk_dialog_new (); - gtk_window_set_screen (GTK_WINDOW (dialog_window), - gtk_widget_get_screen (widget)); - - g_signal_connect (dialog_window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &dialog_window); - g_signal_connect (dialog_window, "destroy", - G_CALLBACK (event_watcher_down), - NULL); - - gtk_window_set_title (GTK_WINDOW (dialog_window), "Event Watcher"); - gtk_container_set_border_width (GTK_CONTAINER (dialog_window), 0); - gtk_widget_set_size_request (dialog_window, 200, 110); - - button = gtk_toggle_button_new_with_label ("Activate Watch"); - g_signal_connect (button, "clicked", - G_CALLBACK (event_watcher_toggle), - NULL); - gtk_container_set_border_width (GTK_CONTAINER (button), 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->vbox), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - dialog_window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (dialog_window)) - gtk_widget_show (dialog_window); - else - gtk_widget_destroy (dialog_window); -} - -/* - * GtkRange - */ - -static gchar* -reformat_value (GtkScale *scale, - gdouble value) -{ - return g_strdup_printf ("-->%0.*g<--", - gtk_scale_get_digits (scale), value); -} - -static void -create_range_controls (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *scrollbar; - GtkWidget *scale; - GtkWidget *separator; - GtkObject *adjustment; - GtkWidget *hbox; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "range controls"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_widget_show (box1); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - gtk_widget_show (box2); - - - adjustment = gtk_adjustment_new (0.0, 0.0, 101.0, 0.1, 1.0, 1.0); - - scale = gtk_hscale_new (GTK_ADJUSTMENT (adjustment)); - gtk_widget_set_size_request (GTK_WIDGET (scale), 150, -1); - gtk_range_set_update_policy (GTK_RANGE (scale), GTK_UPDATE_DELAYED); - gtk_scale_set_digits (GTK_SCALE (scale), 1); - gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE); - gtk_box_pack_start (GTK_BOX (box2), scale, TRUE, TRUE, 0); - gtk_widget_show (scale); - - scrollbar = gtk_hscrollbar_new (GTK_ADJUSTMENT (adjustment)); - gtk_range_set_update_policy (GTK_RANGE (scrollbar), - GTK_UPDATE_CONTINUOUS); - gtk_box_pack_start (GTK_BOX (box2), scrollbar, TRUE, TRUE, 0); - gtk_widget_show (scrollbar); - - scale = gtk_hscale_new (GTK_ADJUSTMENT (adjustment)); - gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE); - g_signal_connect (scale, - "format_value", - G_CALLBACK (reformat_value), - NULL); - gtk_box_pack_start (GTK_BOX (box2), scale, TRUE, TRUE, 0); - gtk_widget_show (scale); - - hbox = gtk_hbox_new (FALSE, 0); - - scale = gtk_vscale_new (GTK_ADJUSTMENT (adjustment)); - gtk_widget_set_size_request (scale, -1, 200); - gtk_scale_set_digits (GTK_SCALE (scale), 2); - gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE); - gtk_box_pack_start (GTK_BOX (hbox), scale, TRUE, TRUE, 0); - gtk_widget_show (scale); - - scale = gtk_vscale_new (GTK_ADJUSTMENT (adjustment)); - gtk_widget_set_size_request (scale, -1, 200); - gtk_scale_set_digits (GTK_SCALE (scale), 2); - gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE); - gtk_range_set_inverted (GTK_RANGE (scale), TRUE); - gtk_box_pack_start (GTK_BOX (hbox), scale, TRUE, TRUE, 0); - gtk_widget_show (scale); - - scale = gtk_vscale_new (GTK_ADJUSTMENT (adjustment)); - gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE); - g_signal_connect (scale, - "format_value", - G_CALLBACK (reformat_value), - NULL); - gtk_box_pack_start (GTK_BOX (hbox), scale, TRUE, TRUE, 0); - gtk_widget_show (scale); - - - gtk_box_pack_start (GTK_BOX (box2), hbox, TRUE, TRUE, 0); - gtk_widget_show (hbox); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - gtk_widget_show (separator); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - gtk_widget_show (box2); - - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkRulers - */ - -void -create_rulers (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *table; - GtkWidget *ruler; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_object_set (window, "allow_shrink", TRUE, "allow_grow", TRUE, NULL); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "rulers"); - gtk_widget_set_size_request (window, 300, 300); - gtk_widget_set_events (window, - GDK_POINTER_MOTION_MASK - | GDK_POINTER_MOTION_HINT_MASK); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - table = gtk_table_new (2, 2, FALSE); - gtk_container_add (GTK_CONTAINER (window), table); - gtk_widget_show (table); - - ruler = gtk_hruler_new (); - gtk_ruler_set_metric (GTK_RULER (ruler), GTK_CENTIMETERS); - gtk_ruler_set_range (GTK_RULER (ruler), 100, 0, 0, 20); - - g_signal_connect_swapped (window, - "motion_notify_event", - G_CALLBACK (GTK_WIDGET_GET_CLASS (ruler)->motion_notify_event), - ruler); - - gtk_table_attach (GTK_TABLE (table), ruler, 1, 2, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0); - gtk_widget_show (ruler); - - - ruler = gtk_vruler_new (); - gtk_ruler_set_range (GTK_RULER (ruler), 5, 15, 0, 20); - - g_signal_connect_swapped (window, - "motion_notify_event", - G_CALLBACK (GTK_WIDGET_GET_CLASS (ruler)->motion_notify_event), - ruler); - - gtk_table_attach (GTK_TABLE (table), ruler, 0, 1, 1, 2, - GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0); - gtk_widget_show (ruler); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -static void -text_toggle_editable (GtkWidget *checkbutton, - GtkWidget *text) -{ - gtk_text_set_editable(GTK_TEXT(text), - GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -static void -text_toggle_word_wrap (GtkWidget *checkbutton, - GtkWidget *text) -{ - gtk_text_set_word_wrap(GTK_TEXT(text), - GTK_TOGGLE_BUTTON(checkbutton)->active); -} - -struct { - GdkColor color; - gchar *name; -} text_colors[] = { - { { 0, 0x0000, 0x0000, 0x0000 }, "black" }, - { { 0, 0xFFFF, 0xFFFF, 0xFFFF }, "white" }, - { { 0, 0xFFFF, 0x0000, 0x0000 }, "red" }, - { { 0, 0x0000, 0xFFFF, 0x0000 }, "green" }, - { { 0, 0x0000, 0x0000, 0xFFFF }, "blue" }, - { { 0, 0x0000, 0xFFFF, 0xFFFF }, "cyan" }, - { { 0, 0xFFFF, 0x0000, 0xFFFF }, "magenta" }, - { { 0, 0xFFFF, 0xFFFF, 0x0000 }, "yellow" } -}; - -int ntext_colors = sizeof(text_colors) / sizeof(text_colors[0]); - -/* - * GtkText - */ -void -text_insert_random (GtkWidget *w, GtkText *text) -{ - int i; - char c; - for (i=0; i<10; i++) - { - c = 'A' + rand() % ('Z' - 'A'); - gtk_text_set_point (text, rand() % gtk_text_get_length (text)); - gtk_text_insert (text, NULL, NULL, NULL, &c, 1); - } -} - -void -create_text (GtkWidget *widget) -{ - int i, j; - - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *hbox; - GtkWidget *button; - GtkWidget *check; - GtkWidget *separator; - GtkWidget *scrolled_window; - GtkWidget *text; - - FILE *infile; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_widget_set_name (window, "text window"); - g_object_set (window, "allow_shrink", TRUE, "allow_grow", TRUE, NULL); - gtk_widget_set_size_request (window, 500, 500); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_widget_show (box1); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0); - gtk_widget_show (box2); - - - scrolled_window = gtk_scrolled_window_new (NULL, NULL); - gtk_box_pack_start (GTK_BOX (box2), scrolled_window, TRUE, TRUE, 0); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), - GTK_POLICY_NEVER, - GTK_POLICY_ALWAYS); - gtk_widget_show (scrolled_window); - - text = gtk_text_new (NULL, NULL); - gtk_text_set_editable (GTK_TEXT (text), TRUE); - gtk_container_add (GTK_CONTAINER (scrolled_window), text); - gtk_widget_grab_focus (text); - gtk_widget_show (text); - - - gtk_text_freeze (GTK_TEXT (text)); - - for (i=0; i<ntext_colors; i++) - { - gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL, - text_colors[i].name, -1); - gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL, "\t", -1); - - for (j=0; j<ntext_colors; j++) - { - gtk_text_insert (GTK_TEXT (text), NULL, - &text_colors[j].color, &text_colors[i].color, - "XYZ", -1); - } - gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL, "\n", -1); - } - - infile = fopen("testgtk.c", "r"); - - if (infile) - { - char *buffer; - int nbytes_read, nbytes_alloc; - - nbytes_read = 0; - nbytes_alloc = 1024; - buffer = g_new (char, nbytes_alloc); - while (1) - { - int len; - if (nbytes_alloc < nbytes_read + 1024) - { - nbytes_alloc *= 2; - buffer = g_realloc (buffer, nbytes_alloc); - } - len = fread (buffer + nbytes_read, 1, 1024, infile); - nbytes_read += len; - if (len < 1024) - break; - } - - gtk_text_insert (GTK_TEXT (text), NULL, NULL, - NULL, buffer, nbytes_read); - g_free(buffer); - fclose (infile); - } - - gtk_text_thaw (GTK_TEXT (text)); - - hbox = gtk_hbutton_box_new (); - gtk_box_pack_start (GTK_BOX (box2), hbox, FALSE, FALSE, 0); - gtk_widget_show (hbox); - - check = gtk_check_button_new_with_label("Editable"); - gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, FALSE, 0); - g_signal_connect (check, "toggled", - G_CALLBACK (text_toggle_editable), text); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(check), TRUE); - gtk_widget_show (check); - - check = gtk_check_button_new_with_label("Wrap Words"); - gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0); - g_signal_connect (check, "toggled", - G_CALLBACK (text_toggle_word_wrap), text); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(check), FALSE); - gtk_widget_show (check); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - gtk_widget_show (separator); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - gtk_widget_show (box2); - - - button = gtk_button_new_with_label ("insert random"); - g_signal_connect (button, "clicked", - G_CALLBACK (text_insert_random), - text); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkNotebook - */ - -GdkPixbuf *book_open; -GdkPixbuf *book_closed; -GtkWidget *sample_notebook; - -static void -set_page_image (GtkNotebook *notebook, gint page_num, GdkPixbuf *pixbuf) -{ - GtkWidget *page_widget; - GtkWidget *pixwid; - - page_widget = gtk_notebook_get_nth_page (notebook, page_num); - - pixwid = g_object_get_data (G_OBJECT (page_widget), "tab_pixmap"); - gtk_image_set_from_pixbuf (GTK_IMAGE (pixwid), pixbuf); - - pixwid = g_object_get_data (G_OBJECT (page_widget), "menu_pixmap"); - gtk_image_set_from_pixbuf (GTK_IMAGE (pixwid), pixbuf); -} - -static void -page_switch (GtkWidget *widget, GtkNotebookPage *page, gint page_num) -{ - GtkNotebook *notebook = GTK_NOTEBOOK (widget); - gint old_page_num = gtk_notebook_get_current_page (notebook); - - if (page_num == old_page_num) - return; - - set_page_image (notebook, page_num, book_open); - - if (old_page_num != -1) - set_page_image (notebook, old_page_num, book_closed); -} - -static void -tab_fill (GtkToggleButton *button, GtkWidget *child) -{ - gboolean expand; - GtkPackType pack_type; - - gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - &expand, NULL, &pack_type); - gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - expand, button->active, pack_type); -} - -static void -tab_expand (GtkToggleButton *button, GtkWidget *child) -{ - gboolean fill; - GtkPackType pack_type; - - gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - NULL, &fill, &pack_type); - gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - button->active, fill, pack_type); -} - -static void -tab_pack (GtkToggleButton *button, GtkWidget *child) - -{ - gboolean expand; - gboolean fill; - - gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - &expand, &fill, NULL); - gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child, - expand, fill, button->active); -} - -static void -create_pages (GtkNotebook *notebook, gint start, gint end) -{ - GtkWidget *child = NULL; - GtkWidget *button; - GtkWidget *label; - GtkWidget *hbox; - GtkWidget *vbox; - GtkWidget *label_box; - GtkWidget *menu_box; - GtkWidget *pixwid; - gint i; - char buffer[32]; - char accel_buffer[32]; - - for (i = start; i <= end; i++) - { - sprintf (buffer, "Page %d", i); - sprintf (accel_buffer, "Page _%d", i); - - child = gtk_frame_new (buffer); - gtk_container_set_border_width (GTK_CONTAINER (child), 10); - - vbox = gtk_vbox_new (TRUE,0); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - gtk_container_add (GTK_CONTAINER (child), vbox); - - hbox = gtk_hbox_new (TRUE,0); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5); - - button = gtk_check_button_new_with_label ("Fill Tab"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - g_signal_connect (button, "toggled", - G_CALLBACK (tab_fill), child); - - button = gtk_check_button_new_with_label ("Expand Tab"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - g_signal_connect (button, "toggled", - G_CALLBACK (tab_expand), child); - - button = gtk_check_button_new_with_label ("Pack end"); - gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5); - g_signal_connect (button, "toggled", - G_CALLBACK (tab_pack), child); - - button = gtk_button_new_with_label ("Hide Page"); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 5); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_hide), - child); - - gtk_widget_show_all (child); - - label_box = gtk_hbox_new (FALSE, 0); - pixwid = gtk_image_new_from_pixbuf (book_closed); - g_object_set_data (G_OBJECT (child), "tab_pixmap", pixwid); - - gtk_box_pack_start (GTK_BOX (label_box), pixwid, FALSE, TRUE, 0); - gtk_misc_set_padding (GTK_MISC (pixwid), 3, 1); - label = gtk_label_new_with_mnemonic (accel_buffer); - gtk_box_pack_start (GTK_BOX (label_box), label, FALSE, TRUE, 0); - gtk_widget_show_all (label_box); - - - menu_box = gtk_hbox_new (FALSE, 0); - pixwid = gtk_image_new_from_pixbuf (book_closed); - g_object_set_data (G_OBJECT (child), "menu_pixmap", pixwid); - - gtk_box_pack_start (GTK_BOX (menu_box), pixwid, FALSE, TRUE, 0); - gtk_misc_set_padding (GTK_MISC (pixwid), 3, 1); - label = gtk_label_new (buffer); - gtk_box_pack_start (GTK_BOX (menu_box), label, FALSE, TRUE, 0); - gtk_widget_show_all (menu_box); - - gtk_notebook_append_page_menu (notebook, child, label_box, menu_box); - } -} - -static void -rotate_notebook (GtkButton *button, - GtkNotebook *notebook) -{ - gtk_notebook_set_tab_pos (notebook, (notebook->tab_pos + 1) % 4); -} - -static void -show_all_pages (GtkButton *button, - GtkNotebook *notebook) -{ - gtk_container_foreach (GTK_CONTAINER (notebook), - (GtkCallback) gtk_widget_show, NULL); -} - -static void -notebook_type_changed (GtkWidget *optionmenu, - gpointer data) -{ - GtkNotebook *notebook; - gint i, c; - - enum { - STANDARD, - NOTABS, - BORDERLESS, - SCROLLABLE - }; - - notebook = GTK_NOTEBOOK (data); - - c = gtk_option_menu_get_history (GTK_OPTION_MENU (optionmenu)); - - switch (c) - { - case STANDARD: - /* standard notebook */ - gtk_notebook_set_show_tabs (notebook, TRUE); - gtk_notebook_set_show_border (notebook, TRUE); - gtk_notebook_set_scrollable (notebook, FALSE); - break; - - case NOTABS: - /* notabs notebook */ - gtk_notebook_set_show_tabs (notebook, FALSE); - gtk_notebook_set_show_border (notebook, TRUE); - break; - - case BORDERLESS: - /* borderless */ - gtk_notebook_set_show_tabs (notebook, FALSE); - gtk_notebook_set_show_border (notebook, FALSE); - break; - - case SCROLLABLE: - /* scrollable */ - gtk_notebook_set_show_tabs (notebook, TRUE); - gtk_notebook_set_show_border (notebook, TRUE); - gtk_notebook_set_scrollable (notebook, TRUE); - if (g_list_length (notebook->children) == 5) - create_pages (notebook, 6, 15); - - return; - break; - } - - if (g_list_length (notebook->children) == 15) - for (i = 0; i < 10; i++) - gtk_notebook_remove_page (notebook, 5); -} - -static void -notebook_popup (GtkToggleButton *button, - GtkNotebook *notebook) -{ - if (button->active) - gtk_notebook_popup_enable (notebook); - else - gtk_notebook_popup_disable (notebook); -} - -static void -notebook_homogeneous (GtkToggleButton *button, - GtkNotebook *notebook) -{ - g_object_set (notebook, "homogeneous", button->active, NULL); -} - -static void -create_notebook (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *button; - GtkWidget *separator; - GtkWidget *omenu; - GtkWidget *label; - - static gchar *items[] = - { - "Standard", - "No tabs", - "Borderless", - "Scrollable" - }; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "notebook"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - sample_notebook = gtk_notebook_new (); - g_signal_connect (sample_notebook, "switch_page", - G_CALLBACK (page_switch), NULL); - gtk_notebook_set_tab_pos (GTK_NOTEBOOK (sample_notebook), GTK_POS_TOP); - gtk_box_pack_start (GTK_BOX (box1), sample_notebook, TRUE, TRUE, 0); - gtk_container_set_border_width (GTK_CONTAINER (sample_notebook), 10); - - gtk_widget_realize (sample_notebook); - - if (!book_open) - book_open = gdk_pixbuf_new_from_xpm_data ((const char **)book_open_xpm); - - if (!book_closed) - book_closed = gdk_pixbuf_new_from_xpm_data ((const char **)book_closed_xpm); - - create_pages (GTK_NOTEBOOK (sample_notebook), 1, 5); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 10); - - box2 = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_check_button_new_with_label ("popup menu"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, FALSE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (notebook_popup), - sample_notebook); - - button = gtk_check_button_new_with_label ("homogeneous tabs"); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, FALSE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (notebook_homogeneous), - sample_notebook); - - box2 = gtk_hbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - label = gtk_label_new ("Notebook Style :"); - gtk_box_pack_start (GTK_BOX (box2), label, FALSE, TRUE, 0); - - omenu = build_option_menu (items, G_N_ELEMENTS (items), 0, - notebook_type_changed, - sample_notebook); - gtk_box_pack_start (GTK_BOX (box2), omenu, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("Show all Pages"); - gtk_box_pack_start (GTK_BOX (box2), button, FALSE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (show_all_pages), sample_notebook); - - box2 = gtk_hbox_new (TRUE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_label ("prev"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_notebook_prev_page), - sample_notebook); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_button_new_with_label ("next"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_notebook_next_page), - sample_notebook); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - button = gtk_button_new_with_label ("rotate"); - g_signal_connect (button, "clicked", - G_CALLBACK (rotate_notebook), sample_notebook); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 5); - - button = gtk_button_new_with_label ("close"); - gtk_container_set_border_width (GTK_CONTAINER (button), 5); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_box_pack_start (GTK_BOX (box1), button, FALSE, FALSE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkPanes - */ - -void -toggle_resize (GtkWidget *widget, GtkWidget *child) -{ - GtkContainer *container = GTK_CONTAINER (gtk_widget_get_parent (child)); - GValue value = { 0, }; - g_value_init (&value, G_TYPE_BOOLEAN); - gtk_container_child_get_property (container, child, "resize", &value); - g_value_set_boolean (&value, !g_value_get_boolean (&value)); - gtk_container_child_set_property (container, child, "resize", &value); -} - -void -toggle_shrink (GtkWidget *widget, GtkWidget *child) -{ - GtkContainer *container = GTK_CONTAINER (gtk_widget_get_parent (child)); - GValue value = { 0, }; - g_value_init (&value, G_TYPE_BOOLEAN); - gtk_container_child_get_property (container, child, "shrink", &value); - g_value_set_boolean (&value, !g_value_get_boolean (&value)); - gtk_container_child_set_property (container, child, "shrink", &value); -} - -static void -paned_props_clicked (GtkWidget *button, - GObject *paned) -{ - GtkWidget *window = create_prop_editor (paned, GTK_TYPE_PANED); - - gtk_window_set_title (GTK_WINDOW (window), "Paned Properties"); -} - -GtkWidget * -create_pane_options (GtkPaned *paned, - const gchar *frame_label, - const gchar *label1, - const gchar *label2) -{ - GtkWidget *frame; - GtkWidget *table; - GtkWidget *label; - GtkWidget *button; - GtkWidget *check_button; - - frame = gtk_frame_new (frame_label); - gtk_container_set_border_width (GTK_CONTAINER (frame), 4); - - table = gtk_table_new (4, 2, 4); - gtk_container_add (GTK_CONTAINER (frame), table); - - label = gtk_label_new (label1); - gtk_table_attach_defaults (GTK_TABLE (table), label, - 0, 1, 0, 1); - - check_button = gtk_check_button_new_with_label ("Resize"); - gtk_table_attach_defaults (GTK_TABLE (table), check_button, - 0, 1, 1, 2); - g_signal_connect (check_button, "toggled", - G_CALLBACK (toggle_resize), - paned->child1); - - check_button = gtk_check_button_new_with_label ("Shrink"); - gtk_table_attach_defaults (GTK_TABLE (table), check_button, - 0, 1, 2, 3); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button), - TRUE); - g_signal_connect (check_button, "toggled", - G_CALLBACK (toggle_shrink), - paned->child1); - - label = gtk_label_new (label2); - gtk_table_attach_defaults (GTK_TABLE (table), label, - 1, 2, 0, 1); - - check_button = gtk_check_button_new_with_label ("Resize"); - gtk_table_attach_defaults (GTK_TABLE (table), check_button, - 1, 2, 1, 2); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button), - TRUE); - g_signal_connect (check_button, "toggled", - G_CALLBACK (toggle_resize), - paned->child2); - - check_button = gtk_check_button_new_with_label ("Shrink"); - gtk_table_attach_defaults (GTK_TABLE (table), check_button, - 1, 2, 2, 3); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button), - TRUE); - g_signal_connect (check_button, "toggled", - G_CALLBACK (toggle_shrink), - paned->child2); - - button = gtk_button_new_with_mnemonic ("_Properties"); - gtk_table_attach_defaults (GTK_TABLE (table), button, - 0, 2, 3, 4); - g_signal_connect (button, "clicked", - G_CALLBACK (paned_props_clicked), - paned); - - return frame; -} - -void -create_panes (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *frame; - GtkWidget *hpaned; - GtkWidget *vpaned; - GtkWidget *button; - GtkWidget *vbox; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Panes"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), vbox); - - vpaned = gtk_vpaned_new (); - gtk_box_pack_start (GTK_BOX (vbox), vpaned, TRUE, TRUE, 0); - gtk_container_set_border_width (GTK_CONTAINER(vpaned), 5); - - hpaned = gtk_hpaned_new (); - gtk_paned_add1 (GTK_PANED (vpaned), hpaned); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN); - gtk_widget_set_size_request (frame, 60, 60); - gtk_paned_add1 (GTK_PANED (hpaned), frame); - - button = gtk_button_new_with_label ("Hi there"); - gtk_container_add (GTK_CONTAINER(frame), button); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN); - gtk_widget_set_size_request (frame, 80, 60); - gtk_paned_add2 (GTK_PANED (hpaned), frame); - - frame = gtk_frame_new (NULL); - gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN); - gtk_widget_set_size_request (frame, 60, 80); - gtk_paned_add2 (GTK_PANED (vpaned), frame); - - /* Now create toggle buttons to control sizing */ - - gtk_box_pack_start (GTK_BOX (vbox), - create_pane_options (GTK_PANED (hpaned), - "Horizontal", - "Left", - "Right"), - FALSE, FALSE, 0); - - gtk_box_pack_start (GTK_BOX (vbox), - create_pane_options (GTK_PANED (vpaned), - "Vertical", - "Top", - "Bottom"), - FALSE, FALSE, 0); - - gtk_widget_show_all (vbox); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Paned keyboard navigation - */ - -static GtkWidget* -paned_keyboard_window1 (GtkWidget *widget) -{ - GtkWidget *window1; - GtkWidget *hpaned1; - GtkWidget *frame1; - GtkWidget *vbox1; - GtkWidget *button7; - GtkWidget *button8; - GtkWidget *button9; - GtkWidget *vpaned1; - GtkWidget *frame2; - GtkWidget *frame5; - GtkWidget *hbox1; - GtkWidget *button5; - GtkWidget *button6; - GtkWidget *frame3; - GtkWidget *frame4; - GtkWidget *table1; - GtkWidget *button1; - GtkWidget *button2; - GtkWidget *button3; - GtkWidget *button4; - - window1 = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_title (GTK_WINDOW (window1), "Basic paned navigation"); - gtk_window_set_screen (GTK_WINDOW (window1), - gtk_widget_get_screen (widget)); - - hpaned1 = gtk_hpaned_new (); - gtk_container_add (GTK_CONTAINER (window1), hpaned1); - - frame1 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (hpaned1), frame1, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame1), GTK_SHADOW_IN); - - vbox1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (frame1), vbox1); - - button7 = gtk_button_new_with_label ("button7"); - gtk_box_pack_start (GTK_BOX (vbox1), button7, FALSE, FALSE, 0); - - button8 = gtk_button_new_with_label ("button8"); - gtk_box_pack_start (GTK_BOX (vbox1), button8, FALSE, FALSE, 0); - - button9 = gtk_button_new_with_label ("button9"); - gtk_box_pack_start (GTK_BOX (vbox1), button9, FALSE, FALSE, 0); - - vpaned1 = gtk_vpaned_new (); - gtk_paned_pack2 (GTK_PANED (hpaned1), vpaned1, TRUE, TRUE); - - frame2 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (vpaned1), frame2, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame2), GTK_SHADOW_IN); - - frame5 = gtk_frame_new (NULL); - gtk_container_add (GTK_CONTAINER (frame2), frame5); - - hbox1 = gtk_hbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (frame5), hbox1); - - button5 = gtk_button_new_with_label ("button5"); - gtk_box_pack_start (GTK_BOX (hbox1), button5, FALSE, FALSE, 0); - - button6 = gtk_button_new_with_label ("button6"); - gtk_box_pack_start (GTK_BOX (hbox1), button6, FALSE, FALSE, 0); - - frame3 = gtk_frame_new (NULL); - gtk_paned_pack2 (GTK_PANED (vpaned1), frame3, TRUE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame3), GTK_SHADOW_IN); - - frame4 = gtk_frame_new ("Buttons"); - gtk_container_add (GTK_CONTAINER (frame3), frame4); - gtk_container_set_border_width (GTK_CONTAINER (frame4), 15); - - table1 = gtk_table_new (2, 2, FALSE); - gtk_container_add (GTK_CONTAINER (frame4), table1); - gtk_container_set_border_width (GTK_CONTAINER (table1), 11); - - button1 = gtk_button_new_with_label ("button1"); - gtk_table_attach (GTK_TABLE (table1), button1, 0, 1, 0, 1, - (GtkAttachOptions) (GTK_FILL), - (GtkAttachOptions) (0), 0, 0); - - button2 = gtk_button_new_with_label ("button2"); - gtk_table_attach (GTK_TABLE (table1), button2, 1, 2, 0, 1, - (GtkAttachOptions) (GTK_FILL), - (GtkAttachOptions) (0), 0, 0); - - button3 = gtk_button_new_with_label ("button3"); - gtk_table_attach (GTK_TABLE (table1), button3, 0, 1, 1, 2, - (GtkAttachOptions) (GTK_FILL), - (GtkAttachOptions) (0), 0, 0); - - button4 = gtk_button_new_with_label ("button4"); - gtk_table_attach (GTK_TABLE (table1), button4, 1, 2, 1, 2, - (GtkAttachOptions) (GTK_FILL), - (GtkAttachOptions) (0), 0, 0); - - return window1; -} - -static GtkWidget* -paned_keyboard_window2 (GtkWidget *widget) -{ - GtkWidget *window2; - GtkWidget *hpaned2; - GtkWidget *frame6; - GtkWidget *button13; - GtkWidget *hbox2; - GtkWidget *vpaned2; - GtkWidget *frame7; - GtkWidget *button12; - GtkWidget *frame8; - GtkWidget *button11; - GtkWidget *button10; - - window2 = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_title (GTK_WINDOW (window2), "\"button 10\" is not inside the horisontal pane"); - - gtk_window_set_screen (GTK_WINDOW (window2), - gtk_widget_get_screen (widget)); - - hpaned2 = gtk_hpaned_new (); - gtk_container_add (GTK_CONTAINER (window2), hpaned2); - - frame6 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (hpaned2), frame6, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame6), GTK_SHADOW_IN); - - button13 = gtk_button_new_with_label ("button13"); - gtk_container_add (GTK_CONTAINER (frame6), button13); - - hbox2 = gtk_hbox_new (FALSE, 0); - gtk_paned_pack2 (GTK_PANED (hpaned2), hbox2, TRUE, TRUE); - - vpaned2 = gtk_vpaned_new (); - gtk_box_pack_start (GTK_BOX (hbox2), vpaned2, TRUE, TRUE, 0); - - frame7 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (vpaned2), frame7, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame7), GTK_SHADOW_IN); - - button12 = gtk_button_new_with_label ("button12"); - gtk_container_add (GTK_CONTAINER (frame7), button12); - - frame8 = gtk_frame_new (NULL); - gtk_paned_pack2 (GTK_PANED (vpaned2), frame8, TRUE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame8), GTK_SHADOW_IN); - - button11 = gtk_button_new_with_label ("button11"); - gtk_container_add (GTK_CONTAINER (frame8), button11); - - button10 = gtk_button_new_with_label ("button10"); - gtk_box_pack_start (GTK_BOX (hbox2), button10, FALSE, FALSE, 0); - - return window2; -} - -static GtkWidget* -paned_keyboard_window3 (GtkWidget *widget) -{ - GtkWidget *window3; - GtkWidget *vbox2; - GtkWidget *label1; - GtkWidget *hpaned3; - GtkWidget *frame9; - GtkWidget *button14; - GtkWidget *hpaned4; - GtkWidget *frame10; - GtkWidget *button15; - GtkWidget *hpaned5; - GtkWidget *frame11; - GtkWidget *button16; - GtkWidget *frame12; - GtkWidget *button17; - - window3 = gtk_window_new (GTK_WINDOW_TOPLEVEL); - g_object_set_data (G_OBJECT (window3), "window3", window3); - gtk_window_set_title (GTK_WINDOW (window3), "Nested panes"); - - gtk_window_set_screen (GTK_WINDOW (window3), - gtk_widget_get_screen (widget)); - - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window3), vbox2); - - label1 = gtk_label_new ("Three panes nested inside each other"); - gtk_box_pack_start (GTK_BOX (vbox2), label1, FALSE, FALSE, 0); - - hpaned3 = gtk_hpaned_new (); - gtk_box_pack_start (GTK_BOX (vbox2), hpaned3, TRUE, TRUE, 0); - - frame9 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (hpaned3), frame9, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame9), GTK_SHADOW_IN); - - button14 = gtk_button_new_with_label ("button14"); - gtk_container_add (GTK_CONTAINER (frame9), button14); - - hpaned4 = gtk_hpaned_new (); - gtk_paned_pack2 (GTK_PANED (hpaned3), hpaned4, TRUE, TRUE); - - frame10 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (hpaned4), frame10, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame10), GTK_SHADOW_IN); - - button15 = gtk_button_new_with_label ("button15"); - gtk_container_add (GTK_CONTAINER (frame10), button15); - - hpaned5 = gtk_hpaned_new (); - gtk_paned_pack2 (GTK_PANED (hpaned4), hpaned5, TRUE, TRUE); - - frame11 = gtk_frame_new (NULL); - gtk_paned_pack1 (GTK_PANED (hpaned5), frame11, FALSE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame11), GTK_SHADOW_IN); - - button16 = gtk_button_new_with_label ("button16"); - gtk_container_add (GTK_CONTAINER (frame11), button16); - - frame12 = gtk_frame_new (NULL); - gtk_paned_pack2 (GTK_PANED (hpaned5), frame12, TRUE, TRUE); - gtk_frame_set_shadow_type (GTK_FRAME (frame12), GTK_SHADOW_IN); - - button17 = gtk_button_new_with_label ("button17"); - gtk_container_add (GTK_CONTAINER (frame12), button17); - - return window3; -} - -static GtkWidget* -paned_keyboard_window4 (GtkWidget *widget) -{ - GtkWidget *window4; - GtkWidget *vbox3; - GtkWidget *label2; - GtkWidget *hpaned6; - GtkWidget *vpaned3; - GtkWidget *button19; - GtkWidget *button18; - GtkWidget *hbox3; - GtkWidget *vpaned4; - GtkWidget *button21; - GtkWidget *button20; - GtkWidget *vpaned5; - GtkWidget *button23; - GtkWidget *button22; - GtkWidget *vpaned6; - GtkWidget *button25; - GtkWidget *button24; - - window4 = gtk_window_new (GTK_WINDOW_TOPLEVEL); - g_object_set_data (G_OBJECT (window4), "window4", window4); - gtk_window_set_title (GTK_WINDOW (window4), "window4"); - - gtk_window_set_screen (GTK_WINDOW (window4), - gtk_widget_get_screen (widget)); - - vbox3 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window4), vbox3); - - label2 = gtk_label_new ("Widget tree:\n\nhpaned \n - vpaned\n - hbox\n - vpaned\n - vpaned\n - vpaned\n"); - gtk_box_pack_start (GTK_BOX (vbox3), label2, FALSE, FALSE, 0); - gtk_label_set_justify (GTK_LABEL (label2), GTK_JUSTIFY_LEFT); - - hpaned6 = gtk_hpaned_new (); - gtk_box_pack_start (GTK_BOX (vbox3), hpaned6, TRUE, TRUE, 0); - - vpaned3 = gtk_vpaned_new (); - gtk_paned_pack1 (GTK_PANED (hpaned6), vpaned3, FALSE, TRUE); - - button19 = gtk_button_new_with_label ("button19"); - gtk_paned_pack1 (GTK_PANED (vpaned3), button19, FALSE, TRUE); - - button18 = gtk_button_new_with_label ("button18"); - gtk_paned_pack2 (GTK_PANED (vpaned3), button18, TRUE, TRUE); - - hbox3 = gtk_hbox_new (FALSE, 0); - gtk_paned_pack2 (GTK_PANED (hpaned6), hbox3, TRUE, TRUE); - - vpaned4 = gtk_vpaned_new (); - gtk_box_pack_start (GTK_BOX (hbox3), vpaned4, TRUE, TRUE, 0); - - button21 = gtk_button_new_with_label ("button21"); - gtk_paned_pack1 (GTK_PANED (vpaned4), button21, FALSE, TRUE); - - button20 = gtk_button_new_with_label ("button20"); - gtk_paned_pack2 (GTK_PANED (vpaned4), button20, TRUE, TRUE); - - vpaned5 = gtk_vpaned_new (); - gtk_box_pack_start (GTK_BOX (hbox3), vpaned5, TRUE, TRUE, 0); - - button23 = gtk_button_new_with_label ("button23"); - gtk_paned_pack1 (GTK_PANED (vpaned5), button23, FALSE, TRUE); - - button22 = gtk_button_new_with_label ("button22"); - gtk_paned_pack2 (GTK_PANED (vpaned5), button22, TRUE, TRUE); - - vpaned6 = gtk_vpaned_new (); - gtk_box_pack_start (GTK_BOX (hbox3), vpaned6, TRUE, TRUE, 0); - - button25 = gtk_button_new_with_label ("button25"); - gtk_paned_pack1 (GTK_PANED (vpaned6), button25, FALSE, TRUE); - - button24 = gtk_button_new_with_label ("button24"); - gtk_paned_pack2 (GTK_PANED (vpaned6), button24, TRUE, TRUE); - - return window4; -} - -static void -create_paned_keyboard_navigation (GtkWidget *widget) -{ - static GtkWidget *window1 = NULL; - static GtkWidget *window2 = NULL; - static GtkWidget *window3 = NULL; - static GtkWidget *window4 = NULL; - - if (window1 && - (gtk_widget_get_screen (window1) != gtk_widget_get_screen (widget))) - { - gtk_widget_destroy (window1); - gtk_widget_destroy (window2); - gtk_widget_destroy (window3); - gtk_widget_destroy (window4); - } - - if (!window1) - { - window1 = paned_keyboard_window1 (widget); - g_signal_connect (window1, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window1); - } - - if (!window2) - { - window2 = paned_keyboard_window2 (widget); - g_signal_connect (window2, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window2); - } - - if (!window3) - { - window3 = paned_keyboard_window3 (widget); - g_signal_connect (window3, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window3); - } - - if (!window4) - { - window4 = paned_keyboard_window4 (widget); - g_signal_connect (window4, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window4); - } - - if (GTK_WIDGET_VISIBLE (window1)) - gtk_widget_destroy (GTK_WIDGET (window1)); - else - gtk_widget_show_all (GTK_WIDGET (window1)); - - if (GTK_WIDGET_VISIBLE (window2)) - gtk_widget_destroy (GTK_WIDGET (window2)); - else - gtk_widget_show_all (GTK_WIDGET (window2)); - - if (GTK_WIDGET_VISIBLE (window3)) - gtk_widget_destroy (GTK_WIDGET (window3)); - else - gtk_widget_show_all (GTK_WIDGET (window3)); - - if (GTK_WIDGET_VISIBLE (window4)) - gtk_widget_destroy (GTK_WIDGET (window4)); - else - gtk_widget_show_all (GTK_WIDGET (window4)); -} - - -/* - * Shaped Windows - */ - -typedef struct _cursoroffset {gint x,y;} CursorOffset; - -static void -shape_pressed (GtkWidget *widget, GdkEventButton *event) -{ - CursorOffset *p; - - /* ignore double and triple click */ - if (event->type != GDK_BUTTON_PRESS) - return; - - p = g_object_get_data (G_OBJECT (widget), "cursor_offset"); - p->x = (int) event->x; - p->y = (int) event->y; - - gtk_grab_add (widget); - gdk_pointer_grab (widget->window, TRUE, - GDK_BUTTON_RELEASE_MASK | - GDK_BUTTON_MOTION_MASK | - GDK_POINTER_MOTION_HINT_MASK, - NULL, NULL, 0); -} - -static void -shape_released (GtkWidget *widget) -{ - gtk_grab_remove (widget); - gdk_display_pointer_ungrab (gtk_widget_get_display (widget), - GDK_CURRENT_TIME); -} - -static void -shape_motion (GtkWidget *widget, - GdkEventMotion *event) -{ - gint xp, yp; - CursorOffset * p; - GdkModifierType mask; - - p = g_object_get_data (G_OBJECT (widget), "cursor_offset"); - - /* - * Can't use event->x / event->y here - * because I need absolute coordinates. - */ - gdk_window_get_pointer (NULL, &xp, &yp, &mask); - gtk_widget_set_uposition (widget, xp - p->x, yp - p->y); -} - -GtkWidget * -shape_create_icon (GdkScreen *screen, - char *xpm_file, - gint x, - gint y, - gint px, - gint py, - gint window_type) -{ - GtkWidget *window; - GtkWidget *pixmap; - GtkWidget *fixed; - CursorOffset* icon_pos; - GdkGC* gc; - GdkBitmap *gdk_pixmap_mask; - GdkPixmap *gdk_pixmap; - GtkStyle *style; - - style = gtk_widget_get_default_style (); - gc = style->black_gc; - - /* - * GDK_WINDOW_TOPLEVEL works also, giving you a title border - */ - window = gtk_window_new (window_type); - gtk_window_set_screen (GTK_WINDOW (window), screen); - - fixed = gtk_fixed_new (); - gtk_widget_set_size_request (fixed, 100, 100); - gtk_container_add (GTK_CONTAINER (window), fixed); - gtk_widget_show (fixed); - - gtk_widget_set_events (window, - gtk_widget_get_events (window) | - GDK_BUTTON_MOTION_MASK | - GDK_POINTER_MOTION_HINT_MASK | - GDK_BUTTON_PRESS_MASK); - - gtk_widget_realize (window); - gdk_pixmap = gdk_pixmap_create_from_xpm (window->window, &gdk_pixmap_mask, - &style->bg[GTK_STATE_NORMAL], - xpm_file); - - pixmap = gtk_image_new_from_pixmap (gdk_pixmap, gdk_pixmap_mask); - gtk_fixed_put (GTK_FIXED (fixed), pixmap, px,py); - gtk_widget_show (pixmap); - - gtk_widget_shape_combine_mask (window, gdk_pixmap_mask, px, py); - - g_object_unref (gdk_pixmap_mask); - g_object_unref (gdk_pixmap); - - g_signal_connect (window, "button_press_event", - G_CALLBACK (shape_pressed), NULL); - g_signal_connect (window, "button_release_event", - G_CALLBACK (shape_released), NULL); - g_signal_connect (window, "motion_notify_event", - G_CALLBACK (shape_motion), NULL); - - icon_pos = g_new (CursorOffset, 1); - g_object_set_data (G_OBJECT (window), "cursor_offset", icon_pos); - - gtk_widget_set_uposition (window, x, y); - gtk_widget_show (window); - - return window; -} - -void -create_shapes (GtkWidget *widget) -{ - /* Variables used by the Drag/Drop and Shape Window demos */ - static GtkWidget *modeller = NULL; - static GtkWidget *sheets = NULL; - static GtkWidget *rings = NULL; - static GtkWidget *with_region = NULL; - GdkScreen *screen = gtk_widget_get_screen (widget); - - if (!(file_exists ("Modeller.xpm") && - file_exists ("FilesQueue.xpm") && - file_exists ("3DRings.xpm"))) - return; - - - if (!modeller) - { - modeller = shape_create_icon (screen, "Modeller.xpm", - 440, 140, 0,0, GTK_WINDOW_POPUP); - - g_signal_connect (modeller, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &modeller); - } - else - gtk_widget_destroy (modeller); - - if (!sheets) - { - sheets = shape_create_icon (screen, "FilesQueue.xpm", - 580, 170, 0,0, GTK_WINDOW_POPUP); - - g_signal_connect (sheets, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &sheets); - - } - else - gtk_widget_destroy (sheets); - - if (!rings) - { - rings = shape_create_icon (screen, "3DRings.xpm", - 460, 270, 25,25, GTK_WINDOW_TOPLEVEL); - - g_signal_connect (rings, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &rings); - } - else - gtk_widget_destroy (rings); - - if (!with_region) - { - GdkRegion *region; - gint x, y; - - with_region = shape_create_icon (screen, "3DRings.xpm", - 460, 270, 25,25, GTK_WINDOW_TOPLEVEL); - - gtk_window_set_decorated (GTK_WINDOW (with_region), FALSE); - - g_signal_connect (with_region, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &with_region); - - /* reset shape from mask to a region */ - x = 0; - y = 0; - region = gdk_region_new (); - - while (x < 460) - { - while (y < 270) - { - GdkRectangle rect; - rect.x = x; - rect.y = y; - rect.width = 10; - rect.height = 10; - - gdk_region_union_with_rect (region, &rect); - - y += 20; - } - y = 0; - x += 20; - } - - gdk_window_shape_combine_region (with_region->window, - region, - 0, 0); - } - else - gtk_widget_destroy (with_region); -} - -/* - * WM Hints demo - */ - -void -create_wmhints (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *label; - GtkWidget *separator; - GtkWidget *button; - GtkWidget *box1; - GtkWidget *box2; - - GdkBitmap *circles; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "WM Hints"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - gtk_widget_realize (window); - - circles = gdk_bitmap_create_from_data (window->window, - circles_bits, - circles_width, - circles_height); - gdk_window_set_icon (window->window, NULL, - circles, circles); - - gdk_window_set_icon_name (window->window, "WMHints Test Icon"); - - gdk_window_set_decorations (window->window, GDK_DECOR_ALL | GDK_DECOR_MENU); - gdk_window_set_functions (window->window, GDK_FUNC_ALL | GDK_FUNC_RESIZE); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - gtk_widget_show (box1); - - label = gtk_label_new ("Try iconizing me!"); - gtk_widget_set_size_request (label, 150, 50); - gtk_box_pack_start (GTK_BOX (box1), label, TRUE, TRUE, 0); - gtk_widget_show (label); - - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - gtk_widget_show (separator); - - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - gtk_widget_show (box2); - - - button = gtk_button_new_with_label ("close"); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - - -/* - * Window state tracking - */ - -static gint -window_state_callback (GtkWidget *widget, - GdkEventWindowState *event, - gpointer data) -{ - GtkWidget *label = data; - gchar *msg; - - msg = g_strconcat (GTK_WINDOW (widget)->title, ": ", - (event->new_window_state & GDK_WINDOW_STATE_WITHDRAWN) ? - "withdrawn" : "not withdrawn", ", ", - (event->new_window_state & GDK_WINDOW_STATE_ICONIFIED) ? - "iconified" : "not iconified", ", ", - (event->new_window_state & GDK_WINDOW_STATE_STICKY) ? - "sticky" : "not sticky", ", ", - (event->new_window_state & GDK_WINDOW_STATE_MAXIMIZED) ? - "maximized" : "not maximized", ", ", - (event->new_window_state & GDK_WINDOW_STATE_FULLSCREEN) ? - "fullscreen" : "not fullscreen", - (event->new_window_state & GDK_WINDOW_STATE_ABOVE) ? - "above" : "not above", ", ", - (event->new_window_state & GDK_WINDOW_STATE_BELOW) ? - "below" : "not below", ", ", - NULL); - - gtk_label_set_text (GTK_LABEL (label), msg); - - g_free (msg); - - return FALSE; -} - -static GtkWidget* -tracking_label (GtkWidget *window) -{ - GtkWidget *label; - GtkWidget *hbox; - GtkWidget *button; - - hbox = gtk_hbox_new (FALSE, 5); - - g_signal_connect_object (hbox, - "destroy", - G_CALLBACK (gtk_widget_destroy), - window, - G_CONNECT_SWAPPED); - - label = gtk_label_new ("<no window state events received>"); - gtk_label_set_line_wrap (GTK_LABEL (label), TRUE); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0); - - g_signal_connect (window, - "window_state_event", - G_CALLBACK (window_state_callback), - label); - - button = gtk_button_new_with_label ("Deiconify"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_deiconify), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Iconify"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_iconify), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Fullscreen"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_fullscreen), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unfullscreen"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_unfullscreen), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Present"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_present), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Show"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_widget_show), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0); - - gtk_widget_show_all (hbox); - - return hbox; -} - -void -keep_window_above (GtkToggleButton *togglebutton, gpointer data) -{ - GtkWidget *button = g_object_get_data (G_OBJECT (togglebutton), "radio"); - - gtk_window_set_keep_above (GTK_WINDOW (data), - gtk_toggle_button_get_active (togglebutton)); - - if (gtk_toggle_button_get_active (togglebutton)) - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), FALSE); -} - -void -keep_window_below (GtkToggleButton *togglebutton, gpointer data) -{ - GtkWidget *button = g_object_get_data (G_OBJECT (togglebutton), "radio"); - - gtk_window_set_keep_below (GTK_WINDOW (data), - gtk_toggle_button_get_active (togglebutton)); - - if (gtk_toggle_button_get_active (togglebutton)) - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), FALSE); -} - - -static GtkWidget* -get_state_controls (GtkWidget *window) -{ - GtkWidget *vbox; - GtkWidget *button; - GtkWidget *button_above; - GtkWidget *button_below; - - vbox = gtk_vbox_new (FALSE, 0); - - button = gtk_button_new_with_label ("Stick"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_stick), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unstick"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_unstick), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Maximize"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_maximize), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unmaximize"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_unmaximize), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Iconify"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_iconify), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Fullscreen"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_fullscreen), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unfullscreen"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_unfullscreen), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button_above = gtk_toggle_button_new_with_label ("Keep above"); - g_signal_connect (button_above, - "toggled", - G_CALLBACK (keep_window_above), - window); - gtk_box_pack_start (GTK_BOX (vbox), button_above, FALSE, FALSE, 0); - - button_below = gtk_toggle_button_new_with_label ("Keep below"); - g_signal_connect (button_below, - "toggled", - G_CALLBACK (keep_window_below), - window); - gtk_box_pack_start (GTK_BOX (vbox), button_below, FALSE, FALSE, 0); - - g_object_set_data (G_OBJECT (button_above), "radio", button_below); - g_object_set_data (G_OBJECT (button_below), "radio", button_above); - - button = gtk_button_new_with_label ("Hide (withdraw)"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_widget_hide), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - gtk_widget_show_all (vbox); - - return vbox; -} - -void -create_window_states (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *label; - GtkWidget *box1; - GtkWidget *iconified; - GtkWidget *normal; - GtkWidget *controls; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Window states"); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - iconified = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (iconified), - gtk_widget_get_screen (widget)); - - g_signal_connect_object (iconified, "destroy", - G_CALLBACK (gtk_widget_destroy), - window, - G_CONNECT_SWAPPED); - gtk_window_iconify (GTK_WINDOW (iconified)); - gtk_window_set_title (GTK_WINDOW (iconified), "Iconified initially"); - controls = get_state_controls (iconified); - gtk_container_add (GTK_CONTAINER (iconified), controls); - - normal = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (normal), - gtk_widget_get_screen (widget)); - - g_signal_connect_object (normal, "destroy", - G_CALLBACK (gtk_widget_destroy), - window, - G_CONNECT_SWAPPED); - - gtk_window_set_title (GTK_WINDOW (normal), "Deiconified initially"); - controls = get_state_controls (normal); - gtk_container_add (GTK_CONTAINER (normal), controls); - - label = tracking_label (iconified); - gtk_container_add (GTK_CONTAINER (box1), label); - - label = tracking_label (normal); - gtk_container_add (GTK_CONTAINER (box1), label); - - gtk_widget_show_all (iconified); - gtk_widget_show_all (normal); - gtk_widget_show_all (box1); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Window sizing - */ - -static gint -configure_event_callback (GtkWidget *widget, - GdkEventConfigure *event, - gpointer data) -{ - GtkWidget *label = data; - gchar *msg; - gint x, y; - - gtk_window_get_position (GTK_WINDOW (widget), &x, &y); - - msg = g_strdup_printf ("event: %d,%d %d x %d\n" - "position: %d, %d", - event->x, event->y, event->width, event->height, - x, y); - - gtk_label_set_text (GTK_LABEL (label), msg); - - g_free (msg); - - return FALSE; -} - -static void -get_ints (GtkWidget *window, - gint *a, - gint *b) -{ - GtkWidget *spin1; - GtkWidget *spin2; - - spin1 = g_object_get_data (G_OBJECT (window), "spin1"); - spin2 = g_object_get_data (G_OBJECT (window), "spin2"); - - *a = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin1)); - *b = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin2)); -} - -static void -set_size_callback (GtkWidget *widget, - gpointer data) -{ - gint w, h; - - get_ints (data, &w, &h); - - gtk_window_resize (GTK_WINDOW (g_object_get_data (data, "target")), w, h); -} - -static void -unset_default_size_callback (GtkWidget *widget, - gpointer data) -{ - gtk_window_set_default_size (g_object_get_data (data, "target"), - -1, -1); -} - -static void -set_default_size_callback (GtkWidget *widget, - gpointer data) -{ - gint w, h; - - get_ints (data, &w, &h); - - gtk_window_set_default_size (g_object_get_data (data, "target"), - w, h); -} - -static void -unset_size_request_callback (GtkWidget *widget, - gpointer data) -{ - gtk_widget_set_size_request (g_object_get_data (data, "target"), - -1, -1); -} - -static void -set_size_request_callback (GtkWidget *widget, - gpointer data) -{ - gint w, h; - - get_ints (data, &w, &h); - - gtk_widget_set_size_request (g_object_get_data (data, "target"), - w, h); -} - -static void -set_location_callback (GtkWidget *widget, - gpointer data) -{ - gint x, y; - - get_ints (data, &x, &y); - - gtk_window_move (g_object_get_data (data, "target"), x, y); -} - -static void -move_to_position_callback (GtkWidget *widget, - gpointer data) -{ - gint x, y; - GtkWindow *window; - - window = g_object_get_data (data, "target"); - - gtk_window_get_position (window, &x, &y); - - gtk_window_move (window, x, y); -} - -static void -set_geometry_callback (GtkWidget *entry, - gpointer data) -{ - gchar *text; - GtkWindow *target; - - target = GTK_WINDOW (g_object_get_data (G_OBJECT (data), "target")); - - text = gtk_editable_get_chars (GTK_EDITABLE (entry), 0, -1); - - if (!gtk_window_parse_geometry (target, text)) - g_print ("Bad geometry string '%s'\n", text); - - g_free (text); -} - -static void -allow_shrink_callback (GtkWidget *widget, - gpointer data) -{ - g_object_set (g_object_get_data (data, "target"), - "allow_shrink", - GTK_TOGGLE_BUTTON (widget)->active, - NULL); -} - -static void -allow_grow_callback (GtkWidget *widget, - gpointer data) -{ - g_object_set (g_object_get_data (data, "target"), - "allow_grow", - GTK_TOGGLE_BUTTON (widget)->active, - NULL); -} - -static void -gravity_selected (GtkWidget *widget, - gpointer data) -{ - gtk_window_set_gravity (GTK_WINDOW (g_object_get_data (data, "target")), - gtk_option_menu_get_history (GTK_OPTION_MENU (widget)) + GDK_GRAVITY_NORTH_WEST); -} - -static void -pos_selected (GtkWidget *widget, - gpointer data) -{ - gtk_window_set_position (GTK_WINDOW (g_object_get_data (data, "target")), - gtk_option_menu_get_history (GTK_OPTION_MENU (widget)) + GTK_WIN_POS_NONE); -} - -static void -move_gravity_window_to_current_position (GtkWidget *widget, - gpointer data) -{ - gint x, y; - GtkWindow *window; - - window = GTK_WINDOW (data); - - gtk_window_get_position (window, &x, &y); - - gtk_window_move (window, x, y); -} - -static void -get_screen_corner (GtkWindow *window, - gint *x, - gint *y) -{ - int w, h; - GdkScreen * screen = gtk_window_get_screen (window); - - gtk_window_get_size (GTK_WINDOW (window), &w, &h); - - switch (gtk_window_get_gravity (window)) - { - case GDK_GRAVITY_SOUTH_EAST: - *x = gdk_screen_get_width (screen) - w; - *y = gdk_screen_get_height (screen) - h; - break; - - case GDK_GRAVITY_NORTH_EAST: - *x = gdk_screen_get_width (screen) - w; - *y = 0; - break; - - case GDK_GRAVITY_SOUTH_WEST: - *x = 0; - *y = gdk_screen_get_height (screen) - h; - break; - - case GDK_GRAVITY_NORTH_WEST: - *x = 0; - *y = 0; - break; - - case GDK_GRAVITY_SOUTH: - *x = (gdk_screen_get_width (screen) - w) / 2; - *y = gdk_screen_get_height (screen) - h; - break; - - case GDK_GRAVITY_NORTH: - *x = (gdk_screen_get_width (screen) - w) / 2; - *y = 0; - break; - - case GDK_GRAVITY_WEST: - *x = 0; - *y = (gdk_screen_get_height (screen) - h) / 2; - break; - - case GDK_GRAVITY_EAST: - *x = gdk_screen_get_width (screen) - w; - *y = (gdk_screen_get_height (screen) - h) / 2; - break; - - case GDK_GRAVITY_CENTER: - *x = (gdk_screen_get_width (screen) - w) / 2; - *y = (gdk_screen_get_height (screen) - h) / 2; - break; - - case GDK_GRAVITY_STATIC: - /* pick some random numbers */ - *x = 350; - *y = 350; - break; - - default: - g_assert_not_reached (); - break; - } -} - -static void -move_gravity_window_to_starting_position (GtkWidget *widget, - gpointer data) -{ - gint x, y; - GtkWindow *window; - - window = GTK_WINDOW (data); - - get_screen_corner (window, - &x, &y); - - gtk_window_move (window, x, y); -} - -static GtkWidget* -make_gravity_window (GtkWidget *destroy_with, - GdkGravity gravity, - const gchar *title) +int +main (int argc, char *argv[]) { - GtkWidget *window; - GtkWidget *button; - GtkWidget *vbox; - int x, y; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (destroy_with)); + gtk_init (&argc, &argv); - vbox = gtk_vbox_new (FALSE, 0); - gtk_widget_show (vbox); - + GtkWidget *window = gtk_window_new (GTK_WINDOW_TOPLEVEL); + GtkWidget *vbox = gtk_vbox_new (FALSE, 0); gtk_container_add (GTK_CONTAINER (window), vbox); - gtk_window_set_title (GTK_WINDOW (window), title); - gtk_window_set_gravity (GTK_WINDOW (window), gravity); - - g_signal_connect_object (destroy_with, - "destroy", - G_CALLBACK (gtk_widget_destroy), - window, - G_CONNECT_SWAPPED); - - - button = gtk_button_new_with_mnemonic ("_Move to current position"); - - g_signal_connect (button, "clicked", - G_CALLBACK (move_gravity_window_to_current_position), - window); - - gtk_container_add (GTK_CONTAINER (vbox), button); - gtk_widget_show (button); - - button = gtk_button_new_with_mnemonic ("Move to _starting position"); - - g_signal_connect (button, "clicked", - G_CALLBACK (move_gravity_window_to_starting_position), - window); - - gtk_container_add (GTK_CONTAINER (vbox), button); - gtk_widget_show (button); - - /* Pretend this is the result of --geometry. - * DO NOT COPY THIS CODE unless you are setting --geometry results, - * and in that case you probably should just use gtk_window_parse_geometry(). - * AGAIN, DO NOT SET GDK_HINT_USER_POS! It violates the ICCCM unless - * you are parsing --geometry or equivalent. - */ - gtk_window_set_geometry_hints (GTK_WINDOW (window), - NULL, NULL, - GDK_HINT_USER_POS); - - gtk_window_set_default_size (GTK_WINDOW (window), - 200, 200); - - get_screen_corner (GTK_WINDOW (window), &x, &y); - - gtk_window_move (GTK_WINDOW (window), - x, y); - - return window; -} - -static void -do_gravity_test (GtkWidget *widget, - gpointer data) -{ - GtkWidget *destroy_with = data; - GtkWidget *window; - - /* We put a window at each gravity point on the screen. */ - window = make_gravity_window (destroy_with, GDK_GRAVITY_NORTH_WEST, - "NorthWest"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_SOUTH_EAST, - "SouthEast"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_NORTH_EAST, - "NorthEast"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_SOUTH_WEST, - "SouthWest"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_SOUTH, - "South"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_NORTH, - "North"); - gtk_widget_show (window); - - - window = make_gravity_window (destroy_with, GDK_GRAVITY_WEST, - "West"); - gtk_widget_show (window); - - - window = make_gravity_window (destroy_with, GDK_GRAVITY_EAST, - "East"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_CENTER, - "Center"); - gtk_widget_show (window); - - window = make_gravity_window (destroy_with, GDK_GRAVITY_STATIC, - "Static"); - gtk_widget_show (window); -} - -static GtkWidget* -window_controls (GtkWidget *window) -{ - GtkWidget *control_window; - GtkWidget *label; - GtkWidget *vbox; - GtkWidget *button; - GtkWidget *spin; - GtkAdjustment *adj; - GtkWidget *entry; - GtkWidget *om; - GtkWidget *menu; - gint i; - - control_window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (control_window), - gtk_widget_get_screen (window)); - - gtk_window_set_title (GTK_WINDOW (control_window), "Size controls"); - - g_object_set_data (G_OBJECT (control_window), - "target", - window); - - g_signal_connect_object (control_window, - "destroy", - G_CALLBACK (gtk_widget_destroy), - window, - G_CONNECT_SWAPPED); - - vbox = gtk_vbox_new (FALSE, 5); - - gtk_container_add (GTK_CONTAINER (control_window), vbox); - - label = gtk_label_new ("<no configure events>"); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - g_signal_connect (window, - "configure_event", - G_CALLBACK (configure_event_callback), - label); - - adj = (GtkAdjustment *) gtk_adjustment_new (10.0, -2000.0, 2000.0, 1.0, - 5.0, 0.0); - spin = gtk_spin_button_new (adj, 0, 0); - - gtk_box_pack_start (GTK_BOX (vbox), spin, FALSE, FALSE, 0); - - g_object_set_data (G_OBJECT (control_window), "spin1", spin); - - adj = (GtkAdjustment *) gtk_adjustment_new (10.0, -2000.0, 2000.0, 1.0, - 5.0, 0.0); - spin = gtk_spin_button_new (adj, 0, 0); - - gtk_box_pack_start (GTK_BOX (vbox), spin, FALSE, FALSE, 0); - - g_object_set_data (G_OBJECT (control_window), "spin2", spin); - - entry = gtk_entry_new (); - gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0); - - g_signal_connect (entry, "changed", - G_CALLBACK (set_geometry_callback), - control_window); - - button = gtk_button_new_with_label ("Show gravity test windows"); - g_signal_connect_swapped (button, - "clicked", - G_CALLBACK (do_gravity_test), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Reshow with initial size"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_window_reshow_with_initial_size), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Queue resize"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_widget_queue_resize), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Resize"); - g_signal_connect (button, - "clicked", - G_CALLBACK (set_size_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Set default size"); - g_signal_connect (button, - "clicked", - G_CALLBACK (set_default_size_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unset default size"); - g_signal_connect (button, - "clicked", - G_CALLBACK (unset_default_size_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Set size request"); - g_signal_connect (button, - "clicked", - G_CALLBACK (set_size_request_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Unset size request"); - g_signal_connect (button, - "clicked", - G_CALLBACK (unset_size_request_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Move"); - g_signal_connect (button, - "clicked", - G_CALLBACK (set_location_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Move to current position"); - g_signal_connect (button, - "clicked", - G_CALLBACK (move_to_position_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_check_button_new_with_label ("Allow shrink"); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), FALSE); - g_signal_connect (button, - "toggled", - G_CALLBACK (allow_shrink_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_check_button_new_with_label ("Allow grow"); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE); - g_signal_connect (button, - "toggled", - G_CALLBACK (allow_grow_callback), - control_window); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_mnemonic ("_Show"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_widget_show), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - button = gtk_button_new_with_mnemonic ("_Hide"); - g_signal_connect_object (button, - "clicked", - G_CALLBACK (gtk_widget_hide), - window, - G_CONNECT_SWAPPED); - gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - menu = gtk_menu_new (); - - i = 0; - while (i < 10) - { - GtkWidget *mi; - static gchar *names[] = { - "GDK_GRAVITY_NORTH_WEST", - "GDK_GRAVITY_NORTH", - "GDK_GRAVITY_NORTH_EAST", - "GDK_GRAVITY_WEST", - "GDK_GRAVITY_CENTER", - "GDK_GRAVITY_EAST", - "GDK_GRAVITY_SOUTH_WEST", - "GDK_GRAVITY_SOUTH", - "GDK_GRAVITY_SOUTH_EAST", - "GDK_GRAVITY_STATIC", - NULL - }; - - g_assert (names[i]); - - mi = gtk_menu_item_new_with_label (names[i]); - - gtk_menu_shell_append (GTK_MENU_SHELL (menu), mi); - - ++i; - } - - gtk_widget_show_all (menu); - - om = gtk_option_menu_new (); - gtk_option_menu_set_menu (GTK_OPTION_MENU (om), menu); - - - g_signal_connect (om, - "changed", - G_CALLBACK (gravity_selected), - control_window); - - gtk_box_pack_end (GTK_BOX (vbox), om, FALSE, FALSE, 0); - - - menu = gtk_menu_new (); - - i = 0; - while (i < 5) - { - GtkWidget *mi; - static gchar *names[] = { - "GTK_WIN_POS_NONE", - "GTK_WIN_POS_CENTER", - "GTK_WIN_POS_MOUSE", - "GTK_WIN_POS_CENTER_ALWAYS", - "GTK_WIN_POS_CENTER_ON_PARENT", - NULL - }; - - g_assert (names[i]); - - mi = gtk_menu_item_new_with_label (names[i]); - - gtk_menu_shell_append (GTK_MENU_SHELL (menu), mi); - - ++i; - } - - gtk_widget_show_all (menu); - - om = gtk_option_menu_new (); - gtk_option_menu_set_menu (GTK_OPTION_MENU (om), menu); - - - g_signal_connect (om, - "changed", - G_CALLBACK (pos_selected), - control_window); - - gtk_box_pack_end (GTK_BOX (vbox), om, FALSE, FALSE, 0); - - gtk_widget_show_all (vbox); - - return control_window; -} - -void -create_window_sizing (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - static GtkWidget *target_window = NULL; - - if (!target_window) - { - GtkWidget *label; - - target_window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (target_window), - gtk_widget_get_screen (widget)); - label = gtk_label_new (NULL); - gtk_label_set_markup (GTK_LABEL (label), "<span foreground=\"purple\"><big>Window being resized</big></span>\nBlah blah blah blah\nblah blah blah\nblah blah blah blah blah"); - gtk_container_add (GTK_CONTAINER (target_window), label); - gtk_widget_show (label); - - g_signal_connect (target_window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &target_window); - - window = window_controls (target_window); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (target_window), "Window to size"); - } - - /* don't show target window by default, we want to allow testing - * of behavior on first show. - */ - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * GtkProgressBar - */ - -typedef struct _ProgressData { - GtkWidget *window; - GtkWidget *pbar; - GtkWidget *block_spin; - GtkWidget *x_align_spin; - GtkWidget *y_align_spin; - GtkWidget *step_spin; - GtkWidget *act_blocks_spin; - GtkWidget *label; - GtkWidget *omenu1; - GtkWidget *elmenu; - GtkWidget *omenu2; - GtkWidget *entry; - int timer; -} ProgressData; - -gint -progress_timeout (gpointer data) -{ - gdouble new_val; - GtkAdjustment *adj; - - adj = GTK_PROGRESS (data)->adjustment; - - new_val = adj->value + 1; - if (new_val > adj->upper) - new_val = adj->lower; - - gtk_progress_set_value (GTK_PROGRESS (data), new_val); - - return TRUE; -} - -static void -destroy_progress (GtkWidget *widget, - ProgressData **pdata) -{ - gtk_timeout_remove ((*pdata)->timer); - (*pdata)->timer = 0; - (*pdata)->window = NULL; - g_free (*pdata); - *pdata = NULL; -} - -static void -progressbar_toggle_orientation (GtkWidget *widget, gpointer data) -{ - ProgressData *pdata; - gint i; - - pdata = (ProgressData *) data; - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar), - (GtkProgressBarOrientation) i); -} - -static void -toggle_show_text (GtkWidget *widget, ProgressData *pdata) -{ - gtk_progress_set_show_text (GTK_PROGRESS (pdata->pbar), - GTK_TOGGLE_BUTTON (widget)->active); - gtk_widget_set_sensitive (pdata->entry, GTK_TOGGLE_BUTTON (widget)->active); - gtk_widget_set_sensitive (pdata->x_align_spin, - GTK_TOGGLE_BUTTON (widget)->active); - gtk_widget_set_sensitive (pdata->y_align_spin, - GTK_TOGGLE_BUTTON (widget)->active); -} - -static void -progressbar_toggle_ellipsize (GtkWidget *widget, - gpointer data) -{ - ProgressData *pdata = data; - if (GTK_WIDGET_DRAWABLE (widget)) - { - gint i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - gtk_progress_bar_set_ellipsize (GTK_PROGRESS_BAR (pdata->pbar), i); - } -} - -static void -progressbar_toggle_bar_style (GtkWidget *widget, gpointer data) -{ - ProgressData *pdata; - gint i; - - pdata = (ProgressData *) data; - - if (!GTK_WIDGET_MAPPED (widget)) - return; - - i = gtk_option_menu_get_history (GTK_OPTION_MENU (widget)); - - if (i == 1) - gtk_widget_set_sensitive (pdata->block_spin, TRUE); - else - gtk_widget_set_sensitive (pdata->block_spin, FALSE); - - gtk_progress_bar_set_bar_style (GTK_PROGRESS_BAR (pdata->pbar), - (GtkProgressBarStyle) i); -} - -static void -progress_value_changed (GtkAdjustment *adj, ProgressData *pdata) -{ - char buf[20]; - - if (GTK_PROGRESS (pdata->pbar)->activity_mode) - sprintf (buf, "???"); - else - sprintf (buf, "%.0f%%", 100 * - gtk_progress_get_current_percentage (GTK_PROGRESS (pdata->pbar))); - gtk_label_set_text (GTK_LABEL (pdata->label), buf); -} - -static void -adjust_blocks (GtkAdjustment *adj, ProgressData *pdata) -{ - gtk_progress_set_percentage (GTK_PROGRESS (pdata->pbar), 0); - gtk_progress_bar_set_discrete_blocks (GTK_PROGRESS_BAR (pdata->pbar), - gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (pdata->block_spin))); -} - -static void -adjust_step (GtkAdjustment *adj, ProgressData *pdata) -{ - gtk_progress_bar_set_activity_step (GTK_PROGRESS_BAR (pdata->pbar), - gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (pdata->step_spin))); -} - -static void -adjust_act_blocks (GtkAdjustment *adj, ProgressData *pdata) -{ - gtk_progress_bar_set_activity_blocks (GTK_PROGRESS_BAR (pdata->pbar), - gtk_spin_button_get_value_as_int - (GTK_SPIN_BUTTON (pdata->act_blocks_spin))); -} - -static void -adjust_align (GtkAdjustment *adj, ProgressData *pdata) -{ - gtk_progress_set_text_alignment (GTK_PROGRESS (pdata->pbar), - gtk_spin_button_get_value (GTK_SPIN_BUTTON (pdata->x_align_spin)), - gtk_spin_button_get_value (GTK_SPIN_BUTTON (pdata->y_align_spin))); -} - -static void -toggle_activity_mode (GtkWidget *widget, ProgressData *pdata) -{ - gtk_progress_set_activity_mode (GTK_PROGRESS (pdata->pbar), - GTK_TOGGLE_BUTTON (widget)->active); - gtk_widget_set_sensitive (pdata->step_spin, - GTK_TOGGLE_BUTTON (widget)->active); - gtk_widget_set_sensitive (pdata->act_blocks_spin, - GTK_TOGGLE_BUTTON (widget)->active); -} - -static void -entry_changed (GtkWidget *widget, ProgressData *pdata) -{ - gtk_progress_set_format_string (GTK_PROGRESS (pdata->pbar), - gtk_entry_get_text (GTK_ENTRY (pdata->entry))); -} - -void -create_progress_bar (GtkWidget *widget) -{ - GtkWidget *button; - GtkWidget *vbox; - GtkWidget *vbox2; - GtkWidget *hbox; - GtkWidget *check; - GtkWidget *frame; - GtkWidget *tab; - GtkWidget *label; - GtkWidget *align; - GtkAdjustment *adj; - static ProgressData *pdata = NULL; - - static gchar *items1[] = - { - "Left-Right", - "Right-Left", - "Bottom-Top", - "Top-Bottom" - }; - - static gchar *items2[] = - { - "Continuous", - "Discrete" - }; - - static char *ellipsize_items[] = { - "None", // PANGO_ELLIPSIZE_NONE, - "Start", // PANGO_ELLIPSIZE_START, - "Middle", // PANGO_ELLIPSIZE_MIDDLE, - "End", // PANGO_ELLIPSIZE_END - }; - - if (!pdata) - pdata = g_new0 (ProgressData, 1); - - if (!pdata->window) - { - pdata->window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (pdata->window), - gtk_widget_get_screen (widget)); - - gtk_window_set_resizable (GTK_WINDOW (pdata->window), TRUE); - - g_signal_connect (pdata->window, "destroy", - G_CALLBACK (destroy_progress), - &pdata); - - pdata->timer = 0; - - gtk_window_set_title (GTK_WINDOW (pdata->window), "GtkProgressBar"); - gtk_container_set_border_width (GTK_CONTAINER (pdata->window), 0); - - vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (pdata->window)->vbox), - vbox, FALSE, TRUE, 0); - - frame = gtk_frame_new ("Progress"); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 5); - gtk_container_add (GTK_CONTAINER (frame), vbox2); - - align = gtk_alignment_new (0.5, 0.5, 0, 0); - gtk_box_pack_start (GTK_BOX (vbox2), align, FALSE, FALSE, 5); - - adj = (GtkAdjustment *) gtk_adjustment_new (0, 1, 300, 0, 0, 0); - g_signal_connect (adj, "value_changed", - G_CALLBACK (progress_value_changed), pdata); - - pdata->pbar = gtk_widget_new (GTK_TYPE_PROGRESS_BAR, - "adjustment", adj, - "ellipsize", PANGO_ELLIPSIZE_MIDDLE, - NULL); - gtk_progress_set_format_string (GTK_PROGRESS (pdata->pbar), - "%v from [%l,%u] (=%p%%)"); - gtk_container_add (GTK_CONTAINER (align), pdata->pbar); - pdata->timer = gtk_timeout_add (100, progress_timeout, pdata->pbar); - - align = gtk_alignment_new (0.5, 0.5, 0, 0); - gtk_box_pack_start (GTK_BOX (vbox2), align, FALSE, FALSE, 5); - - hbox = gtk_hbox_new (FALSE, 5); - gtk_container_add (GTK_CONTAINER (align), hbox); - label = gtk_label_new ("Label updated by user :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - pdata->label = gtk_label_new (""); - gtk_box_pack_start (GTK_BOX (hbox), pdata->label, FALSE, TRUE, 0); - - frame = gtk_frame_new ("Options"); - gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 5); - gtk_container_add (GTK_CONTAINER (frame), vbox2); - - tab = gtk_table_new (7, 2, FALSE); - gtk_box_pack_start (GTK_BOX (vbox2), tab, FALSE, TRUE, 0); - - label = gtk_label_new ("Orientation :"); - gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - - pdata->omenu1 = build_option_menu (items1, 4, 0, - progressbar_toggle_orientation, - pdata); - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 0, 1, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_box_pack_start (GTK_BOX (hbox), pdata->omenu1, TRUE, TRUE, 0); - - check = gtk_check_button_new_with_label ("Show text"); - g_signal_connect (check, "clicked", - G_CALLBACK (toggle_show_text), - pdata); - gtk_table_attach (GTK_TABLE (tab), check, 0, 1, 1, 2, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 1, 2, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - - label = gtk_label_new ("Format : "); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - - pdata->entry = gtk_entry_new (); - g_signal_connect (pdata->entry, "changed", - G_CALLBACK (entry_changed), - pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->entry, TRUE, TRUE, 0); - gtk_entry_set_text (GTK_ENTRY (pdata->entry), "%v from [%l,%u] (=%p%%)"); - gtk_widget_set_size_request (pdata->entry, 100, -1); - gtk_widget_set_sensitive (pdata->entry, FALSE); - - label = gtk_label_new ("Text align :"); - gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 2, 3, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 2, 3, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - - label = gtk_label_new ("x :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 5); - - adj = (GtkAdjustment *) gtk_adjustment_new (0.5, 0, 1, 0.1, 0.1, 0); - pdata->x_align_spin = gtk_spin_button_new (adj, 0, 1); - g_signal_connect (adj, "value_changed", - G_CALLBACK (adjust_align), pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->x_align_spin, FALSE, TRUE, 0); - gtk_widget_set_sensitive (pdata->x_align_spin, FALSE); - - label = gtk_label_new ("y :"); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 5); - - adj = (GtkAdjustment *) gtk_adjustment_new (0.5, 0, 1, 0.1, 0.1, 0); - pdata->y_align_spin = gtk_spin_button_new (adj, 0, 1); - g_signal_connect (adj, "value_changed", - G_CALLBACK (adjust_align), pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->y_align_spin, FALSE, TRUE, 0); - gtk_widget_set_sensitive (pdata->y_align_spin, FALSE); - - label = gtk_label_new ("Ellipsize text :"); - gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 10, 11, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - pdata->elmenu = build_option_menu (ellipsize_items, - sizeof (ellipsize_items) / sizeof (ellipsize_items[0]), - 2, // PANGO_ELLIPSIZE_MIDDLE - progressbar_toggle_ellipsize, - pdata); - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 10, 11, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_box_pack_start (GTK_BOX (hbox), pdata->elmenu, TRUE, TRUE, 0); - - label = gtk_label_new ("Bar Style :"); - gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 13, 14, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - - pdata->omenu2 = build_option_menu (items2, 2, 0, - progressbar_toggle_bar_style, - pdata); - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 13, 14, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_box_pack_start (GTK_BOX (hbox), pdata->omenu2, TRUE, TRUE, 0); - - label = gtk_label_new ("Block count :"); - gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 14, 15, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 14, 15, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - adj = (GtkAdjustment *) gtk_adjustment_new (10, 2, 20, 1, 5, 0); - pdata->block_spin = gtk_spin_button_new (adj, 0, 0); - g_signal_connect (adj, "value_changed", - G_CALLBACK (adjust_blocks), pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->block_spin, FALSE, TRUE, 0); - gtk_widget_set_sensitive (pdata->block_spin, FALSE); - - check = gtk_check_button_new_with_label ("Activity mode"); - g_signal_connect (check, "clicked", - G_CALLBACK (toggle_activity_mode), pdata); - gtk_table_attach (GTK_TABLE (tab), check, 0, 1, 15, 16, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 15, 16, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - label = gtk_label_new ("Step size : "); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - adj = (GtkAdjustment *) gtk_adjustment_new (3, 1, 20, 1, 5, 0); - pdata->step_spin = gtk_spin_button_new (adj, 0, 0); - g_signal_connect (adj, "value_changed", - G_CALLBACK (adjust_step), pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->step_spin, FALSE, TRUE, 0); - gtk_widget_set_sensitive (pdata->step_spin, FALSE); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 16, 17, - GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, - 5, 5); - label = gtk_label_new ("Blocks : "); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0); - adj = (GtkAdjustment *) gtk_adjustment_new (5, 2, 10, 1, 5, 0); - pdata->act_blocks_spin = gtk_spin_button_new (adj, 0, 0); - g_signal_connect (adj, "value_changed", - G_CALLBACK (adjust_act_blocks), pdata); - gtk_box_pack_start (GTK_BOX (hbox), pdata->act_blocks_spin, FALSE, TRUE, - 0); - gtk_widget_set_sensitive (pdata->act_blocks_spin, FALSE); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - pdata->window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (pdata->window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - } - - if (!GTK_WIDGET_VISIBLE (pdata->window)) - gtk_widget_show_all (pdata->window); - else - gtk_widget_destroy (pdata->window); -} - -/* - * Properties - */ - -typedef struct { - int x; - int y; - gboolean found; - gboolean first; - GtkWidget *res_widget; -} FindWidgetData; - -static void -find_widget (GtkWidget *widget, FindWidgetData *data) -{ - GtkAllocation new_allocation; - gint x_offset = 0; - gint y_offset = 0; - - new_allocation = widget->allocation; - - if (data->found || !GTK_WIDGET_MAPPED (widget)) - return; - - /* Note that in the following code, we only count the - * position as being inside a WINDOW widget if it is inside - * widget->window; points that are outside of widget->window - * but within the allocation are not counted. This is consistent - * with the way we highlight drag targets. - */ - if (!GTK_WIDGET_NO_WINDOW (widget)) - { - new_allocation.x = 0; - new_allocation.y = 0; - } - - if (widget->parent && !data->first) - { - GdkWindow *window = widget->window; - while (window != widget->parent->window) - { - gint tx, ty, twidth, theight; - gdk_drawable_get_size (window, &twidth, &theight); - - if (new_allocation.x < 0) - { - new_allocation.width += new_allocation.x; - new_allocation.x = 0; - } - if (new_allocation.y < 0) - { - new_allocation.height += new_allocation.y; - new_allocation.y = 0; - } - if (new_allocation.x + new_allocation.width > twidth) - new_allocation.width = twidth - new_allocation.x; - if (new_allocation.y + new_allocation.height > theight) - new_allocation.height = theight - new_allocation.y; - - gdk_window_get_position (window, &tx, &ty); - new_allocation.x += tx; - x_offset += tx; - new_allocation.y += ty; - y_offset += ty; - - window = gdk_window_get_parent (window); - } - } - - if ((data->x >= new_allocation.x) && (data->y >= new_allocation.y) && - (data->x < new_allocation.x + new_allocation.width) && - (data->y < new_allocation.y + new_allocation.height)) - { - /* First, check if the drag is in a valid drop site in - * one of our children - */ - if (GTK_IS_CONTAINER (widget)) - { - FindWidgetData new_data = *data; - - new_data.x -= x_offset; - new_data.y -= y_offset; - new_data.found = FALSE; - new_data.first = FALSE; - - gtk_container_forall (GTK_CONTAINER (widget), - (GtkCallback)find_widget, - &new_data); - - data->found = new_data.found; - if (data->found) - data->res_widget = new_data.res_widget; - } - - /* If not, and this widget is registered as a drop site, check to - * emit "drag_motion" to check if we are actually in - * a drop site. - */ - if (!data->found) - { - data->found = TRUE; - data->res_widget = widget; - } - } -} - -static GtkWidget * -find_widget_at_pointer (GdkDisplay *display) -{ - GtkWidget *widget = NULL; - GdkWindow *pointer_window; - gint x, y; - FindWidgetData data; - - pointer_window = gdk_display_get_window_at_pointer (display, NULL, NULL); - - if (pointer_window) - gdk_window_get_user_data (pointer_window, (gpointer) &widget); - - if (widget) - { - gdk_window_get_pointer (widget->window, - &x, &y, NULL); - - data.x = x; - data.y = y; - data.found = FALSE; - data.first = TRUE; - - find_widget (widget, &data); - if (data.found) - return data.res_widget; - return widget; - } - return NULL; -} - -struct PropertiesData { - GtkWidget **window; - GdkCursor *cursor; - gboolean in_query; - gint handler; -}; - -static void -destroy_properties (GtkWidget *widget, - struct PropertiesData *data) -{ - if (data->window) - { - *data->window = NULL; - data->window = NULL; - } - - if (data->cursor) - { - gdk_cursor_unref (data->cursor); - data->cursor = NULL; - } - - if (data->handler) - { - g_signal_handler_disconnect (widget, data->handler); - data->handler = 0; - } - - g_free (data); -} - -static gint -property_query_event (GtkWidget *widget, - GdkEvent *event, - struct PropertiesData *data) -{ - GtkWidget *res_widget = NULL; - - if (!data->in_query) - return FALSE; - - if (event->type == GDK_BUTTON_RELEASE) - { - gtk_grab_remove (widget); - gdk_display_pointer_ungrab (gtk_widget_get_display (widget), - GDK_CURRENT_TIME); - - res_widget = find_widget_at_pointer (gtk_widget_get_display (widget)); - if (res_widget) - { - g_object_set_data (G_OBJECT (res_widget), "prop-editor-screen", - gtk_widget_get_screen (widget)); - create_prop_editor (G_OBJECT (res_widget), 0); - } - - data->in_query = FALSE; - } - return FALSE; -} - - -static void -query_properties (GtkButton *button, - struct PropertiesData *data) -{ - gint failure; - - g_signal_connect (button, "event", - G_CALLBACK (property_query_event), data); - - - if (!data->cursor) - data->cursor = gdk_cursor_new_for_display (gtk_widget_get_display (GTK_WIDGET (button)), - GDK_TARGET); - - failure = gdk_pointer_grab (GTK_WIDGET (button)->window, - TRUE, - GDK_BUTTON_RELEASE_MASK, - NULL, - data->cursor, - GDK_CURRENT_TIME); - - gtk_grab_add (GTK_WIDGET (button)); - - data->in_query = TRUE; -} - -static void -create_properties (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - GtkWidget *vbox; - GtkWidget *label; - struct PropertiesData *data; - - data = g_new (struct PropertiesData, 1); - data->window = &window; - data->in_query = FALSE; - data->cursor = NULL; - data->handler = 0; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - data->handler = g_signal_connect (window, "destroy", - G_CALLBACK (destroy_properties), - data); - - gtk_window_set_title (GTK_WINDOW (window), "test properties"); - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - - vbox = gtk_vbox_new (FALSE, 1); - gtk_container_add (GTK_CONTAINER (window), vbox); - - label = gtk_label_new ("This is just a dumb test to test properties.\nIf you need a generic module, get GLE."); - gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0); - - button = gtk_button_new_with_label ("Query properties"); - gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, TRUE, 0); - g_signal_connect (button, "clicked", - G_CALLBACK (query_properties), - data); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); - -} + /* It has to be a widget with a popup, GtkComboBox, GtkVolumeButton, ... */ + GtkWidget *combobox = gtk_combo_box_new_text (); + gtk_combo_box_append_text (GTK_COMBO_BOX (combobox), "combobox"); + gtk_container_add (GTK_CONTAINER (vbox), combobox); -/* - * Color Preview - */ + GtkWidget *notebook = gtk_notebook_new (); + gtk_notebook_set_show_tabs (GTK_NOTEBOOK (notebook), FALSE); + gtk_container_add (GTK_CONTAINER (vbox), notebook); -static int color_idle = 0; + GtkWidget *label = gtk_label_new ("Hello world!"); + gtk_notebook_append_page (GTK_NOTEBOOK (notebook), label, NULL); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (notebook), label, TRUE); -gint -color_idle_func (GtkWidget *preview) -{ - static int count = 1; - guchar buf[768]; - int i, j, k; - - for (i = 0; i < 256; i++) - { - for (j = 0, k = 0; j < 256; j++) - { - buf[k+0] = i + count; - buf[k+1] = 0; - buf[k+2] = j + count; - k += 3; - } - - gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256); - } - - count += 1; - - gtk_widget_queue_draw (preview); - gdk_window_process_updates (preview->window, TRUE); - - return TRUE; -} - -static void -color_preview_destroy (GtkWidget *widget, - GtkWidget **window) -{ - gtk_idle_remove (color_idle); - color_idle = 0; - - *window = NULL; -} - -void -create_color_preview (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *preview; - guchar buf[768]; - int i, j, k; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (color_preview_destroy), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - - preview = gtk_preview_new (GTK_PREVIEW_COLOR); - gtk_preview_size (GTK_PREVIEW (preview), 256, 256); - gtk_container_add (GTK_CONTAINER (window), preview); - - for (i = 0; i < 256; i++) - { - for (j = 0, k = 0; j < 256; j++) - { - buf[k+0] = i; - buf[k+1] = 0; - buf[k+2] = j; - k += 3; - } - - gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256); - } - - color_idle = gtk_idle_add ((GtkFunction) color_idle_func, preview); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Gray Preview - */ - -static int gray_idle = 0; - -gint -gray_idle_func (GtkWidget *preview) -{ - static int count = 1; - guchar buf[256]; - int i, j; - - for (i = 0; i < 256; i++) - { - for (j = 0; j < 256; j++) - buf[j] = i + j + count; - - gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256); - } - - count += 1; - - gtk_widget_draw (preview, NULL); - - return TRUE; -} - -static void -gray_preview_destroy (GtkWidget *widget, - GtkWidget **window) -{ - gtk_idle_remove (gray_idle); - gray_idle = 0; - - *window = NULL; -} - -void -create_gray_preview (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *preview; - guchar buf[256]; - int i, j; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gray_preview_destroy), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - - preview = gtk_preview_new (GTK_PREVIEW_GRAYSCALE); - gtk_preview_size (GTK_PREVIEW (preview), 256, 256); - gtk_container_add (GTK_CONTAINER (window), preview); - - for (i = 0; i < 256; i++) - { - for (j = 0; j < 256; j++) - buf[j] = i + j; - - gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256); - } - - gray_idle = gtk_idle_add ((GtkFunction) gray_idle_func, preview); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - - -/* - * Selection Test - */ - -void -selection_test_received (GtkWidget *list, GtkSelectionData *data) -{ - GdkAtom *atoms; - GtkWidget *list_item; - GList *item_list; - int i, l; - - if (data->length < 0) - { - g_print ("Selection retrieval failed\n"); - return; - } - if (data->type != GDK_SELECTION_TYPE_ATOM) - { - g_print ("Selection \"TARGETS\" was not returned as atoms!\n"); - return; - } - - /* Clear out any current list items */ - - gtk_list_clear_items (GTK_LIST(list), 0, -1); - - /* Add new items to list */ - - atoms = (GdkAtom *)data->data; - - item_list = NULL; - l = data->length / sizeof (GdkAtom); - for (i = 0; i < l; i++) - { - char *name; - name = gdk_atom_name (atoms[i]); - if (name != NULL) - { - list_item = gtk_list_item_new_with_label (name); - g_free (name); - } - else - list_item = gtk_list_item_new_with_label ("(bad atom)"); - - gtk_widget_show (list_item); - item_list = g_list_append (item_list, list_item); - } - - gtk_list_append_items (GTK_LIST (list), item_list); - - return; -} - -void -selection_test_get_targets (GtkWidget *widget, GtkWidget *list) -{ - static GdkAtom targets_atom = GDK_NONE; - - if (targets_atom == GDK_NONE) - targets_atom = gdk_atom_intern ("TARGETS", FALSE); - - gtk_selection_convert (list, GDK_SELECTION_PRIMARY, targets_atom, - GDK_CURRENT_TIME); -} - -void -create_selection_test (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - GtkWidget *vbox; - GtkWidget *scrolled_win; - GtkWidget *list; - GtkWidget *label; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Selection Test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - /* Create the list */ - - vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox, - TRUE, TRUE, 0); - - label = gtk_label_new ("Gets available targets for current selection"); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - scrolled_win = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0); - gtk_widget_set_size_request (scrolled_win, 100, 200); - - list = gtk_list_new (); - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_win), list); - - g_signal_connect (list, "selection_received", - G_CALLBACK (selection_test_received), NULL); - - /* .. And create some buttons */ - button = gtk_button_new_with_label ("Get Targets"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - - g_signal_connect (button, "clicked", - G_CALLBACK (selection_test_get_targets), list); - - button = gtk_button_new_with_label ("Quit"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Gamma Curve - */ - -void -create_gamma_curve (GtkWidget *widget) -{ - static GtkWidget *window = NULL, *curve; - static int count = 0; - gfloat vec[256]; - gint max; - gint i; - - if (!window) - { - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_title (GTK_WINDOW (window), "test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 10); - - g_signal_connect (window, "destroy", - G_CALLBACK(gtk_widget_destroyed), - &window); - - curve = gtk_gamma_curve_new (); - gtk_container_add (GTK_CONTAINER (window), curve); - gtk_widget_show (curve); - } - - max = 127 + (count % 2)*128; - gtk_curve_set_range (GTK_CURVE (GTK_GAMMA_CURVE (curve)->curve), - 0, max, 0, max); - for (i = 0; i < max; ++i) - vec[i] = (127 / sqrt (max)) * sqrt (i); - gtk_curve_set_vector (GTK_CURVE (GTK_GAMMA_CURVE (curve)->curve), - max, vec); - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else if (count % 4 == 3) - { - gtk_widget_destroy (window); - window = NULL; - } - - ++count; -} - -/* - * Test scrolling - */ - -static int scroll_test_pos = 0.0; - -static gint -scroll_test_expose (GtkWidget *widget, GdkEventExpose *event, - GtkAdjustment *adj) -{ - gint i,j; - gint imin, imax, jmin, jmax; - - imin = (event->area.x) / 10; - imax = (event->area.x + event->area.width + 9) / 10; - - jmin = ((int)adj->value + event->area.y) / 10; - jmax = ((int)adj->value + event->area.y + event->area.height + 9) / 10; - - gdk_window_clear_area (widget->window, - event->area.x, event->area.y, - event->area.width, event->area.height); - - for (i=imin; i<imax; i++) - for (j=jmin; j<jmax; j++) - if ((i+j) % 2) - gdk_draw_rectangle (widget->window, - widget->style->black_gc, - TRUE, - 10*i, 10*j - (int)adj->value, 1+i%10, 1+j%10); - - return TRUE; -} - -static gint -scroll_test_scroll (GtkWidget *widget, GdkEventScroll *event, - GtkAdjustment *adj) -{ - gdouble new_value = adj->value + ((event->direction == GDK_SCROLL_UP) ? - -adj->page_increment / 2: - adj->page_increment / 2); - new_value = CLAMP (new_value, adj->lower, adj->upper - adj->page_size); - gtk_adjustment_set_value (adj, new_value); - - return TRUE; -} - -static void -scroll_test_configure (GtkWidget *widget, GdkEventConfigure *event, - GtkAdjustment *adj) -{ - adj->page_increment = 0.9 * widget->allocation.height; - adj->page_size = widget->allocation.height; - - g_signal_emit_by_name (adj, "changed"); -} - -static void -scroll_test_adjustment_changed (GtkAdjustment *adj, GtkWidget *widget) -{ - /* gint source_min = (int)adj->value - scroll_test_pos; */ - gint dy; - - dy = scroll_test_pos - (int)adj->value; - scroll_test_pos = adj->value; - - if (!GTK_WIDGET_DRAWABLE (widget)) - return; - gdk_window_scroll (widget->window, 0, dy); - gdk_window_process_updates (widget->window, FALSE); -} - - -void -create_scroll_test (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *hbox; - GtkWidget *drawing_area; - GtkWidget *scrollbar; - GtkWidget *button; - GtkAdjustment *adj; - GdkGeometry geometry; - GdkWindowHints geometry_mask; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Scroll Test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), hbox, - TRUE, TRUE, 0); - gtk_widget_show (hbox); - - drawing_area = gtk_drawing_area_new (); - gtk_widget_set_size_request (drawing_area, 200, 200); - gtk_box_pack_start (GTK_BOX (hbox), drawing_area, TRUE, TRUE, 0); - gtk_widget_show (drawing_area); - - gtk_widget_set_events (drawing_area, GDK_EXPOSURE_MASK | GDK_SCROLL_MASK); - - adj = GTK_ADJUSTMENT (gtk_adjustment_new (0.0, 0.0, 1000.0, 1.0, 180.0, 200.0)); - scroll_test_pos = 0.0; - - scrollbar = gtk_vscrollbar_new (adj); - gtk_box_pack_start (GTK_BOX (hbox), scrollbar, FALSE, FALSE, 0); - gtk_widget_show (scrollbar); - - g_signal_connect (drawing_area, "expose_event", - G_CALLBACK (scroll_test_expose), adj); - g_signal_connect (drawing_area, "configure_event", - G_CALLBACK (scroll_test_configure), adj); - g_signal_connect (drawing_area, "scroll_event", - G_CALLBACK (scroll_test_scroll), adj); - - g_signal_connect (adj, "value_changed", - G_CALLBACK (scroll_test_adjustment_changed), - drawing_area); - - /* .. And create some buttons */ - - button = gtk_button_new_with_label ("Quit"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - gtk_widget_show (button); - - /* Set up gridded geometry */ - - geometry_mask = GDK_HINT_MIN_SIZE | - GDK_HINT_BASE_SIZE | - GDK_HINT_RESIZE_INC; - - geometry.min_width = 20; - geometry.min_height = 20; - geometry.base_width = 0; - geometry.base_height = 0; - geometry.width_inc = 10; - geometry.height_inc = 10; - - gtk_window_set_geometry_hints (GTK_WINDOW (window), - drawing_area, &geometry, geometry_mask); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Timeout Test - */ - -static int timer = 0; - -gint -timeout_test (GtkWidget *label) -{ - static int count = 0; - static char buffer[32]; - - sprintf (buffer, "count: %d", ++count); - gtk_label_set_text (GTK_LABEL (label), buffer); - - return TRUE; -} - -void -start_timeout_test (GtkWidget *widget, - GtkWidget *label) -{ - if (!timer) - { - timer = gtk_timeout_add (100, (GtkFunction) timeout_test, label); - } -} - -void -stop_timeout_test (GtkWidget *widget, - gpointer data) -{ - if (timer) - { - gtk_timeout_remove (timer); - timer = 0; - } -} - -void -destroy_timeout_test (GtkWidget *widget, - GtkWidget **window) -{ - stop_timeout_test (NULL, NULL); - - *window = NULL; -} - -void -create_timeout_test (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - GtkWidget *label; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (destroy_timeout_test), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Timeout Test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - label = gtk_label_new ("count: 0"); - gtk_misc_set_padding (GTK_MISC (label), 10, 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - label, TRUE, TRUE, 0); - gtk_widget_show (label); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("start"); - g_signal_connect (button, "clicked", - G_CALLBACK(start_timeout_test), - label); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("stop"); - g_signal_connect (button, "clicked", - G_CALLBACK (stop_timeout_test), - NULL); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * Idle Test - */ - -static int idle_id = 0; - -static gint -idle_test (GtkWidget *label) -{ - static int count = 0; - static char buffer[32]; - - sprintf (buffer, "count: %d", ++count); - gtk_label_set_text (GTK_LABEL (label), buffer); - - return TRUE; -} - -static void -start_idle_test (GtkWidget *widget, - GtkWidget *label) -{ - if (!idle_id) - { - idle_id = gtk_idle_add ((GtkFunction) idle_test, label); - } -} - -static void -stop_idle_test (GtkWidget *widget, - gpointer data) -{ - if (idle_id) - { - gtk_idle_remove (idle_id); - idle_id = 0; - } -} - -static void -destroy_idle_test (GtkWidget *widget, - GtkWidget **window) -{ - stop_idle_test (NULL, NULL); - - *window = NULL; -} - -static void -toggle_idle_container (GObject *button, - GtkContainer *container) -{ - gtk_container_set_resize_mode (container, GPOINTER_TO_INT (g_object_get_data (button, "user_data"))); -} - -static void -create_idle_test (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - GtkWidget *label; - GtkWidget *container; - - if (!window) - { - GtkWidget *button2; - GtkWidget *frame; - GtkWidget *box; - - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (destroy_idle_test), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Idle Test"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - label = gtk_label_new ("count: 0"); - gtk_misc_set_padding (GTK_MISC (label), 10, 10); - gtk_widget_show (label); - - container = - gtk_widget_new (GTK_TYPE_HBOX, - "visible", TRUE, - /* "GtkContainer::child", gtk_widget_new (GTK_TYPE_HBOX, - * "GtkWidget::visible", TRUE, - */ - "child", label, - /* NULL), */ - NULL); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), - container, TRUE, TRUE, 0); - - frame = - gtk_widget_new (GTK_TYPE_FRAME, - "border_width", 5, - "label", "Label Container", - "visible", TRUE, - "parent", GTK_DIALOG (window)->vbox, - NULL); - box = - gtk_widget_new (GTK_TYPE_VBOX, - "visible", TRUE, - "parent", frame, - NULL); - button = - g_object_connect (gtk_widget_new (GTK_TYPE_RADIO_BUTTON, - "label", "Resize-Parent", - "user_data", (void*)GTK_RESIZE_PARENT, - "visible", TRUE, - "parent", box, - NULL), - "signal::clicked", toggle_idle_container, container, - NULL); - button = gtk_widget_new (GTK_TYPE_RADIO_BUTTON, - "label", "Resize-Queue", - "user_data", (void*)GTK_RESIZE_QUEUE, - "group", button, - "visible", TRUE, - "parent", box, - NULL); - g_object_connect (button, - "signal::clicked", toggle_idle_container, container, - NULL); - button2 = gtk_widget_new (GTK_TYPE_RADIO_BUTTON, - "label", "Resize-Immediate", - "user_data", (void*)GTK_RESIZE_IMMEDIATE, - NULL); - g_object_connect (button2, - "signal::clicked", toggle_idle_container, container, - NULL); - g_object_set (button2, - "group", button, - "visible", TRUE, - "parent", box, - NULL); - - button = gtk_button_new_with_label ("close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("start"); - g_signal_connect (button, "clicked", - G_CALLBACK (start_idle_test), - label); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - - button = gtk_button_new_with_label ("stop"); - g_signal_connect (button, "clicked", - G_CALLBACK (stop_idle_test), - NULL); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); - else - gtk_widget_destroy (window); -} - -/* - * rc file test - */ - -void -reload_all_rc_files (void) -{ - static GdkAtom atom_rcfiles = GDK_NONE; - - GdkEvent *send_event = gdk_event_new (GDK_CLIENT_EVENT); - int i; - - if (!atom_rcfiles) - atom_rcfiles = gdk_atom_intern("_GTK_READ_RCFILES", FALSE); - - for(i = 0; i < 5; i++) - send_event->client.data.l[i] = 0; - send_event->client.data_format = 32; - send_event->client.message_type = atom_rcfiles; - gdk_event_send_clientmessage_toall (send_event); - - gdk_event_free (send_event); -} - -void -create_rc_file (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *button; - GtkWidget *frame; - GtkWidget *vbox; - GtkWidget *label; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - frame = gtk_aspect_frame_new ("Testing RC file prioritization", 0.5, 0.5, 0.0, TRUE); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), frame, FALSE, FALSE, 0); - - vbox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (frame), vbox); - - label = gtk_label_new ("This label should be red"); - gtk_widget_set_name (label, "testgtk-red-label"); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - label = gtk_label_new ("This label should be green"); - gtk_widget_set_name (label, "testgtk-green-label"); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - label = gtk_label_new ("This label should be blue"); - gtk_widget_set_name (label, "testgtk-blue-label"); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - gtk_window_set_title (GTK_WINDOW (window), "Reload Rc file"); - gtk_container_set_border_width (GTK_CONTAINER (window), 0); - - button = gtk_button_new_with_label ("Reload"); - g_signal_connect (button, "clicked", - G_CALLBACK (gtk_rc_reparse_all), NULL); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_grab_default (button); - - button = gtk_button_new_with_label ("Reload All"); - g_signal_connect (button, "clicked", - G_CALLBACK (reload_all_rc_files), NULL); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Test of recursive mainloop - */ - -void -mainloop_destroyed (GtkWidget *w, GtkWidget **window) -{ - *window = NULL; - gtk_main_quit (); -} - -void -create_mainloop (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *label; - GtkWidget *button; - - if (!window) - { - window = gtk_dialog_new (); - - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - gtk_window_set_title (GTK_WINDOW (window), "Test Main Loop"); - - g_signal_connect (window, "destroy", - G_CALLBACK (mainloop_destroyed), - &window); - - label = gtk_label_new ("In recursive main loop..."); - gtk_misc_set_padding (GTK_MISC(label), 20, 20); - - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), label, - TRUE, TRUE, 0); - gtk_widget_show (label); - - button = gtk_button_new_with_label ("Leave"); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), button, - FALSE, TRUE, 0); - - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); - - gtk_widget_show (button); - } - - if (!GTK_WIDGET_VISIBLE (window)) - { - gtk_widget_show (window); - - g_print ("create_mainloop: start\n"); - gtk_main (); - g_print ("create_mainloop: done\n"); - } - else - gtk_widget_destroy (window); -} - -gboolean -layout_expose_handler (GtkWidget *widget, GdkEventExpose *event) -{ - GtkLayout *layout; - - gint i,j; - gint imin, imax, jmin, jmax; - - layout = GTK_LAYOUT (widget); - - if (event->window != layout->bin_window) - return FALSE; - - imin = (event->area.x) / 10; - imax = (event->area.x + event->area.width + 9) / 10; - - jmin = (event->area.y) / 10; - jmax = (event->area.y + event->area.height + 9) / 10; - - for (i=imin; i<imax; i++) - for (j=jmin; j<jmax; j++) - if ((i+j) % 2) - gdk_draw_rectangle (layout->bin_window, - widget->style->black_gc, - TRUE, - 10*i, 10*j, - 1+i%10, 1+j%10); - - return FALSE; -} - -void create_layout (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *layout; - GtkWidget *scrolledwindow; - GtkWidget *button; - - if (!window) - { - gchar buf[16]; - - gint i, j; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - gtk_window_set_title (GTK_WINDOW (window), "Layout"); - gtk_widget_set_size_request (window, 200, 200); - - scrolledwindow = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolledwindow), - GTK_SHADOW_IN); - gtk_scrolled_window_set_placement (GTK_SCROLLED_WINDOW (scrolledwindow), - GTK_CORNER_TOP_RIGHT); - - gtk_container_add (GTK_CONTAINER (window), scrolledwindow); - - layout = gtk_layout_new (NULL, NULL); - gtk_container_add (GTK_CONTAINER (scrolledwindow), layout); - - /* We set step sizes here since GtkLayout does not set - * them itself. - */ - GTK_LAYOUT (layout)->hadjustment->step_increment = 10.0; - GTK_LAYOUT (layout)->vadjustment->step_increment = 10.0; - - gtk_widget_set_events (layout, GDK_EXPOSURE_MASK); - g_signal_connect (layout, "expose_event", - G_CALLBACK (layout_expose_handler), NULL); - - gtk_layout_set_size (GTK_LAYOUT (layout), 1600, 128000); - - for (i=0 ; i < 16 ; i++) - for (j=0 ; j < 16 ; j++) - { - sprintf(buf, "Button %d, %d", i, j); - if ((i + j) % 2) - button = gtk_button_new_with_label (buf); - else - button = gtk_label_new (buf); - - gtk_layout_put (GTK_LAYOUT (layout), button, - j*100, i*100); - } - - for (i=16; i < 1280; i++) - { - sprintf(buf, "Button %d, %d", i, 0); - if (i % 2) - button = gtk_button_new_with_label (buf); - else - button = gtk_label_new (buf); - - gtk_layout_put (GTK_LAYOUT (layout), button, - 0, i*100); - } - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -void -create_styles (GtkWidget *widget) -{ - static GtkWidget *window = NULL; - GtkWidget *label; - GtkWidget *button; - GtkWidget *entry; - GtkWidget *vbox; - static GdkColor red = { 0, 0xffff, 0, 0 }; - static GdkColor green = { 0, 0, 0xffff, 0 }; - static GdkColor blue = { 0, 0, 0, 0xffff }; - static GdkColor yellow = { 0, 0xffff, 0xffff, 0 }; - static GdkColor cyan = { 0, 0 , 0xffff, 0xffff }; - PangoFontDescription *font_desc; - - GtkRcStyle *rc_style; - - if (!window) - { - window = gtk_dialog_new (); - gtk_window_set_screen (GTK_WINDOW (window), - gtk_widget_get_screen (widget)); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_widget_destroyed), - &window); - - - button = gtk_button_new_with_label ("Close"); - g_signal_connect_swapped (button, "clicked", - G_CALLBACK (gtk_widget_destroy), - window); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), - button, TRUE, TRUE, 0); - gtk_widget_show (button); - - vbox = gtk_vbox_new (FALSE, 5); - gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); - gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox, FALSE, FALSE, 0); - - label = gtk_label_new ("Font:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - font_desc = pango_font_description_from_string ("Helvetica,Sans Oblique 18"); - - button = gtk_button_new_with_label ("Some Text"); - gtk_widget_modify_font (GTK_BIN (button)->child, font_desc); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - label = gtk_label_new ("Foreground:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Some Text"); - gtk_widget_modify_fg (GTK_BIN (button)->child, GTK_STATE_NORMAL, &red); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - label = gtk_label_new ("Background:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Some Text"); - gtk_widget_modify_bg (button, GTK_STATE_NORMAL, &green); - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - - label = gtk_label_new ("Text:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), "Some Text"); - gtk_widget_modify_text (entry, GTK_STATE_NORMAL, &blue); - gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0); - - label = gtk_label_new ("Base:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), "Some Text"); - gtk_widget_modify_base (entry, GTK_STATE_NORMAL, &yellow); - gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0); - - label = gtk_label_new ("Cursor:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - entry = gtk_entry_new (); - gtk_entry_set_text (GTK_ENTRY (entry), "Some Text"); - gtk_widget_modify_cursor (entry, &red, &red); - gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0); - - label = gtk_label_new ("Multiple:"); - gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); - gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0); - - button = gtk_button_new_with_label ("Some Text"); - - rc_style = gtk_rc_style_new (); - - rc_style->font_desc = pango_font_description_copy (font_desc); - rc_style->color_flags[GTK_STATE_NORMAL] = GTK_RC_FG | GTK_RC_BG; - rc_style->color_flags[GTK_STATE_PRELIGHT] = GTK_RC_FG | GTK_RC_BG; - rc_style->color_flags[GTK_STATE_ACTIVE] = GTK_RC_FG | GTK_RC_BG; - rc_style->fg[GTK_STATE_NORMAL] = yellow; - rc_style->bg[GTK_STATE_NORMAL] = blue; - rc_style->fg[GTK_STATE_PRELIGHT] = blue; - rc_style->bg[GTK_STATE_PRELIGHT] = yellow; - rc_style->fg[GTK_STATE_ACTIVE] = red; - rc_style->bg[GTK_STATE_ACTIVE] = cyan; - rc_style->xthickness = 5; - rc_style->ythickness = 5; - - gtk_widget_modify_style (button, rc_style); - gtk_widget_modify_style (GTK_BIN (button)->child, rc_style); - - g_object_unref (rc_style); - - gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); - } - - if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); - else - gtk_widget_destroy (window); -} - -/* - * Main Window and Exit - */ - -void -do_exit (GtkWidget *widget, GtkWidget *window) -{ - gtk_widget_destroy (window); - gtk_main_quit (); -} - -struct { - char *label; - void (*func) (GtkWidget *widget); - gboolean do_not_benchmark; -} buttons[] = -{ - { "alpha window", create_alpha_window }, -#ifdef G_OS_WIN32 - /* dog slow on NT, no working at all on 9x */ - { "big windows", create_big_windows, TRUE }, -#else - { "big windows", create_big_windows }, -#endif - { "button box", create_button_box }, - { "buttons", create_buttons }, - { "check buttons", create_check_buttons }, - { "clist", create_clist}, - { "color selection", create_color_selection }, - { "composited window", create_composited_window }, - { "ctree", create_ctree }, - { "cursors", create_cursors }, - { "dialog", create_dialog, TRUE }, - { "display & screen", create_display_screen, TRUE }, - { "entry", create_entry }, - { "event box", create_event_box }, - { "event watcher", create_event_watcher }, - { "expander", create_expander }, - { "file selection", create_file_selection }, - { "flipping", create_flipping }, - { "focus", create_focus }, - { "font selection", create_font_selection }, - { "gamma curve", create_gamma_curve, TRUE }, - { "gridded geometry", create_gridded_geometry }, - { "handle box", create_handle_box }, - { "image from drawable", create_get_image }, - { "image", create_image }, - { "item factory", create_item_factory }, - { "key lookup", create_key_lookup }, - { "labels", create_labels }, - { "layout", create_layout }, - { "list", create_list }, - { "menus", create_menus }, - { "message dialog", create_message_dialog }, - { "modal window", create_modal_window, TRUE }, - { "notebook", create_notebook }, - { "panes", create_panes }, - { "paned keyboard", create_paned_keyboard_navigation }, - { "pixmap", create_pixmap }, - { "preview color", create_color_preview, TRUE }, - { "preview gray", create_gray_preview, TRUE }, - { "progress bar", create_progress_bar }, - { "properties", create_properties }, - { "radio buttons", create_radio_buttons }, - { "range controls", create_range_controls }, - { "rc file", create_rc_file }, - { "reparent", create_reparent }, - { "resize grips", create_resize_grips }, - { "rotated label", create_rotated_label }, - { "rotated text", create_rotated_text }, - { "rulers", create_rulers }, - { "saved position", create_saved_position }, - { "scrolled windows", create_scrolled_windows }, - { "shapes", create_shapes }, - { "size groups", create_size_groups }, - { "spinbutton", create_spins }, - { "statusbar", create_statusbar }, - { "styles", create_styles }, - { "test idle", create_idle_test }, - { "test mainloop", create_mainloop, TRUE }, - { "test scrolling", create_scroll_test }, - { "test selection", create_selection_test }, - { "test timeout", create_timeout_test }, - { "text", create_text }, - { "toggle buttons", create_toggle_buttons }, - { "toolbar", create_toolbar }, - { "tooltips", create_tooltips }, - { "tree", create_tree_mode_window}, - { "WM hints", create_wmhints }, - { "window sizing", create_window_sizing }, - { "window states", create_window_states } -}; -int nbuttons = sizeof (buttons) / sizeof (buttons[0]); - -void -create_main_window (void) -{ - GtkWidget *window; - GtkWidget *box1; - GtkWidget *box2; - GtkWidget *scrolled_window; - GtkWidget *button; - GtkWidget *label; - gchar buffer[64]; - GtkWidget *separator; - GdkGeometry geometry; - int i; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_widget_set_name (window, "main window"); - gtk_widget_set_uposition (window, 20, 20); - gtk_window_set_default_size (GTK_WINDOW (window), -1, 400); - - geometry.min_width = -1; - geometry.min_height = -1; - geometry.max_width = -1; - geometry.max_height = G_MAXSHORT; - gtk_window_set_geometry_hints (GTK_WINDOW (window), NULL, - &geometry, - GDK_HINT_MIN_SIZE | GDK_HINT_MAX_SIZE); - - g_signal_connect (window, "destroy", - G_CALLBACK (gtk_main_quit), - NULL); - g_signal_connect (window, "delete-event", - G_CALLBACK (gtk_false), - NULL); - - box1 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (window), box1); - - if (gtk_micro_version > 0) - sprintf (buffer, - "Gtk+ v%d.%d.%d", - gtk_major_version, - gtk_minor_version, - gtk_micro_version); - else - sprintf (buffer, - "Gtk+ v%d.%d", - gtk_major_version, - gtk_minor_version); - - label = gtk_label_new (buffer); - gtk_box_pack_start (GTK_BOX (box1), label, FALSE, FALSE, 0); - gtk_widget_set_name (label, "testgtk-version-label"); - - scrolled_window = gtk_scrolled_window_new (NULL, NULL); - gtk_container_set_border_width (GTK_CONTAINER (scrolled_window), 10); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), - GTK_POLICY_NEVER, - GTK_POLICY_AUTOMATIC); - gtk_box_pack_start (GTK_BOX (box1), scrolled_window, TRUE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 0); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_window), box2); - gtk_container_set_focus_vadjustment (GTK_CONTAINER (box2), - gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (scrolled_window))); - gtk_widget_show (box2); - - for (i = 0; i < nbuttons; i++) - { - button = gtk_button_new_with_label (buttons[i].label); - if (buttons[i].func) - g_signal_connect (button, - "clicked", - G_CALLBACK(buttons[i].func), - NULL); - else - gtk_widget_set_sensitive (button, FALSE); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - } - - separator = gtk_hseparator_new (); - gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0); - - box2 = gtk_vbox_new (FALSE, 10); - gtk_container_set_border_width (GTK_CONTAINER (box2), 10); - gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0); - - button = gtk_button_new_with_mnemonic ("_Close"); - g_signal_connect (button, "clicked", - G_CALLBACK (do_exit), - window); - gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0); - GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT); - gtk_widget_grab_default (button); + g_signal_connect (window, "delete-event", G_CALLBACK (gtk_main_quit), NULL); gtk_widget_show_all (window); -} - -static void -test_init (void) -{ - if (g_file_test ("../gdk-pixbuf/libpixbufloader-pnm.la", - G_FILE_TEST_EXISTS)) - { - g_setenv ("GDK_PIXBUF_MODULE_FILE", "../gdk-pixbuf/gdk-pixbuf.loaders", TRUE); - g_setenv ("GTK_IM_MODULE_FILE", "../modules/input/gtk.immodules", TRUE); - } -} - -static char * -pad (const char *str, int to) -{ - static char buf[256]; - int len = strlen (str); - int i; - - for (i = 0; i < to; i++) - buf[i] = ' '; - - buf[to] = '\0'; - - memcpy (buf, str, len); - - return buf; -} - -static void -bench_iteration (GtkWidget *widget, void (* fn) (GtkWidget *widget)) -{ - fn (widget); /* on */ - while (g_main_context_iteration (NULL, FALSE)); - fn (widget); /* off */ - while (g_main_context_iteration (NULL, FALSE)); -} - -void -do_real_bench (GtkWidget *widget, void (* fn) (GtkWidget *widget), char *name, int num) -{ - GTimeVal tv0, tv1; - double dt_first; - double dt; - int n; - static gboolean printed_headers = FALSE; - - if (!printed_headers) { - g_print ("Test Iters First Other\n"); - g_print ("-------------------- ----- ---------- ----------\n"); - printed_headers = TRUE; - } - - g_get_current_time (&tv0); - bench_iteration (widget, fn); - g_get_current_time (&tv1); - - dt_first = ((double)tv1.tv_sec - tv0.tv_sec) * 1000.0 - + (tv1.tv_usec - tv0.tv_usec) / 1000.0; - - g_get_current_time (&tv0); - for (n = 0; n < num - 1; n++) - bench_iteration (widget, fn); - g_get_current_time (&tv1); - dt = ((double)tv1.tv_sec - tv0.tv_sec) * 1000.0 - + (tv1.tv_usec - tv0.tv_usec) / 1000.0; - - g_print ("%s %5d ", pad (name, 20), num); - if (num > 1) - g_print ("%10.1f %10.1f\n", dt_first, dt/(num-1)); - else - g_print ("%10.1f\n", dt_first); -} - -void -do_bench (char* what, int num) -{ - int i; - GtkWidget *widget; - void (* fn) (GtkWidget *widget); - fn = NULL; - widget = gtk_window_new (GTK_WINDOW_TOPLEVEL); - if (g_ascii_strcasecmp (what, "ALL") == 0) - { - for (i = 0; i < nbuttons; i++) - { - if (!buttons[i].do_not_benchmark) - do_real_bench (widget, buttons[i].func, buttons[i].label, num); - } - - return; - } - else - { - for (i = 0; i < nbuttons; i++) - { - if (strcmp (buttons[i].label, what) == 0) - { - fn = buttons[i].func; - break; - } - } - - if (!fn) - g_print ("Can't bench: \"%s\" not found.\n", what); - else - do_real_bench (widget, fn, buttons[i].label, num); - } -} + gtk_main (); -void -usage (void) -{ - fprintf (stderr, "Usage: testgtk [--bench ALL|<bench>[:<count>]]\n"); - exit (1); + return 0; } -int -main (int argc, char *argv[]) -{ - GtkBindingSet *binding_set; - int i; - gboolean done_benchmarks = FALSE; - - srand (time (NULL)); - - test_init (); - - /* Check to see if we are being run from the correct - * directory. - */ - if (file_exists ("testgtkrc")) - gtk_rc_add_default_file ("testgtkrc"); - g_set_application_name ("GTK+ Test Program"); - gtk_init (&argc, &argv); - - gtk_accelerator_set_default_mod_mask (GDK_SHIFT_MASK | - GDK_CONTROL_MASK | - GDK_MOD1_MASK | - GDK_META_MASK | - GDK_SUPER_MASK | - GDK_HYPER_MASK | - GDK_MOD4_MASK); - /* benchmarking - */ - for (i = 1; i < argc; i++) - { - if (strncmp (argv[i], "--bench", strlen("--bench")) == 0) - { - int num = 1; - char *nextarg; - char *what; - char *count; - - nextarg = strchr (argv[i], '='); - if (nextarg) - nextarg++; - else - { - i++; - if (i == argc) - usage (); - nextarg = argv[i]; - } - - count = strchr (nextarg, ':'); - if (count) - { - what = g_strndup (nextarg, count - nextarg); - count++; - num = atoi (count); - if (num <= 0) - usage (); - } - else - what = g_strdup (nextarg); - - do_bench (what, num ? num : 1); - done_benchmarks = TRUE; - } - else - usage (); - } - if (done_benchmarks) - return 0; - - /* bindings test - */ - binding_set = gtk_binding_set_by_class (gtk_type_class (GTK_TYPE_WIDGET)); - gtk_binding_entry_add_signal (binding_set, - '9', GDK_CONTROL_MASK | GDK_RELEASE_MASK, - "debug_msg", - 1, - G_TYPE_STRING, "GtkWidgetClass <ctrl><release>9 test"); - - /* We use gtk_rc_parse_string() here so we can make sure it works across theme - * changes - */ - - gtk_rc_parse_string ("style \"testgtk-version-label\" { " - " fg[NORMAL] = \"#ff0000\"\n" - " font = \"Sans 18\"\n" - "}\n" - "widget \"*.testgtk-version-label\" style \"testgtk-version-label\""); - - create_main_window (); - - gtk_main (); - - if (1) - { - while (g_main_context_pending (NULL)) - g_main_context_iteration (NULL, FALSE); -#if 0 - sleep (1); - while (g_main_context_pending (NULL)) - g_main_context_iteration (NULL, FALSE); -#endif - } - return 0; -} diff --git a/tests/textbuffertest.c b/tests/textbuffertest.c index 5c89fb32e8..f8a33a1eb3 100644 --- a/tests/textbuffertest.c +++ b/tests/textbuffertest.c @@ -1284,6 +1284,8 @@ test_tag (void) g_object_unref (buffer); } +extern void pixbuf_init (void); + int main (int argc, char** argv) { @@ -1291,6 +1293,7 @@ main (int argc, char** argv) gtk_debug_flags |= GTK_DEBUG_TEXT; gtk_test_init (&argc, &argv); + pixbuf_init (); g_test_add_func ("/TextBuffer/UTF8 unknown char", test_utf8); g_test_add_func ("/TextBuffer/Line separator", test_line_separator); |