From aadd9ae20113234e5697903a70580347803e335c Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 19:15:06 -0400 Subject: [PATCH 1/7] tests: Drop testbuttons This does not really add much. We have plenty of different button styles in our demos and tests. See #2738 --- tests/meson.build | 1 - tests/testbuttons.c | 123 -------------------------------------------- 2 files changed, 124 deletions(-) delete mode 100644 tests/testbuttons.c diff --git a/tests/meson.build b/tests/meson.build index ad8b6838cb..244e74fbb8 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -17,7 +17,6 @@ gtk_tests = [ ['testappchooserbutton'], ['testassistant'], ['testbaseline'], - ['testbuttons'], ['testcalendar'], ['testclipboard2'], ['testcombo'], diff --git a/tests/testbuttons.c b/tests/testbuttons.c deleted file mode 100644 index cac1b578a0..0000000000 --- a/tests/testbuttons.c +++ /dev/null @@ -1,123 +0,0 @@ -/* testbuttons.c - * Copyright (C) 2009 Red Hat, Inc. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library 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 - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include - -/* various combinations of use_underline */ - -int main (int argc, char *argv[]) -{ - GtkWidget *window, *box, *button, *hbox; - gchar *text; - const char *icon_name; - gboolean use_underline; - GtkWidget *label; - - gtk_init (); - - window = gtk_window_new (); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - - gtk_window_set_child (GTK_WINDOW (window), box); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = g_object_new (GTK_TYPE_BUTTON, - "label", "document-save", - NULL); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_with_label ("_Save"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_with_mnemonic ("_Save"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_from_icon_name ("help-about"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new (); - gtk_button_set_icon_name (GTK_BUTTON (button), "help-about"); - gtk_button_set_use_underline (GTK_BUTTON (button), TRUE); - gtk_box_append (GTK_BOX (hbox), button); - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} - From 52c630d9940fa26f85a328eb2609b76bac33792a Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 19:43:01 -0400 Subject: [PATCH 2/7] tests: Drop testgiconpixbuf More a pixbuf test, and we don't support emblems anymore. See #2738 --- tests/meson.build | 1 - tests/testgiconpixbuf.c | 91 ----------------------------------------- 2 files changed, 92 deletions(-) delete mode 100644 tests/testgiconpixbuf.c diff --git a/tests/meson.build b/tests/meson.build index 244e74fbb8..15768ca5e7 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -36,7 +36,6 @@ gtk_tests = [ ['testfontoptions'], ['testframe'], ['testfullscreen'], - ['testgiconpixbuf'], ['testglarea'], ['testglblending', ['gtkgears.c']], ['testgrid'], diff --git a/tests/testgiconpixbuf.c b/tests/testgiconpixbuf.c deleted file mode 100644 index 16b3c1a991..0000000000 --- a/tests/testgiconpixbuf.c +++ /dev/null @@ -1,91 +0,0 @@ -/* testgiconpixbuf.c - * Copyright (C) 2010 Red Hat, Inc. - * Authors: Cosimo Cecchi - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library 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 - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include -#include - -static void -quit_cb (GtkWidget *widget, - gpointer data) -{ - gboolean *done = data; - - *done = TRUE; - - g_main_context_wakeup (NULL); -} - -int -main (int argc, - char **argv) -{ - GdkPixbuf *pixbuf, *otherpix; - GtkWidget *image, *image2, *hbox, *vbox, *label, *toplevel; - GIcon *emblemed; - GEmblem *emblem; - gchar *str; - gboolean done = FALSE; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - pixbuf = gdk_pixbuf_new_from_file ("apple-red.png", NULL); - toplevel = gtk_window_new (); - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); - gtk_window_set_child (GTK_WINDOW (toplevel), hbox); - - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - gtk_box_append (GTK_BOX (hbox), vbox); - - image = gtk_image_new_from_gicon (G_ICON (pixbuf)); - gtk_image_set_icon_size (GTK_IMAGE (image), GTK_ICON_SIZE_LARGE); - gtk_box_append (GTK_BOX (vbox), image); - - label = gtk_label_new (NULL); - str = g_strdup_printf ("Normal icon, hash %u", g_icon_hash (G_ICON (pixbuf))); - gtk_label_set_label (GTK_LABEL (label), str); - gtk_box_append (GTK_BOX (vbox), label); - - otherpix = gdk_pixbuf_new_from_file ("gnome-textfile.png", NULL); - emblem = g_emblem_new (G_ICON (otherpix)); - emblemed = g_emblemed_icon_new (G_ICON (pixbuf), emblem); - - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - gtk_box_append (GTK_BOX (hbox), vbox); - - image2 = gtk_image_new_from_gicon (emblemed); - gtk_image_set_icon_size (GTK_IMAGE (image2), GTK_ICON_SIZE_LARGE); - gtk_box_append (GTK_BOX (vbox), image2); - - label = gtk_label_new (NULL); - str = g_strdup_printf ("Emblemed icon, hash %u", g_icon_hash (emblemed)); - gtk_label_set_label (GTK_LABEL (label), str); - gtk_box_append (GTK_BOX (vbox), label); - - gtk_widget_show (toplevel); - - g_signal_connect (toplevel, "destroy", G_CALLBACK (quit_cb), &done); - - while (!done) - g_main_context_iteration (NULL, TRUE); - - return 0; -} From dca142d5d23ac14694b1d0123a87b3574a9f651d Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 19:44:54 -0400 Subject: [PATCH 3/7] tests: Drop testemblems We no longer support emblems on icons. See #2738 --- tests/meson.build | 1 - tests/testemblems.c | 42 ------------------------------------------ 2 files changed, 43 deletions(-) delete mode 100644 tests/testemblems.c diff --git a/tests/meson.build b/tests/meson.build index 15768ca5e7..b02f4f015d 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -27,7 +27,6 @@ gtk_tests = [ ['testdnd2'], ['testdnd3'], ['testellipsise'], - ['testemblems'], ['testentrycompletion'], ['testentryicons'], ['testfilechooser'], diff --git a/tests/testemblems.c b/tests/testemblems.c deleted file mode 100644 index d94b56cafa..0000000000 --- a/tests/testemblems.c +++ /dev/null @@ -1,42 +0,0 @@ -#include - -int main (int argc, char **argv) -{ - GtkWidget *window; - GtkWidget *button; - GtkWidget *grid; - GIcon *icon; - GIcon *icon2; - - gtk_init (); - - window = gtk_window_new (); - - grid = gtk_grid_new (); - gtk_grid_set_row_spacing (GTK_GRID (grid), 12); - gtk_grid_set_column_spacing (GTK_GRID (grid), 12); - gtk_window_set_child (GTK_WINDOW (window), grid); - - icon = g_themed_icon_new ("folder"); - button = gtk_image_new_from_gicon (icon); - gtk_grid_attach (GTK_GRID (grid), button, 1, 1, 1, 1); - - icon2 = g_themed_icon_new ("folder-symbolic"); - button = gtk_image_new_from_gicon (icon2); - gtk_grid_attach (GTK_GRID (grid), button, 2, 1, 1, 1); - - icon = g_emblemed_icon_new (icon, g_emblem_new (g_themed_icon_new ("emblem-new"))); - button = gtk_image_new_from_gicon (icon); - gtk_grid_attach (GTK_GRID (grid), button, 1, 2, 1, 1); - - icon2 = g_emblemed_icon_new (icon2, g_emblem_new (g_themed_icon_new ("emblem-new"))); - button = gtk_image_new_from_gicon (icon2); - gtk_grid_attach (GTK_GRID (grid), button, 2, 2, 1, 1); - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} From 4079b782d6263376a4455b44fd7b10e81d8c9d45 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 19:48:08 -0400 Subject: [PATCH 4/7] tests: Drop testorientable Not really that interesting, and it only tests a single case of orientable, a box. See #2738 --- tests/meson.build | 1 - tests/testorientable.c | 98 ------------------------------------------ 2 files changed, 99 deletions(-) delete mode 100644 tests/testorientable.c diff --git a/tests/meson.build b/tests/meson.build index b02f4f015d..39bc6c2b47 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -57,7 +57,6 @@ gtk_tests = [ ['testmountoperation'], ['testnotebookdnd'], ['testnouiprint'], - ['testorientable'], ['testoverlay'], ['testoverlaystyleclass'], ['testprint', ['testprintfileoperation.c']], diff --git a/tests/testorientable.c b/tests/testorientable.c deleted file mode 100644 index d312ec7207..0000000000 --- a/tests/testorientable.c +++ /dev/null @@ -1,98 +0,0 @@ -/* testorientable.c - * Copyright (C) 2004 Red Hat, Inc. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library 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 - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include - -static void -orient_toggled (GtkToggleButton *button, gpointer user_data) -{ - GList *orientables = (GList *) user_data, *ptr; - gboolean state = gtk_toggle_button_get_active (button); - GtkOrientation orientation; - - if (state) - { - orientation = GTK_ORIENTATION_VERTICAL; - gtk_button_set_label (GTK_BUTTON (button), "Vertical"); - } - else - { - orientation = GTK_ORIENTATION_HORIZONTAL; - gtk_button_set_label (GTK_BUTTON (button), "Horizontal"); - } - - for (ptr = orientables; ptr; ptr = ptr->next) - { - GtkOrientable *orientable = GTK_ORIENTABLE (ptr->data); - - gtk_orientable_set_orientation (orientable, orientation); - } -} - -static void -quit_cb (GtkWidget *widget, - gpointer data) -{ - gboolean *done = data; - - *done = TRUE; - - g_main_context_wakeup (NULL); -} - -int -main (int argc, char **argv) -{ - GtkWidget *window; - GtkWidget *vbox; - GtkWidget *box, *button; - GList *orientables = NULL; - gboolean done = FALSE; - - gtk_init (); - - window = gtk_window_new (); - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - - button = gtk_toggle_button_new_with_label ("Horizontal"); - gtk_box_append (GTK_BOX (vbox), button); - - /* GtkBox */ - box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6); - orientables = g_list_prepend (orientables, box); - gtk_box_append (GTK_BOX (vbox), box); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 1")); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 2")); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 3")); - - g_signal_connect (button, "toggled", - G_CALLBACK (orient_toggled), orientables); - - gtk_window_set_child (GTK_WINDOW (window), vbox); - gtk_widget_show (window); - - g_signal_connect (window, "destroy", - G_CALLBACK (quit_cb), &done); - - while (!done) - g_main_context_iteration (NULL, TRUE); - - return 0; -} From 1e2b5a9c19c2072dac430d80f17b719771272dc5 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 20:01:45 -0400 Subject: [PATCH 5/7] tests: Consolidate all headerbar tests No need to have several binaries for this. See #2738 --- tests/meson.build | 3 - tests/testheaderbar.c | 167 --------------------- tests/testheaderbar2.c | 297 +++++++++++++++++++++++++++++++++++++ tests/testsplitheaders.c | 80 ---------- tests/teststackedheaders.c | 55 ------- 5 files changed, 297 insertions(+), 305 deletions(-) delete mode 100644 tests/testheaderbar.c delete mode 100644 tests/testsplitheaders.c delete mode 100644 tests/teststackedheaders.c diff --git a/tests/meson.build b/tests/meson.build index 39bc6c2b47..4fdfa766c9 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -39,7 +39,6 @@ gtk_tests = [ ['testglblending', ['gtkgears.c']], ['testgrid'], ['testgtk'], - ['testheaderbar'], ['testheaderbar2'], ['testheightforwidth'], ['testhover'], @@ -95,8 +94,6 @@ gtk_tests = [ ['testrevealer'], ['testrevealer2'], ['testtreelistmodel'], - ['testsplitheaders'], - ['teststackedheaders'], ['testwindowsize'], ['testpopover'], ['listmodel'], diff --git a/tests/testheaderbar.c b/tests/testheaderbar.c deleted file mode 100644 index 2390b438e5..0000000000 --- a/tests/testheaderbar.c +++ /dev/null @@ -1,167 +0,0 @@ -#include - -static const gchar css[] = - ".main.background { " - " background-image: linear-gradient(to bottom, red, blue);" - " border-width: 0px; " - "}" - ".titlebar.backdrop { " - " background-image: none; " - " background-color: @bg_color; " - " border-radius: 10px 10px 0px 0px; " - "}" - ".titlebar { " - " background-image: linear-gradient(to bottom, white, @bg_color);" - " border-radius: 10px 10px 0px 0px; " - "}"; - -static void -on_bookmark_clicked (GtkButton *button, gpointer data) -{ - GtkWindow *window = GTK_WINDOW (data); - GtkWidget *chooser; - - chooser = gtk_file_chooser_dialog_new ("File Chooser Test", - window, - GTK_FILE_CHOOSER_ACTION_OPEN, - "_Close", - GTK_RESPONSE_CLOSE, - NULL); - - g_signal_connect (chooser, "response", - G_CALLBACK (gtk_window_destroy), NULL); - - gtk_widget_show (chooser); -} - -static GtkWidget *header; - -static void -toggle_fullscreen (GtkButton *button, gpointer data) -{ - GtkWidget *window = GTK_WIDGET (data); - static gboolean fullscreen = FALSE; - - if (fullscreen) - { - gtk_window_unfullscreen (GTK_WINDOW (window)); - fullscreen = FALSE; - } - else - { - gtk_window_fullscreen (GTK_WINDOW (window)); - fullscreen = TRUE; - } -} - -static gboolean done = FALSE; - -static void -quit_cb (GtkWidget *widget, - gpointer user_data) -{ - gboolean *is_done = user_data; - - *is_done = TRUE; - - g_main_context_wakeup (NULL); -} - -static void -change_header (GtkButton *button, gpointer data) -{ - GtkWidget *window = GTK_WIDGET (data); - GtkWidget *label; - GtkWidget *widget; - GtkWidget *image; - - if (button && gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button))) - { - header = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 10); - gtk_widget_add_css_class (header, "titlebar"); - gtk_widget_add_css_class (header, "header-bar"); - gtk_widget_set_margin_start (header, 10); - gtk_widget_set_margin_end (header, 10); - gtk_widget_set_margin_top (header, 10); - gtk_widget_set_margin_bottom (header, 10); - label = gtk_label_new ("Label"); - gtk_box_append (GTK_BOX (header), label); - widget = gtk_level_bar_new (); - gtk_level_bar_set_value (GTK_LEVEL_BAR (widget), 0.4); - gtk_widget_set_hexpand (widget, TRUE); - gtk_box_append (GTK_BOX (header), widget); - } - else - { - header = gtk_header_bar_new (); - gtk_widget_add_css_class (header, "titlebar"); - - widget = gtk_button_new_with_label ("_Close"); - gtk_button_set_use_underline (GTK_BUTTON (widget), TRUE); - gtk_widget_add_css_class (widget, "suggested-action"); - g_signal_connect (widget, "clicked", G_CALLBACK (quit_cb), &done); - - gtk_header_bar_pack_end (GTK_HEADER_BAR (header), widget); - - widget= gtk_button_new (); - image = gtk_image_new_from_icon_name ("bookmark-new-symbolic"); - g_signal_connect (widget, "clicked", G_CALLBACK (on_bookmark_clicked), window); - gtk_button_set_child (GTK_BUTTON (widget), image); - - gtk_header_bar_pack_start (GTK_HEADER_BAR (header), widget); - } - - gtk_window_set_titlebar (GTK_WINDOW (window), header); -} - -int -main (int argc, char *argv[]) -{ - GtkWidget *window; - GtkWidget *box; - GtkWidget *footer; - GtkWidget *button; - GtkWidget *content; - GtkCssProvider *provider; - - gtk_init (); - - window = gtk_window_new (); - gtk_widget_add_css_class (window, "main"); - - provider = gtk_css_provider_new (); - gtk_css_provider_load_from_data (provider, css, -1); - gtk_style_context_add_provider_for_display (gtk_widget_get_display (window), - GTK_STYLE_PROVIDER (provider), - GTK_STYLE_PROVIDER_PRIORITY_USER); - - - change_header (NULL, window); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_set_child (GTK_WINDOW (window), box); - - content = gtk_image_new_from_icon_name ("start-here-symbolic"); - gtk_image_set_pixel_size (GTK_IMAGE (content), 512); - gtk_widget_set_vexpand (content, TRUE); - - gtk_box_append (GTK_BOX (box), content); - - footer = gtk_action_bar_new (); - gtk_action_bar_set_center_widget (GTK_ACTION_BAR (footer), gtk_check_button_new_with_label ("Middle")); - button = gtk_toggle_button_new_with_label ("Custom"); - g_signal_connect (button, "clicked", G_CALLBACK (change_header), window); - gtk_action_bar_pack_start (GTK_ACTION_BAR (footer), button); - button = gtk_button_new_with_label ("Fullscreen"); - gtk_action_bar_pack_end (GTK_ACTION_BAR (footer), button); - g_signal_connect (button, "clicked", G_CALLBACK (toggle_fullscreen), window); - gtk_box_append (GTK_BOX (box), footer); - gtk_widget_show (window); - - while (!done) - g_main_context_iteration (NULL, TRUE); - - gtk_window_destroy (GTK_WINDOW (window)); - - return 0; -} diff --git a/tests/testheaderbar2.c b/tests/testheaderbar2.c index 309bbb594a..6326e54cc0 100644 --- a/tests/testheaderbar2.c +++ b/tests/testheaderbar2.c @@ -214,6 +214,300 @@ create_fake_headerbar (GtkApplication *app) gtk_widget_show (window); } +/* split headerbar */ + +static void +split_decorations (GtkSettings *settings, + GParamSpec *pspec, + GtkBuilder *builder) +{ + GtkWidget *sheader, *mheader; + gchar *layout, *p1, *p2; + gchar **p; + + sheader = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); + mheader = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); + + g_object_get (settings, "gtk-decoration-layout", &layout, NULL); + + p = g_strsplit (layout, ":", -1); + + p1 = g_strconcat ("", p[0], ":", NULL); + + if (g_strv_length (p) >= 2) + p2 = g_strconcat (":", p[1], NULL); + else + p2 = g_strdup (""); + + gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (sheader), p1); + gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (mheader), p2); + + g_free (p1); + g_free (p2); + g_strfreev (p); + g_free (layout); +} + + +static void +create_split_headerbar (GtkApplication *app) +{ + GtkBuilder *builder; + GtkSettings *settings; + GtkWidget *win; + GtkWidget *entry; + GtkWidget *check; + GtkWidget *header; + const char *ui = "tests/testsplitheaders.ui"; + + if (!g_file_test (ui, G_FILE_TEST_EXISTS)) + { + g_warning ("Can't find %s", ui); + return; + } + + builder = gtk_builder_new_from_file (ui); + + win = (GtkWidget *)gtk_builder_get_object (builder, "window"); + gtk_window_set_application (GTK_WINDOW (win), app); + + settings = gtk_widget_get_settings (win); + + g_signal_connect (settings, "notify::gtk-decoration-layout", + G_CALLBACK (split_decorations), builder); + split_decorations (settings, NULL, builder); + + entry = (GtkWidget *)gtk_builder_get_object (builder, "layout-entry"); + g_object_bind_property (settings, "gtk-decoration-layout", + entry, "text", + G_BINDING_BIDIRECTIONAL|G_BINDING_SYNC_CREATE); + check = (GtkWidget *)gtk_builder_get_object (builder, "decorations"); + header = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); + g_object_bind_property (check, "active", + header, "show-title-buttons", + G_BINDING_DEFAULT); + header = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); + g_object_bind_property (check, "active", + header, "show-title-buttons", + G_BINDING_DEFAULT); + gtk_window_present (GTK_WINDOW (win)); +} + +/* stacked headers */ + +static void +back_to_main (GtkButton *button, + GtkWidget *win) +{ + GtkWidget *header_stack; + GtkWidget *page_stack; + + header_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "header-stack")); + page_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "page-stack")); + + gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "main"); + gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "page1"); +} + +static void +go_to_secondary (GtkButton *button, + GtkWidget *win) +{ + GtkWidget *header_stack; + GtkWidget *page_stack; + + header_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "header-stack")); + page_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "page-stack")); + + gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "secondary"); + gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "secondary"); +} + +static void +create_stacked_headerbar (GtkApplication *app) +{ + GtkBuilder *builder; + GtkWidget *win; + GtkWidget *new_btn; + GtkWidget *back_btn; + GtkWidget *header_stack; + GtkWidget *page_stack; + const char *ui = "tests/teststackedheaders.ui"; + + if (!g_file_test (ui, G_FILE_TEST_EXISTS)) + { + g_warning ("Can't find %s", ui); + return; + } + + builder = gtk_builder_new (); + gtk_builder_add_from_file (builder, ui, NULL); + + win = (GtkWidget *)gtk_builder_get_object (builder, "window"); + gtk_window_set_application (GTK_WINDOW (win), app); + + header_stack = (GtkWidget *)gtk_builder_get_object (builder, "header_stack"); + page_stack = (GtkWidget *)gtk_builder_get_object (builder, "page_stack"); + + g_object_set_data (G_OBJECT (win), "header-stack", header_stack); + g_object_set_data (G_OBJECT (win), "page-stack", page_stack); + + new_btn = (GtkWidget *)gtk_builder_get_object (builder, "new_btn"); + back_btn = (GtkWidget *)gtk_builder_get_object (builder, "back_btn"); + + g_signal_connect (new_btn, "clicked", G_CALLBACK (go_to_secondary), win); + g_signal_connect (back_btn, "clicked", G_CALLBACK (back_to_main), win); + + gtk_window_present (GTK_WINDOW (win)); +} + +/* technorama */ + +static const gchar css[] = + ".main.background { " + " background-image: linear-gradient(to bottom, red, blue);" + " border-width: 0px; " + "}" + ".titlebar.backdrop { " + " background-image: none; " + " background-color: @bg_color; " + " border-radius: 10px 10px 0px 0px; " + "}" + ".titlebar { " + " background-image: linear-gradient(to bottom, white, @bg_color);" + " border-radius: 10px 10px 0px 0px; " + "}"; + +static void +on_bookmark_clicked (GtkButton *button, gpointer data) +{ + GtkWindow *window = GTK_WINDOW (data); + GtkWidget *chooser; + + chooser = gtk_file_chooser_dialog_new ("File Chooser Test", + window, + GTK_FILE_CHOOSER_ACTION_OPEN, + "_Close", + GTK_RESPONSE_CLOSE, + NULL); + + g_signal_connect (chooser, "response", + G_CALLBACK (gtk_window_destroy), NULL); + + gtk_widget_show (chooser); +} + +static void +toggle_fullscreen (GtkButton *button, gpointer data) +{ + GtkWidget *window = GTK_WIDGET (data); + static gboolean fullscreen = FALSE; + + if (fullscreen) + { + gtk_window_unfullscreen (GTK_WINDOW (window)); + fullscreen = FALSE; + } + else + { + gtk_window_fullscreen (GTK_WINDOW (window)); + fullscreen = TRUE; + } +} + +static void +change_header (GtkButton *button, gpointer data) +{ + GtkWidget *window = GTK_WIDGET (data); + GtkWidget *label; + GtkWidget *widget; + GtkWidget *image; + GtkWidget *header; + + if (button && gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button))) + { + header = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 10); + gtk_widget_add_css_class (header, "titlebar"); + gtk_widget_add_css_class (header, "header-bar"); + gtk_widget_set_margin_start (header, 10); + gtk_widget_set_margin_end (header, 10); + gtk_widget_set_margin_top (header, 10); + gtk_widget_set_margin_bottom (header, 10); + label = gtk_label_new ("Label"); + gtk_box_append (GTK_BOX (header), label); + widget = gtk_level_bar_new (); + gtk_level_bar_set_value (GTK_LEVEL_BAR (widget), 0.4); + gtk_widget_set_hexpand (widget, TRUE); + gtk_box_append (GTK_BOX (header), widget); + } + else + { + header = gtk_header_bar_new (); + gtk_widget_add_css_class (header, "titlebar"); + + widget = gtk_button_new_with_label ("_Close"); + gtk_button_set_use_underline (GTK_BUTTON (widget), TRUE); + gtk_widget_add_css_class (widget, "suggested-action"); + g_signal_connect_swapped (widget, "clicked", G_CALLBACK (gtk_window_destroy), window); + + gtk_header_bar_pack_end (GTK_HEADER_BAR (header), widget); + + widget= gtk_button_new (); + image = gtk_image_new_from_icon_name ("bookmark-new-symbolic"); + g_signal_connect (widget, "clicked", G_CALLBACK (on_bookmark_clicked), window); + gtk_button_set_child (GTK_BUTTON (widget), image); + + gtk_header_bar_pack_start (GTK_HEADER_BAR (header), widget); + } + + gtk_window_set_titlebar (GTK_WINDOW (window), header); +} + +static void +create_technorama (GtkApplication *app) +{ + GtkWidget *window; + GtkWidget *box; + GtkWidget *footer; + GtkWidget *button; + GtkWidget *content; + GtkCssProvider *provider; + + window = gtk_window_new (); + gtk_window_set_application (GTK_WINDOW (window), app); + + gtk_widget_add_css_class (window, "main"); + + provider = gtk_css_provider_new (); + gtk_css_provider_load_from_data (provider, css, -1); + gtk_style_context_add_provider_for_display (gtk_widget_get_display (window), + GTK_STYLE_PROVIDER (provider), + GTK_STYLE_PROVIDER_PRIORITY_USER); + + + change_header (NULL, window); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + gtk_window_set_child (GTK_WINDOW (window), box); + + content = gtk_image_new_from_icon_name ("start-here-symbolic"); + gtk_image_set_pixel_size (GTK_IMAGE (content), 512); + gtk_widget_set_vexpand (content, TRUE); + + gtk_box_append (GTK_BOX (box), content); + + footer = gtk_action_bar_new (); + gtk_action_bar_set_center_widget (GTK_ACTION_BAR (footer), gtk_check_button_new_with_label ("Middle")); + button = gtk_toggle_button_new_with_label ("Custom"); + g_signal_connect (button, "clicked", G_CALLBACK (change_header), window); + gtk_action_bar_pack_start (GTK_ACTION_BAR (footer), button); + button = gtk_button_new_with_label ("Fullscreen"); + gtk_action_bar_pack_end (GTK_ACTION_BAR (footer), button); + g_signal_connect (button, "clicked", G_CALLBACK (toggle_fullscreen), window); + gtk_box_append (GTK_BOX (box), footer); + gtk_widget_show (window); +} + struct { const gchar *name; void (*cb) (GtkApplication *app); @@ -225,6 +519,9 @@ struct { { "Headerbar overlaying content", create_headerbar_overlay }, { "Hiding headerbar", create_hiding_headerbar }, { "Fake headerbar", create_fake_headerbar }, + { "Split headerbar", create_split_headerbar }, + { "Stacked headerbar", create_stacked_headerbar }, + { "Technorama", create_technorama }, }; int n_buttons = sizeof (buttons) / sizeof (buttons[0]); diff --git a/tests/testsplitheaders.c b/tests/testsplitheaders.c deleted file mode 100644 index 7bbf8d3c89..0000000000 --- a/tests/testsplitheaders.c +++ /dev/null @@ -1,80 +0,0 @@ -#include -#include - -static void -split_decorations (GtkSettings *settings, - GParamSpec *pspec, - GtkBuilder *builder) -{ - GtkWidget *sheader, *mheader; - gchar *layout, *p1, *p2; - gchar **p; - - sheader = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); - mheader = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); - - g_object_get (settings, "gtk-decoration-layout", &layout, NULL); - - p = g_strsplit (layout, ":", -1); - - p1 = g_strconcat ("", p[0], ":", NULL); - - if (g_strv_length (p) >= 2) - p2 = g_strconcat (":", p[1], NULL); - else - p2 = g_strdup (""); - - gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (sheader), p1); - gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (mheader), p2); - - g_free (p1); - g_free (p2); - g_strfreev (p); - g_free (layout); -} - -int -main (int argc, char *argv[]) -{ - GtkBuilder *builder; - GtkSettings *settings; - GtkWidget *win; - GtkWidget *entry; - GtkWidget *check; - GtkWidget *header; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - builder = gtk_builder_new_from_file ("testsplitheaders.ui"); - - win = (GtkWidget *)gtk_builder_get_object (builder, "window"); - settings = gtk_widget_get_settings (win); - - g_signal_connect (settings, "notify::gtk-decoration-layout", - G_CALLBACK (split_decorations), builder); - split_decorations (settings, NULL, builder); - - entry = (GtkWidget *)gtk_builder_get_object (builder, "layout-entry"); - g_object_bind_property (settings, "gtk-decoration-layout", - entry, "text", - G_BINDING_BIDIRECTIONAL|G_BINDING_SYNC_CREATE); - check = (GtkWidget *)gtk_builder_get_object (builder, "decorations"); - header = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); - g_object_bind_property (check, "active", - header, "show-title-buttons", - G_BINDING_DEFAULT); - header = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); - g_object_bind_property (check, "active", - header, "show-title-buttons", - G_BINDING_DEFAULT); - gtk_window_present (GTK_WINDOW (win)); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/teststackedheaders.c b/tests/teststackedheaders.c deleted file mode 100644 index 3435418238..0000000000 --- a/tests/teststackedheaders.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -static GtkWidget *header_stack; -static GtkWidget *page_stack; - -static void -back_to_main (GtkButton *button) -{ - gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "main"); - gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "page1"); -} - -static void -go_to_secondary (GtkButton *button) -{ - gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "secondary"); - gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "secondary"); -} - -int -main (int argc, char *argv[]) -{ - GtkBuilder *builder; - GtkWidget *win; - GtkWidget *new_btn; - GtkWidget *back_btn; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - builder = gtk_builder_new (); - gtk_builder_add_from_file (builder, "teststackedheaders.ui", NULL); - - win = (GtkWidget *)gtk_builder_get_object (builder, "window"); - header_stack = (GtkWidget *)gtk_builder_get_object (builder, "header_stack"); - page_stack = (GtkWidget *)gtk_builder_get_object (builder, "page_stack"); - new_btn = (GtkWidget *)gtk_builder_get_object (builder, "new_btn"); - back_btn = (GtkWidget *)gtk_builder_get_object (builder, "back_btn"); - - g_signal_connect (new_btn, "clicked", G_CALLBACK (go_to_secondary), NULL); - g_signal_connect (back_btn, "clicked", G_CALLBACK (back_to_main), NULL); - - g_assert (header_stack); - - gtk_window_present (GTK_WINDOW (win)); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} From 9e8d845a61548e1fb1a3037a472fd88377e498b4 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 20:15:59 -0400 Subject: [PATCH 6/7] tests: Rename testheaderbar2 to testheaderbar There is only one headerbar test now. --- tests/meson.build | 2 +- tests/{testheaderbar2.c => testheaderbar.c} | 0 2 files changed, 1 insertion(+), 1 deletion(-) rename tests/{testheaderbar2.c => testheaderbar.c} (100%) diff --git a/tests/meson.build b/tests/meson.build index 4fdfa766c9..5b4b5603d3 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -39,7 +39,7 @@ gtk_tests = [ ['testglblending', ['gtkgears.c']], ['testgrid'], ['testgtk'], - ['testheaderbar2'], + ['testheaderbar'], ['testheightforwidth'], ['testhover'], ['testiconview'], diff --git a/tests/testheaderbar2.c b/tests/testheaderbar.c similarity index 100% rename from tests/testheaderbar2.c rename to tests/testheaderbar.c From dcfb4690c32780a8c5e27845481309af70153cb7 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Thu, 14 May 2020 20:32:53 -0400 Subject: [PATCH 7/7] tests: Drop testdnd3 This has been integrated in gtk4-demo as the DND example. See #2738 --- tests/meson.build | 1 - tests/testdnd3.c | 326 ---------------------------------------------- 2 files changed, 327 deletions(-) delete mode 100644 tests/testdnd3.c diff --git a/tests/meson.build b/tests/meson.build index 5b4b5603d3..5cb5a04d92 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -25,7 +25,6 @@ gtk_tests = [ ['testdialog'], ['testdnd'], ['testdnd2'], - ['testdnd3'], ['testellipsise'], ['testentrycompletion'], ['testentryicons'], diff --git a/tests/testdnd3.c b/tests/testdnd3.c deleted file mode 100644 index 3dd96bb35c..0000000000 --- a/tests/testdnd3.c +++ /dev/null @@ -1,326 +0,0 @@ -#include - -static GdkContentProvider * -prepare (GtkDragSource *source, double x, double y) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = gtk_widget_pick (canvas, x, y, GTK_PICK_DEFAULT); - - if (!GTK_IS_LABEL (item)) - return NULL; - - g_object_set_data (G_OBJECT (canvas), "dragged-item", item); - - return gdk_content_provider_new_typed (GTK_TYPE_WIDGET, item); -} - -static void -drag_begin (GtkDragSource *source, GdkDrag *drag) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = g_object_get_data (G_OBJECT (canvas), "dragged-item"); - - gtk_widget_set_opacity (item, 0.5); -} - -static void -drag_end (GtkDragSource *source, GdkDrag *drag) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = g_object_get_data (G_OBJECT (canvas), "dragged-item"); - g_object_set_data (G_OBJECT (canvas), "dragged-item", NULL); - - gtk_widget_set_opacity (item, 1.0); -} - -static void -drag_cancel (GtkDragSource *source, - GdkDrag *drag, - GdkDragCancelReason reason) -{ - drag_end (source, drag); -} - -typedef struct { - double x, y; - double angle; - double delta; -} TransformData; - -static void -apply_transform (GtkWidget *item) -{ - GtkWidget *canvas = gtk_widget_get_parent (item); - TransformData *data; - GskTransform *transform; - - data = g_object_get_data (G_OBJECT (item), "transform-data"); - transform = gsk_transform_rotate (gsk_transform_translate (NULL, &(graphene_point_t){data->x, data->y}), - data->angle + data->delta); - gtk_fixed_set_child_transform (GTK_FIXED (canvas), item, transform); - gsk_transform_unref (transform); -} - -static gboolean -drag_drop (GtkDropTarget *target, - const GValue *value, - double x, - double y) -{ - GtkWidget *item; - TransformData *transform_data; - GtkWidget *canvas; - GtkWidget *last_child; - - item = g_value_get_object (value); - transform_data = g_object_get_data (G_OBJECT (item), "transform-data"); - - transform_data->x = x; - transform_data->y = y; - - canvas = gtk_widget_get_parent (item); - last_child = gtk_widget_get_last_child (canvas); - if (item != last_child) - gtk_widget_insert_after (item, canvas, last_child); - - apply_transform (item); - - return TRUE; -} - -static GtkWidget * -canvas_new (void) -{ - GtkWidget *canvas; - GtkDragSource *source; - GtkDropTarget *dest; - - canvas = gtk_fixed_new (); - gtk_widget_set_hexpand (canvas, TRUE); - gtk_widget_set_vexpand (canvas, TRUE); - gtk_widget_add_css_class (canvas, "frame"); - - source = gtk_drag_source_new (); - gtk_drag_source_set_actions (source, GDK_ACTION_MOVE); - g_signal_connect (source, "prepare", G_CALLBACK (prepare), NULL); - g_signal_connect (source, "drag-begin", G_CALLBACK (drag_begin), NULL); - g_signal_connect (source, "drag-end", G_CALLBACK (drag_end), NULL); - g_signal_connect (source, "drag-cancel", G_CALLBACK (drag_cancel), NULL); - gtk_widget_add_controller (canvas, GTK_EVENT_CONTROLLER (source)); - - dest = gtk_drop_target_new (GTK_TYPE_WIDGET, GDK_ACTION_MOVE); - g_signal_connect (dest, "drop", G_CALLBACK (drag_drop), NULL); - gtk_widget_add_controller (canvas, GTK_EVENT_CONTROLLER (dest)); - - return canvas; -} - -static void -set_color (GtkWidget *item, - GdkRGBA *color) -{ - char *css; - char *str; - GtkStyleContext *context; - GtkCssProvider *provider; - - str = gdk_rgba_to_string (color); - css = g_strdup_printf ("* { background: %s; padding: 10px; }", str); - - context = gtk_widget_get_style_context (item); - provider = g_object_get_data (G_OBJECT (context), "style-provider"); - if (provider) - gtk_style_context_remove_provider (context, GTK_STYLE_PROVIDER (provider)); - - provider = gtk_css_provider_new (); - gtk_css_provider_load_from_data (provider, css, -1); - gtk_style_context_add_provider (gtk_widget_get_style_context (item), GTK_STYLE_PROVIDER (provider), 800); - g_object_set_data_full (G_OBJECT (context), "style-provider", provider, g_object_unref); - - g_free (str); - g_free (css); -} - -static gboolean -item_drag_drop (GtkDropTarget *dest, - const GValue *value, - double x, - double y) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (dest)); - - set_color (item, g_value_get_boxed (value)); - - return TRUE; -} - -static void -angle_changed (GtkGestureRotate *gesture, - double angle, - double delta) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - TransformData *data = g_object_get_data (G_OBJECT (item), "transform-data"); - - data->delta = angle / M_PI * 180.0; - - apply_transform (item); -} - -static void -rotate_done (GtkGesture *gesture) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - TransformData *data = g_object_get_data (G_OBJECT (item), "transform-data"); - - data->angle = data->angle + data->delta; - data->delta = 0; -} - -static void -click_done (GtkGesture *gesture) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - GtkWidget *canvas = gtk_widget_get_parent (item); - GtkWidget *last_child; - - last_child = gtk_widget_get_last_child (canvas); - if (item != last_child) - gtk_widget_insert_after (item, canvas, last_child); -} - -static GtkWidget * -canvas_item_new (int i, - double x, - double y, - double angle) -{ - GtkWidget *widget; - char *label; - char *id; - TransformData *transform_data; - GdkRGBA rgba; - GtkDropTarget *dest; - GtkGesture *gesture; - - label = g_strdup_printf ("Item %d", i); - id = g_strdup_printf ("item%d", i); - - gdk_rgba_parse (&rgba, "yellow"); - - widget = gtk_label_new (label); - gtk_widget_add_css_class (widget, "frame"); - gtk_widget_set_name (widget, id); - - set_color (widget, &rgba); - transform_data = g_new0 (TransformData, 1); - transform_data->x = x; - transform_data->y = y; - transform_data->angle = angle; - g_object_set_data_full (G_OBJECT (widget), "transform-data", transform_data, g_free); - - g_free (label); - g_free (id); - - dest = gtk_drop_target_new (GDK_TYPE_RGBA, GDK_ACTION_COPY); - g_signal_connect (dest, "drop", G_CALLBACK (item_drag_drop), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (dest)); - - gesture = gtk_gesture_rotate_new (); - g_signal_connect (gesture, "angle-changed", G_CALLBACK (angle_changed), NULL); - g_signal_connect (gesture, "end", G_CALLBACK (rotate_done), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (gesture)); - - gesture = gtk_gesture_click_new (); - g_signal_connect (gesture, "released", G_CALLBACK (click_done), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (gesture)); - - return widget; -} - -int main (int argc, char *argv[]) -{ - GtkWidget *window; - GtkWidget *sw; - GtkWidget *canvas; - GtkWidget *widget; - GtkWidget *box, *box2, *box3; - const char *colors[] = { - "red", "green", "blue", "magenta", "orange", "gray", "black", "yellow", - "white", "gray", "brown", "pink", "cyan", "bisque", "gold", "maroon", - "navy", "orchid", "olive", "peru", "salmon", "silver", "wheat", - NULL - }; - int i; - int x, y; - - gtk_init (); - - widget = gtk_color_button_new (); - g_object_unref (g_object_ref_sink (widget)); - - window = gtk_window_new (); - gtk_window_set_default_size (GTK_WINDOW (window), 640, 480); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_set_child (GTK_WINDOW (window), box); - - box2 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), box2); - - canvas = canvas_new (); - gtk_box_append (GTK_BOX (box2), canvas); - - x = y = 40; - for (i = 0; i < 4; i++) - { - GtkWidget *item; - - item = canvas_item_new (i, x, y, 0); - gtk_box_append (GTK_BOX (canvas), item); - apply_transform (item); - - x += 150; - y += 100; - } - - sw = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_NEVER); - gtk_box_append (GTK_BOX (box), sw); - - box3 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_widget_add_css_class (box3, "linked"); - gtk_scrolled_window_set_child (GTK_SCROLLED_WINDOW (sw), box3); - - for (i = 0; colors[i]; i++) - { - GdkRGBA rgba; - GtkWidget *swatch; - - gdk_rgba_parse (&rgba, colors[i]); - - swatch = g_object_new (g_type_from_name ("GtkColorSwatch"), - "rgba", &rgba, - "selectable", FALSE, - NULL); - gtk_box_append (GTK_BOX (box3), swatch); - } - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -}