]> Pileus Git - ~andy/gtk/blobdiff - tests/teststatusicon.c
stylecontext: Do invalidation on first resize container
[~andy/gtk] / tests / teststatusicon.c
index 738181d30d983cdf7538a9e6dd6b45d22d3e0f97..c6f81fc580205f99221b60aa8771a24b52d998e5 100755 (executable)
  * 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, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
  *
  * Authors:
  *     Mark McLoughlin <mark@skynet.ie>
  */
 
 #include <gtk/gtk.h>
+#include <stdlib.h>
+
+#include "prop-editor.h"
 
 typedef enum
 {
@@ -31,62 +32,90 @@ typedef enum
 
 static TestStatus status = TEST_STATUS_INFO;
 static gint timeout = 0;
+static GSList *icons = NULL;
+
+static void
+size_changed_cb (GtkStatusIcon *icon,
+                int size)
+{
+  g_print ("status icon %p size-changed size = %d\n", icon, size);
+}
+
+static void
+embedded_changed_cb (GtkStatusIcon *icon)
+{
+  g_print ("status icon %p embedded changed to %d\n", icon,
+          gtk_status_icon_is_embedded (icon));
+}
 
 static void
-update_icon (GtkStatusIcon *status_icon)
+orientation_changed_cb (GtkStatusIcon *icon)
 {
+  GtkOrientation orientation;
+
+  g_object_get (icon, "orientation", &orientation, NULL);
+  g_print ("status icon %p orientation changed to %d\n", icon, orientation);
+}
+
+static void
+screen_changed_cb (GtkStatusIcon *icon)
+{
+  g_print ("status icon %p screen changed to %p\n", icon,
+          gtk_status_icon_get_screen (icon));
+}
+
+static void
+update_icons (void)
+{
+  GSList *l;
   gchar *icon_name;
   gchar *tooltip;
 
   if (status == TEST_STATUS_INFO)
     {
-      icon_name = GTK_STOCK_DIALOG_INFO;
-      tooltip = "Some Infromation ...";
+      icon_name = "dialog-information";
+      tooltip = "Some Information ...";
     }
   else
     {
-      icon_name = GTK_STOCK_DIALOG_QUESTION;
+      icon_name = "dialog-question";
       tooltip = "Some Question ...";
     }
 
-  gtk_status_icon_set_from_icon_name (status_icon, icon_name);
-  gtk_status_icon_set_tooltip (status_icon, tooltip);
+  for (l = icons; l; l = l->next)
+    {
+      GtkStatusIcon *status_icon = l->data;
+
+      gtk_status_icon_set_from_icon_name (status_icon, icon_name);
+      gtk_status_icon_set_tooltip_text (status_icon, tooltip);
+    }
 }
 
 static gboolean
 timeout_handler (gpointer data)
 {
-  GtkStatusIcon *icon = GTK_STATUS_ICON (data);
-
   if (status == TEST_STATUS_INFO)
     status = TEST_STATUS_QUESTION;
   else
     status = TEST_STATUS_INFO;
 
-  update_icon (icon);
+  update_icons ();
 
   return TRUE;
 }
 
 static void
-blink_toggle_toggled (GtkToggleButton *toggle,
-                     GtkStatusIcon   *icon)
+visible_toggle_toggled (GtkToggleButton *toggle)
 {
-  gtk_status_icon_set_blinking (icon, 
-                               gtk_toggle_button_get_active (toggle));
-}
+  GSList *l;
 
-static void
-visible_toggle_toggled (GtkToggleButton *toggle,
-                       GtkStatusIcon   *icon)
-{
-  gtk_status_icon_set_visible (icon, 
-                              gtk_toggle_button_get_active (toggle));
+  for (l = icons; l; l = l->next)
+    gtk_status_icon_set_visible (GTK_STATUS_ICON (l->data),
+                                 gtk_toggle_button_get_active (toggle));
 }
 
 static void
-timeout_toggle_toggled (GtkToggleButton *toggle,
-                       GtkStatusIcon   *icon)
+timeout_toggle_toggled (GtkToggleButton *toggle)
 {
   if (timeout)
     {
@@ -95,13 +124,14 @@ timeout_toggle_toggled (GtkToggleButton *toggle,
     }
   else
     {
-      timeout = g_timeout_add (2000, timeout_handler, icon);
+      timeout = gdk_threads_add_timeout (2000, timeout_handler, NULL);
     }
 }
 
 static void
 icon_activated (GtkStatusIcon *icon)
 {
+  GtkWidget *content_area;
   GtkWidget *dialog;
   GtkWidget *toggle;
 
@@ -113,6 +143,9 @@ icon_activated (GtkStatusIcon *icon)
                                       GTK_BUTTONS_CLOSE,
                                       "You wanna test the status icon ?");
 
+      gtk_window_set_screen (GTK_WINDOW (dialog), gtk_status_icon_get_screen (icon));
+      gtk_window_set_position (GTK_WINDOW (dialog), GTK_WIN_POS_CENTER);
+
       g_object_set_data_full (G_OBJECT (icon), "test-status-icon-dialog",
                              dialog, (GDestroyNotify) gtk_widget_destroy);
 
@@ -121,43 +154,67 @@ icon_activated (GtkStatusIcon *icon)
       g_signal_connect (dialog, "delete_event", 
                        G_CALLBACK (gtk_widget_hide_on_delete), NULL);
 
+      content_area = gtk_dialog_get_content_area (GTK_DIALOG (dialog));
+
       toggle = gtk_toggle_button_new_with_mnemonic ("_Show the icon");
-      gtk_box_pack_end (GTK_BOX (GTK_DIALOG (dialog)->vbox), toggle, TRUE, TRUE, 6);
+      gtk_box_pack_end (GTK_BOX (content_area), toggle, TRUE, TRUE, 6);
       gtk_widget_show (toggle);
 
       gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
                                    gtk_status_icon_get_visible (icon));
       g_signal_connect (toggle, "toggled", 
-                       G_CALLBACK (visible_toggle_toggled), icon);
-
-      toggle = gtk_toggle_button_new_with_mnemonic ("_Blink the icon");
-      gtk_box_pack_end (GTK_BOX (GTK_DIALOG (dialog)->vbox), toggle, TRUE, TRUE, 6);
-      gtk_widget_show (toggle);
-
-      gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
-                                   gtk_status_icon_get_blinking (icon));
-      g_signal_connect (toggle, "toggled", 
-                       G_CALLBACK (blink_toggle_toggled), icon);
+                       G_CALLBACK (visible_toggle_toggled), NULL);
 
       toggle = gtk_toggle_button_new_with_mnemonic ("_Change images");
-      gtk_box_pack_end (GTK_BOX (GTK_DIALOG (dialog)->vbox), toggle, TRUE, TRUE, 6);
+      gtk_box_pack_end (GTK_BOX (content_area), toggle, TRUE, TRUE, 6);
       gtk_widget_show (toggle);
 
       gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
                                    timeout != 0);
       g_signal_connect (toggle, "toggled", 
-                       G_CALLBACK (timeout_toggle_toggled), icon);
+                       G_CALLBACK (timeout_toggle_toggled), NULL);
     }
 
   gtk_window_present (GTK_WINDOW (dialog));
 }
 
 static void
-check_activated (GtkCheckMenuItem *item,
-                GtkStatusIcon    *icon)
+do_properties (GtkMenuItem   *item,
+              GtkStatusIcon *icon)
+{
+       static GtkWidget *editor = NULL;
+
+       if (editor == NULL) {
+               editor = create_prop_editor (G_OBJECT (icon), GTK_TYPE_STATUS_ICON);
+               g_signal_connect (editor, "destroy", G_CALLBACK (gtk_widget_destroyed), &editor);
+       }
+
+       gtk_window_present (GTK_WINDOW (editor));
+}
+
+static void
+do_quit (GtkMenuItem *item)
 {
-  gtk_status_icon_set_blinking (icon, 
-                               gtk_check_menu_item_get_active (item));
+  GSList *l;
+
+  for (l = icons; l; l = l->next)
+    {
+      GtkStatusIcon *icon = l->data;
+
+      gtk_status_icon_set_visible (icon, FALSE);
+      g_object_unref (icon);
+    }
+
+  g_slist_free (icons);
+  icons = NULL;
+
+  gtk_main_quit ();
+}
+
+static void
+do_exit (GtkMenuItem *item)
+{
+  exit (0);
 }
 
 static void 
@@ -169,39 +226,74 @@ popup_menu (GtkStatusIcon *icon,
 
   menu = gtk_menu_new ();
 
-  menuitem = gtk_check_menu_item_new_with_label ("Blink");
-  gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (menuitem), 
-                                 gtk_status_icon_get_blinking (icon));
-  g_signal_connect (menuitem, "activate", G_CALLBACK (check_activated), icon);
+  gtk_menu_set_screen (GTK_MENU (menu),
+                       gtk_status_icon_get_screen (icon));
+
+  menuitem = gtk_image_menu_item_new_from_stock (GTK_STOCK_PROPERTIES, NULL);
+  g_signal_connect (menuitem, "activate", G_CALLBACK (do_properties), icon);
+
+  gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
+
+  gtk_widget_show (menuitem);
+
+  menuitem = gtk_menu_item_new_with_label ("Quit");
+  g_signal_connect (menuitem, "activate", G_CALLBACK (do_quit), NULL);
+
+  gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
+
+  gtk_widget_show (menuitem);
+
+  menuitem = gtk_menu_item_new_with_label ("Exit abruptly");
+  g_signal_connect (menuitem, "activate", G_CALLBACK (do_exit), NULL);
 
   gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
 
   gtk_widget_show (menuitem);
 
   gtk_menu_popup (GTK_MENU (menu), 
-                 NULL, NULL, NULL, NULL, 
+                 NULL, NULL,
+                 gtk_status_icon_position_menu, icon,
                  button, activate_time);
 }
 
 int
 main (int argc, char **argv)
 {
-  GtkStatusIcon *icon;
+  GdkDisplay *display;
+  guint n_screens, i;
 
   gtk_init (&argc, &argv);
 
-  icon = gtk_status_icon_new ();
-  update_icon (icon);
+  display = gdk_display_get_default ();
+
+  n_screens = gdk_display_get_n_screens (display);
+
+  for (i = 0; i < n_screens; i++)
+    {
+      GtkStatusIcon *icon;
+
+      icon = gtk_status_icon_new ();
+      gtk_status_icon_set_screen (icon, gdk_display_get_screen (display, i));
+      update_icons ();
+
+      g_signal_connect (icon, "size-changed", G_CALLBACK (size_changed_cb), NULL);
+      g_signal_connect (icon, "notify::embedded", G_CALLBACK (embedded_changed_cb), NULL);
+      g_signal_connect (icon, "notify::orientation", G_CALLBACK (orientation_changed_cb), NULL);
+      g_signal_connect (icon, "notify::screen", G_CALLBACK (screen_changed_cb), NULL);
+      g_print ("icon size %d\n", gtk_status_icon_get_size (icon));
 
-  gtk_status_icon_set_blinking (GTK_STATUS_ICON (icon), TRUE);
+      g_signal_connect (icon, "activate",
+                        G_CALLBACK (icon_activated), NULL);
 
-  g_signal_connect (icon, "activate",
-                   G_CALLBACK (icon_activated), NULL);
+      g_signal_connect (icon, "popup-menu",
+                        G_CALLBACK (popup_menu), NULL);
 
-  g_signal_connect (icon, "popup-menu",
-                   G_CALLBACK (popup_menu), NULL);
+      icons = g_slist_append (icons, icon);
  
-  timeout = g_timeout_add (2000, timeout_handler, icon);
+      update_icons ();
+
+      timeout = gdk_threads_add_timeout (2000, timeout_handler, icon);
+    }
 
   gtk_main ();