summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tests/testpopover.c172
1 files changed, 32 insertions, 140 deletions
diff --git a/tests/testpopover.c b/tests/testpopover.c
index 3ece11139b..e25c34d6b4 100644
--- a/tests/testpopover.c
+++ b/tests/testpopover.c
@@ -2,159 +2,51 @@
#include <glib/gstdio.h>
static void
-activate (GSimpleAction *action,
- GVariant *parameter,
- gpointer user_data)
+clicked (GtkButton *button)
{
- g_print ("%s activated\n", g_action_get_name (G_ACTION (action)));
+ GtkWidget *toplevel;
+ GtkWindow *window;
+ GtkAllocation alloc;
+ graphene_rect_t bounds;
+
+ window = gtk_window_new (GTK_WINDOW_POPUP);
+ gtk_style_context_add_class (gtk_widget_get_style_context (window), "view");
+ gtk_window_set_resizable (window, FALSE);
+ toplevel = gtk_widget_get_toplevel (button);
+ gtk_window_set_transient_for (window, toplevel);
+ gtk_container_add (GTK_CONTAINER (window), gtk_label_new ("test content"));
+
+ gtk_widget_compute_bounds (button, toplevel, &bounds);
+ alloc.x = floorf (bounds.origin.x);
+ alloc.y = floorf (bounds.origin.y);
+ alloc.width = ceilf (bounds.size.width);
+ alloc.height = ceilf (bounds.size.height);
+
+ gtk_widget_realize (window);
+ gdk_surface_move_to_rect (gtk_widget_get_surface (window),
+ &alloc,
+ GDK_GRAVITY_SOUTH,
+ GDK_GRAVITY_NORTH,
+ GDK_ANCHOR_FLIP | GDK_ANCHOR_SLIDE,
+ 0, 0);
+
+ gtk_widget_show (window);
}
-static GActionEntry entries[] = {
- { "cut", activate, NULL, NULL, NULL },
- { "copy", activate, NULL, NULL, NULL },
- { "paste", activate, NULL, NULL, NULL },
- { "bold", NULL, NULL, "false", NULL },
- { "italic", NULL, NULL, "false", NULL },
- { "strikethrough", NULL, NULL, "false", NULL },
- { "underline", NULL, NULL, "false", NULL },
- { "set-view", NULL, "s", "'list'", NULL },
- { "action1", activate, NULL, NULL, NULL },
- { "action2", NULL, NULL, "true", NULL },
- { "action2a", NULL, NULL, "false", NULL },
- { "action3", NULL, "s", "'three'", NULL },
- { "action4", activate, NULL, NULL, NULL },
- { "action5", activate, NULL, NULL, NULL },
- { "action6", activate, NULL, NULL, NULL },
- { "action7", activate, NULL, NULL, NULL },
- { "action8", activate, NULL, NULL, NULL },
- { "action9", activate, NULL, NULL, NULL },
- { "action10", activate, NULL, NULL, NULL }
-};
-
int
main (int argc, char *argv[])
{
GtkWidget *win;
- GtkWidget *box;
GtkWidget *button;
- GtkWidget *button2;
- GtkBuilder *builder;
- GMenuModel *model;
- GSimpleActionGroup *actions;
- GtkWidget *overlay;
- GtkWidget *grid;
- GtkWidget *popover;
- GtkWidget *popover2;
- GtkWidget *label;
- GtkWidget *check;
- GtkWidget *combo;
- GtkWidget *header_bar;
-
-#ifdef GTK_SRCDIR
- g_chdir (GTK_SRCDIR);
-#endif
gtk_init ();
win = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_default_size (GTK_WINDOW (win), 400, 600);
- header_bar = gtk_header_bar_new ();
- gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header_bar), TRUE);
- gtk_window_set_titlebar (GTK_WINDOW (win), header_bar);
- gtk_window_set_title (GTK_WINDOW (win), "Test GtkPopover");
- actions = g_simple_action_group_new ();
- g_action_map_add_action_entries (G_ACTION_MAP (actions), entries, G_N_ELEMENTS (entries), NULL);
-
- gtk_widget_insert_action_group (win, "top", G_ACTION_GROUP (actions));
-
- overlay = gtk_overlay_new ();
- gtk_container_add (GTK_CONTAINER (win), overlay);
-
- grid = gtk_grid_new ();
- gtk_widget_set_halign (grid, GTK_ALIGN_FILL);
- gtk_widget_set_valign (grid, GTK_ALIGN_FILL);
- gtk_grid_set_row_spacing (GTK_GRID (grid), 10);
- gtk_grid_set_column_spacing (GTK_GRID (grid), 10);
- gtk_container_add (GTK_CONTAINER (overlay), grid);
-
- label = gtk_label_new ("");
- gtk_widget_set_hexpand (label, TRUE);
- gtk_widget_set_vexpand (label, TRUE);
- gtk_grid_attach (GTK_GRID (grid), label, 0, 0, 1, 1);
-
- label = gtk_label_new ("");
- gtk_widget_set_hexpand (label, TRUE);
- gtk_widget_set_vexpand (label, TRUE);
- gtk_grid_attach (GTK_GRID (grid), label, 3, 6, 1, 1);
-
- builder = gtk_builder_new_from_file ("popover.ui");
- model = (GMenuModel *)gtk_builder_get_object (builder, "menu");
-
- box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6);
- button = gtk_menu_button_new ();
- gtk_container_add (GTK_CONTAINER (box), button);
- button2 = gtk_menu_button_new ();
- gtk_container_add (GTK_CONTAINER (box), button2);
-
- gtk_menu_button_set_menu_model (GTK_MENU_BUTTON (button), model);
- gtk_menu_button_set_use_popover (GTK_MENU_BUTTON (button), TRUE);
- popover = GTK_WIDGET (gtk_menu_button_get_popover (GTK_MENU_BUTTON (button)));
-
- builder = gtk_builder_new_from_file ("popover2.ui");
- popover2 = (GtkWidget *)gtk_builder_get_object (builder, "popover");
- gtk_menu_button_set_popover (GTK_MENU_BUTTON (button2), popover2);
-
- g_object_set (box, "margin", 10, NULL);
- gtk_overlay_add_overlay (GTK_OVERLAY (overlay), box);
-
- label = gtk_label_new ("Popover hexpand");
- check = gtk_check_button_new ();
- g_object_bind_property (check, "active", popover, "hexpand", G_BINDING_SYNC_CREATE);
- g_object_bind_property (check, "active", popover2, "hexpand", G_BINDING_SYNC_CREATE);
- gtk_grid_attach (GTK_GRID (grid), label , 1, 1, 1, 1);
- gtk_grid_attach (GTK_GRID (grid), check, 2, 1, 1, 1);
-
- label = gtk_label_new ("Popover vexpand");
- check = gtk_check_button_new ();
- g_object_bind_property (check, "active", popover, "vexpand", G_BINDING_SYNC_CREATE);
- g_object_bind_property (check, "active", popover2, "vexpand", G_BINDING_SYNC_CREATE);
- gtk_grid_attach (GTK_GRID (grid), label , 1, 2, 1, 1);
- gtk_grid_attach (GTK_GRID (grid), check, 2, 2, 1, 1);
-
- label = gtk_label_new ("Button direction");
- combo = gtk_combo_box_text_new ();
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "up", "Up");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "down", "Down");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "left", "Left");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "right", "Right");
- gtk_combo_box_set_active (GTK_COMBO_BOX (combo), 1);
- g_object_bind_property (combo, "active", button, "direction", G_BINDING_SYNC_CREATE);
- g_object_bind_property (combo, "active", button2, "direction", G_BINDING_SYNC_CREATE);
- gtk_grid_attach (GTK_GRID (grid), label , 1, 3, 1, 1);
- gtk_grid_attach (GTK_GRID (grid), combo, 2, 3, 1, 1);
-
- label = gtk_label_new ("Button halign");
- combo = gtk_combo_box_text_new ();
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "fill", "Fill");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "start", "Start");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "end", "End");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "center", "Center");
- gtk_combo_box_set_active (GTK_COMBO_BOX (combo), 2);
- g_object_bind_property (combo, "active", box, "halign", G_BINDING_SYNC_CREATE);
- gtk_grid_attach (GTK_GRID (grid), label , 1, 4, 1, 1);
- gtk_grid_attach (GTK_GRID (grid), combo, 2, 4, 1, 1);
-
- label = gtk_label_new ("Button valign");
- combo = gtk_combo_box_text_new ();
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "fill", "Fill");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "start", "Start");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "end", "End");
- gtk_combo_box_text_append (GTK_COMBO_BOX_TEXT (combo), "center", "Center");
- gtk_combo_box_set_active (GTK_COMBO_BOX (combo), 1);
- g_object_bind_property (combo, "active", box, "valign", G_BINDING_SYNC_CREATE);
- gtk_grid_attach (GTK_GRID (grid), label , 1, 5, 1, 1);
- gtk_grid_attach (GTK_GRID (grid), combo, 2, 5, 1, 1);
+ button = gtk_button_new_with_label ("Pop");
+ g_object_set (button, "margin", 30, NULL);
+ gtk_container_add (GTK_CONTAINER (win), button);
+ g_signal_connect (button, "clicked", G_CALLBACK (clicked), NULL);
g_signal_connect (win, "destroy", G_CALLBACK (gtk_main_quit), NULL);
gtk_widget_show (win);