[yocto] [matchbox-panel-2][PATCH 08/25] notify: port to GTK+ 3
Jussi Kukkonen
jussi.kukkonen at intel.com
Tue May 3 04:30:27 PDT 2016
From: Ross Burton <ross.burton at intel.com>
---
applets/notify/applet.c | 19 ++++++++++++-------
applets/notify/mb-notification.c | 38 +++++++++++++++++++++-----------------
2 files changed, 33 insertions(+), 24 deletions(-)
diff --git a/applets/notify/applet.c b/applets/notify/applet.c
index 2920b12..2d896e8 100644
--- a/applets/notify/applet.c
+++ b/applets/notify/applet.c
@@ -1,4 +1,4 @@
-/*
+/*
* (C) 2008 OpenedHand Ltd.
*
* Author: Ross Burton <ross at openedhand.com>
@@ -20,9 +20,13 @@ reposition (GtkWindow *window)
screen = gtk_window_get_screen (window);
- gtk_widget_size_request ((GtkWidget*)window, &req);
+ gtk_widget_get_preferred_size (GTK_WIDGET (window), &req, NULL);
+
if (req.height) {
gtk_window_resize (window, req.width, req.height);
+ /* TODO: get the primary monitor and then use
+ gdk_screen_get_monitor_geometry() to get the geometry of the primary
+ display, not the overall screen. */
gtk_window_move (window,
gdk_screen_get_width (screen) - req.width,
gdk_screen_get_height (screen) - req.height);
@@ -45,7 +49,7 @@ find_widget (GtkContainer *container, guint32 id)
{
GList *children, *l;
GtkWidget *w;
-
+
children = gtk_container_get_children (container);
l = g_list_find_custom (children, GINT_TO_POINTER (id), id_compare);
w = l ? l->data : NULL;
@@ -86,7 +90,7 @@ on_notification_closed (MbNotifyStore *store, guint id, guint reason, GtkWindow
w = find_widget ((GtkContainer*)box, id);
if (w)
gtk_container_remove (GTK_CONTAINER (box), w);
-
+
reposition (window);
}
@@ -95,14 +99,15 @@ mb_panel_applet_create (const char *id, GtkOrientation orientation)
{
GtkWidget *window, *box;
MbNotifyStore *notify;
-
+
window = gtk_window_new (GTK_WINDOW_POPUP);
gtk_widget_set_name (window, "MbNotificationBox");
-
+ gtk_window_set_gravity (GTK_WINDOW (window), GDK_GRAVITY_SOUTH_EAST);
+
box = gtk_vbox_new (TRUE, 0);
gtk_container_add (GTK_CONTAINER (window), box);
gtk_widget_show_all (window);
-
+
notify = mb_notify_store_new ();
g_signal_connect (notify, "notification-added", G_CALLBACK (on_notification_added), window);
g_signal_connect (notify, "notification-closed", G_CALLBACK (on_notification_closed), window);
diff --git a/applets/notify/mb-notification.c b/applets/notify/mb-notification.c
index 0d0e97c..e440ec9 100644
--- a/applets/notify/mb-notification.c
+++ b/applets/notify/mb-notification.c
@@ -9,7 +9,7 @@ enum {
};
static guint signals[N_SIGNALS];
-
+
#define GET_PRIVATE(o) \
(G_TYPE_INSTANCE_GET_PRIVATE ((o), MB_TYPE_NOTIFICATION, MbNotificationPrivate))
@@ -31,17 +31,21 @@ on_button_release (MbNotification *notification, GdkEventButton *event)
}
}
-static gint
-expose (GtkWidget *widget, GdkEventExpose *event)
+static gboolean
+on_draw (GtkWidget *widget, cairo_t *cr)
{
- if (gtk_widget_is_drawable (widget)) {
- gtk_paint_box (widget->style, widget->window,
- widget->state, GTK_SHADOW_OUT,
- &event->area, widget, "notification",
- 0, 0, -1, -1);
-
- (*GTK_WIDGET_CLASS (mb_notification_parent_class)->expose_event) (widget, event);
- }
+ GtkStyleContext *style;
+ int width, height;
+
+ style = gtk_widget_get_style_context (widget);
+
+ width = gtk_widget_get_allocated_width (widget);
+ height = gtk_widget_get_allocated_height (widget);
+
+ gtk_render_frame (style, cr, 0, 0, width, height);
+
+ (*GTK_WIDGET_CLASS (mb_notification_parent_class)->draw) (widget, cr);
+
return FALSE;
}
@@ -52,8 +56,8 @@ mb_notification_class_init (MbNotificationClass *klass)
g_type_class_add_private (klass, sizeof (MbNotificationPrivate));
- widget_class->expose_event = expose;
-
+ widget_class->draw = on_draw;
+
signals[CLOSED] = g_signal_new ("closed",
G_OBJECT_CLASS_TYPE (klass),
G_SIGNAL_RUN_FIRST,
@@ -73,13 +77,13 @@ mb_notification_init (MbNotification *self)
gtk_event_box_set_visible_window (GTK_EVENT_BOX (self), FALSE);
gtk_widget_add_events (GTK_WIDGET (self), GDK_BUTTON_RELEASE_MASK);
g_signal_connect (self, "button-release-event", G_CALLBACK (on_button_release), NULL);
-
- box = gtk_hbox_new (FALSE, 8);
+
+ box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 8);
gtk_container_add (GTK_CONTAINER (self), box);
priv->image = gtk_image_new ();
gtk_box_pack_start (GTK_BOX (box), priv->image, FALSE, FALSE, 0);
-
+
priv->label = gtk_label_new (NULL);
gtk_misc_set_alignment (GTK_MISC (priv->label), 0.0, 0.5);
gtk_box_pack_start (GTK_BOX (box), priv->label, TRUE, TRUE, 0);
@@ -106,7 +110,7 @@ mb_notification_update (MbNotification *notification, Notification *n)
/* TODO: should this default to no image, or "info" */
gtk_image_clear (GTK_IMAGE (priv->image));
}
-
+
s = g_strdup_printf ("<big><b>%s</b></big>\n"
"\n%s", n->summary, n->body ?: NULL);
gtk_label_set_markup (GTK_LABEL (priv->label), s);
--
2.8.1
More information about the yocto
mailing list