diff options
author | Matthias Clasen <mclasen@redhat.com> | 2004-12-14 14:08:30 +0000 |
---|---|---|
committer | Matthias Clasen <matthiasc@src.gnome.org> | 2004-12-14 14:08:30 +0000 |
commit | 7e7c5358a10bd51894c6d6b0581d1b8f2cfb9384 (patch) | |
tree | b8eb951fcafa5083078cf107b1bad56e5aa61868 /tests/testiconview.c | |
parent | 5c19d9e4e61bf25d243297bcbeab7b9775cc8e82 (diff) | |
download | gtk+-7e7c5358a10bd51894c6d6b0581d1b8f2cfb9384.tar.gz |
Test oversized items.
2004-12-14 Matthias Clasen <mclasen@redhat.com>
* tests/testiconview.c: Test oversized items.
Diffstat (limited to 'tests/testiconview.c')
-rw-r--r-- | tests/testiconview.c | 81 |
1 files changed, 78 insertions, 3 deletions
diff --git a/tests/testiconview.c b/tests/testiconview.c index 69fd6a873c..988864bda9 100644 --- a/tests/testiconview.c +++ b/tests/testiconview.c @@ -148,6 +148,70 @@ add_many (GtkWidget *button, GtkIconView *icon_list) } static void +add_large (GtkWidget *button, GtkIconView *icon_list) +{ + GtkListStore *store; + GtkTreeIter iter; + + GdkPixbuf *pixbuf, *pb; + gchar *str; + + store = GTK_LIST_STORE (gtk_icon_view_get_model (icon_list)); + pixbuf = gdk_pixbuf_new_from_file ("gnome-textfile.png", NULL); + + pb = gdk_pixbuf_scale_simple (pixbuf, + 2 * gdk_pixbuf_get_width (pixbuf), + 2 * gdk_pixbuf_get_height (pixbuf), + GDK_INTERP_BILINEAR); + + str = g_strdup_printf ("Some really long text"); + gtk_list_store_append (store, &iter); + gtk_list_store_set (store, &iter, + 0, pb, + 1, str, + 2, 0, + 3, str, + -1); + g_object_unref (pb); + g_free (str); + + pb = gdk_pixbuf_scale_simple (pixbuf, + 3 * gdk_pixbuf_get_width (pixbuf), + 3 * gdk_pixbuf_get_height (pixbuf), + GDK_INTERP_BILINEAR); + + str = g_strdup ("see how long text behaves when placed underneath " + "an oversized icon which would allow for long lines"); + gtk_list_store_append (store, &iter); + gtk_list_store_set (store, &iter, + 0, pb, + 1, str, + 2, 1, + 3, str, + -1); + g_object_unref (pb); + g_free (str); + + pb = gdk_pixbuf_scale_simple (pixbuf, + 3 * gdk_pixbuf_get_width (pixbuf), + 3 * gdk_pixbuf_get_height (pixbuf), + GDK_INTERP_BILINEAR); + + str = g_strdup ("short text"); + gtk_list_store_append (store, &iter); + gtk_list_store_set (store, &iter, + 0, pb, + 1, str, + 2, 2, + 3, str, + -1); + g_object_unref (pb); + g_free (str); + + g_object_unref (pixbuf); +} + +static void select_all (GtkWidget *button, GtkIconView *icon_list) { gtk_icon_view_select_all (icon_list); @@ -286,8 +350,11 @@ main (gint argc, gchar **argv) window = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_window_set_default_size (GTK_WINDOW (window), 700, 400); + vbox = gtk_vbox_new (FALSE, 0); + gtk_container_add (GTK_CONTAINER (window), vbox); + paned = gtk_hpaned_new (); - gtk_container_add (GTK_CONTAINER (window), paned); + gtk_box_pack_start (GTK_BOX (vbox), paned, TRUE, TRUE, 0); icon_list = gtk_icon_view_new (); gtk_icon_view_set_selection_mode (GTK_ICON_VIEW (icon_list), GTK_SELECTION_MULTIPLE); @@ -315,8 +382,8 @@ main (gint argc, gchar **argv) gtk_container_add (GTK_CONTAINER (scrolled_window), icon_list); gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); - vbox = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (vbox), scrolled_window, TRUE, TRUE, 0); + + gtk_paned_add1 (GTK_PANED (paned), scrolled_window); bbox = gtk_hbutton_box_new (); gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), GTK_BUTTONBOX_START); gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, FALSE, 0); @@ -329,10 +396,18 @@ main (gint argc, gchar **argv) g_signal_connect (button, "clicked", G_CALLBACK (add_many), icon_list); gtk_box_pack_start_defaults (GTK_BOX (bbox), button); + button = gtk_button_new_with_label ("Add large"); + g_signal_connect (button, "clicked", G_CALLBACK (add_large), icon_list); + gtk_box_pack_start_defaults (GTK_BOX (bbox), button); + button = gtk_button_new_with_label ("Remove selected"); g_signal_connect (button, "clicked", G_CALLBACK (foreach_selected_remove), icon_list); gtk_box_pack_start_defaults (GTK_BOX (bbox), button); + bbox = gtk_hbutton_box_new (); + gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), GTK_BUTTONBOX_START); + gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, FALSE, 0); + button = gtk_button_new_with_label ("Select all"); g_signal_connect (button, "clicked", G_CALLBACK (select_all), icon_list); gtk_box_pack_start_defaults (GTK_BOX (bbox), button); |