| /* testadjustsize.c |
| * Copyright (C) 2010 Havoc Pennington |
| * |
| * Author: |
| * Havoc Pennington <hp@pobox.com> |
| * |
| * 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 <http://www.gnu.org/licenses/>. |
| */ |
| |
| #include <gtk/gtk.h> |
| |
| static GtkWidget *test_window; |
| |
| enum { |
| TEST_WIDGET_LABEL, |
| TEST_WIDGET_WRAP_LABEL, |
| TEST_WIDGET_IMAGE, |
| TEST_WIDGET_BUTTON, |
| TEST_WIDGET_LAST |
| }; |
| |
| static gboolean done = FALSE; |
| static GtkWidget *test_widgets[TEST_WIDGET_LAST]; |
| |
| static GtkWidget* |
| create_image (void) |
| { |
| return gtk_image_new_from_icon_name ("document-open"); |
| } |
| |
| static GtkWidget* |
| create_label (gboolean wrap) |
| { |
| GtkWidget *widget; |
| |
| widget = gtk_label_new ("This is a label, label label label"); |
| |
| if (wrap) |
| gtk_label_set_wrap (GTK_LABEL (widget), TRUE); |
| |
| return widget; |
| } |
| |
| static GtkWidget* |
| create_button (void) |
| { |
| return gtk_button_new_with_label ("BUTTON!"); |
| } |
| |
| static void |
| quit_cb (GtkWidget *widget, |
| gpointer data) |
| { |
| gboolean *is_done = data; |
| |
| *is_done = TRUE; |
| |
| g_main_context_wakeup (NULL); |
| } |
| |
| static void |
| open_test_window (void) |
| { |
| GtkWidget *grid; |
| int i; |
| |
| test_window = gtk_window_new (); |
| gtk_window_set_title (GTK_WINDOW (test_window), "Tests"); |
| |
| g_signal_connect (test_window, "destroy", G_CALLBACK (quit_cb), &done); |
| |
| gtk_window_set_resizable (GTK_WINDOW (test_window), FALSE); |
| |
| test_widgets[TEST_WIDGET_IMAGE] = create_image (); |
| test_widgets[TEST_WIDGET_LABEL] = create_label (FALSE); |
| test_widgets[TEST_WIDGET_WRAP_LABEL] = create_label (TRUE); |
| test_widgets[TEST_WIDGET_BUTTON] = create_button (); |
| |
| grid = gtk_grid_new (); |
| |
| gtk_window_set_child (GTK_WINDOW (test_window), grid); |
| |
| for (i = 0; i < TEST_WIDGET_LAST; ++i) |
| { |
| gtk_grid_attach (GTK_GRID (grid), test_widgets[i], i % 3, i / 3, 1, 1); |
| } |
| |
| gtk_widget_show (test_window); |
| } |
| |
| static void |
| on_set_small_size_requests (GtkToggleButton *button, |
| void *data) |
| { |
| gboolean has_small_size_requests; |
| int i; |
| |
| has_small_size_requests = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button)); |
| |
| for (i = 0; i < TEST_WIDGET_LAST; ++i) |
| { |
| gtk_widget_set_size_request (test_widgets[i], |
| has_small_size_requests ? 5 : -1, |
| has_small_size_requests ? 5 : -1); |
| } |
| } |
| |
| static void |
| on_set_large_size_requests (GtkToggleButton *button, |
| void *data) |
| { |
| gboolean has_large_size_requests; |
| int i; |
| |
| has_large_size_requests = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button)); |
| |
| for (i = 0; i < TEST_WIDGET_LAST; ++i) |
| { |
| gtk_widget_set_size_request (test_widgets[i], |
| has_large_size_requests ? 200 : -1, |
| has_large_size_requests ? 200 : -1); |
| } |
| } |
| |
| static void |
| open_control_window (void) |
| { |
| GtkWidget *window; |
| GtkWidget *box; |
| GtkWidget *toggle; |
| |
| window = gtk_window_new (); |
| gtk_window_set_title (GTK_WINDOW (window), "Controls"); |
| |
| g_signal_connect (window, "destroy", G_CALLBACK (quit_cb), &done); |
| |
| box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); |
| gtk_window_set_child (GTK_WINDOW (window), box); |
| |
| toggle = |
| gtk_toggle_button_new_with_label ("Set small size requests"); |
| g_signal_connect (G_OBJECT (toggle), |
| "toggled", G_CALLBACK (on_set_small_size_requests), |
| NULL); |
| gtk_box_append (GTK_BOX (box), toggle); |
| |
| toggle = |
| gtk_toggle_button_new_with_label ("Set large size requests"); |
| g_signal_connect (G_OBJECT (toggle), |
| "toggled", G_CALLBACK (on_set_large_size_requests), |
| NULL); |
| gtk_box_append (GTK_BOX (box), toggle); |
| |
| |
| gtk_widget_show (window); |
| } |
| |
| #define TEST_WIDGET(outer) (gtk_overlay_get_child (GTK_OVERLAY (gtk_overlay_get_child (GTK_OVERLAY (outer))))) |
| |
| static GtkWidget* |
| create_widget_visible_border (const char *text) |
| { |
| GtkWidget *outer_box; |
| GtkWidget *inner_box; |
| GtkWidget *test_widget; |
| GtkWidget *label; |
| |
| outer_box = gtk_overlay_new (); |
| gtk_widget_add_css_class (outer_box, "black-bg"); |
| |
| inner_box = gtk_overlay_new (); |
| gtk_widget_add_css_class (inner_box, "blue-bg"); |
| |
| gtk_overlay_set_child (GTK_OVERLAY (outer_box), inner_box); |
| |
| |
| test_widget = gtk_overlay_new (); |
| gtk_widget_add_css_class (test_widget, "red-bg"); |
| |
| gtk_overlay_set_child (GTK_OVERLAY (inner_box), test_widget); |
| |
| label = gtk_label_new (text); |
| gtk_overlay_set_child (GTK_OVERLAY (test_widget), label); |
| |
| g_assert (TEST_WIDGET (outer_box) == test_widget); |
| |
| return outer_box; |
| } |
| |
| static const char* |
| enum_to_string (GType enum_type, |
| int value) |
| { |
| GEnumValue *v; |
| |
| v = g_enum_get_value (g_type_class_peek (enum_type), value); |
| |
| return v->value_nick; |
| } |
| |
| static GtkWidget* |
| create_aligned (GtkAlign halign, |
| GtkAlign valign) |
| { |
| GtkWidget *widget; |
| char *label; |
| |
| label = g_strdup_printf ("h=%s v=%s", |
| enum_to_string (GTK_TYPE_ALIGN, halign), |
| enum_to_string (GTK_TYPE_ALIGN, valign)); |
| |
| widget = create_widget_visible_border (label); |
| |
| g_object_set (G_OBJECT (TEST_WIDGET (widget)), |
| "halign", halign, |
| "valign", valign, |
| "hexpand", TRUE, |
| "vexpand", TRUE, |
| NULL); |
| |
| return widget; |
| } |
| |
| static void |
| open_alignment_window (void) |
| { |
| GtkWidget *grid; |
| int i; |
| GEnumClass *align_class; |
| |
| test_window = gtk_window_new (); |
| gtk_window_set_title (GTK_WINDOW (test_window), "Alignment"); |
| |
| g_signal_connect (test_window, "destroy", G_CALLBACK (quit_cb), &done); |
| |
| gtk_window_set_resizable (GTK_WINDOW (test_window), TRUE); |
| gtk_window_set_default_size (GTK_WINDOW (test_window), 500, 500); |
| |
| align_class = g_type_class_peek (GTK_TYPE_ALIGN); |
| |
| grid = gtk_grid_new (); |
| gtk_grid_set_row_homogeneous (GTK_GRID (grid), TRUE); |
| gtk_grid_set_column_homogeneous (GTK_GRID (grid), TRUE); |
| |
| gtk_window_set_child (GTK_WINDOW (test_window), grid); |
| |
| for (i = 0; i < align_class->n_values; ++i) |
| { |
| int j; |
| for (j = 0; j < align_class->n_values; ++j) |
| { |
| GtkWidget *child = |
| create_aligned(align_class->values[i].value, |
| align_class->values[j].value); |
| |
| gtk_grid_attach (GTK_GRID (grid), child, i, j, 1, 1); |
| } |
| } |
| |
| gtk_widget_show (test_window); |
| } |
| |
| static GtkWidget* |
| create_margined (const char *propname) |
| { |
| GtkWidget *widget; |
| |
| widget = create_widget_visible_border (propname); |
| |
| g_object_set (G_OBJECT (TEST_WIDGET (widget)), |
| propname, 15, |
| "hexpand", TRUE, |
| "vexpand", TRUE, |
| NULL); |
| |
| return widget; |
| } |
| |
| static void |
| open_margin_window (void) |
| { |
| GtkWidget *box; |
| int i; |
| const char *margins[] = { |
| "margin-start", |
| "margin-end", |
| "margin-top", |
| "margin-bottom" |
| }; |
| |
| test_window = gtk_window_new (); |
| gtk_window_set_title (GTK_WINDOW (test_window), "Margin"); |
| |
| g_signal_connect (test_window, "destroy", G_CALLBACK (quit_cb), &done); |
| |
| gtk_window_set_resizable (GTK_WINDOW (test_window), TRUE); |
| |
| box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); |
| |
| gtk_window_set_child (GTK_WINDOW (test_window), box); |
| |
| for (i = 0; i < (int) G_N_ELEMENTS (margins); ++i) |
| { |
| GtkWidget *child = |
| create_margined(margins[i]); |
| |
| gtk_box_append (GTK_BOX (box), child); |
| } |
| |
| gtk_widget_show (test_window); |
| } |
| |
| static void |
| open_valigned_label_window (void) |
| { |
| GtkWidget *window, *box, *label, *frame; |
| |
| window = gtk_window_new (); |
| |
| g_signal_connect (test_window, "destroy", G_CALLBACK (quit_cb), &done); |
| |
| box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); |
| gtk_window_set_child (GTK_WINDOW (window), box); |
| |
| label = gtk_label_new ("Both labels expand"); |
| gtk_box_append (GTK_BOX (box), label); |
| |
| label = gtk_label_new ("Some wrapping text with width-chars = 15 and max-width-chars = 35"); |
| gtk_label_set_wrap (GTK_LABEL (label), TRUE); |
| gtk_label_set_width_chars (GTK_LABEL (label), 15); |
| gtk_label_set_max_width_chars (GTK_LABEL (label), 35); |
| |
| frame = gtk_frame_new (NULL); |
| gtk_frame_set_child (GTK_FRAME (frame), label); |
| |
| gtk_widget_set_valign (frame, GTK_ALIGN_CENTER); |
| gtk_widget_set_halign (frame, GTK_ALIGN_CENTER); |
| |
| gtk_box_append (GTK_BOX (box), frame); |
| |
| gtk_window_present (GTK_WINDOW (window)); |
| } |
| |
| int |
| main (int argc, char *argv[]) |
| { |
| GtkCssProvider *provider; |
| |
| gtk_init (); |
| |
| provider = gtk_css_provider_new (); |
| gtk_css_provider_load_from_data (provider, |
| ".black-bg { background-color: black; }" |
| ".red-bg { background-color: red; }" |
| ".blue-bg { background-color: blue; }", -1); |
| gtk_style_context_add_provider_for_display (gdk_display_get_default (), |
| GTK_STYLE_PROVIDER (provider), |
| GTK_STYLE_PROVIDER_PRIORITY_APPLICATION); |
| g_object_unref (provider); |
| |
| if (g_getenv ("RTL")) |
| gtk_widget_set_default_direction (GTK_TEXT_DIR_RTL); |
| |
| open_test_window (); |
| open_control_window (); |
| open_alignment_window (); |
| open_margin_window (); |
| open_valigned_label_window (); |
| |
| while (!done) |
| g_main_context_iteration (NULL, TRUE); |
| |
| return 0; |
| } |