diff options
author | Jiri Moskovcak <jmoskovc@redhat.com> | 2009-11-16 10:08:03 +0100 |
---|---|---|
committer | Jiri Moskovcak <jmoskovc@redhat.com> | 2009-11-16 10:08:03 +0100 |
commit | b497ec740fa242d71d9c5bb2b168707ac13b001b (patch) | |
tree | 2cb0d01208a09ace9d50268aee25b9f6b3ef58f7 /src/Applet | |
parent | c5f8a36751a164937b6d70c5e0ef2e228213848f (diff) | |
download | abrt-b497ec740fa242d71d9c5bb2b168707ac13b001b.tar.gz abrt-b497ec740fa242d71d9c5bb2b168707ac13b001b.tar.xz abrt-b497ec740fa242d71d9c5bb2b168707ac13b001b.zip |
APPLET: changed icon from default gtk-warning to abrt specific, add animation
- there were complaints about abrt using standard warning icon,
which is confusing, so I changed it to use abrt spefic icon and
made it move, to attract user attention
Diffstat (limited to 'src/Applet')
-rw-r--r-- | src/Applet/CCApplet.cpp | 65 | ||||
-rw-r--r-- | src/Applet/CCApplet.h | 20 | ||||
-rw-r--r-- | src/Applet/Makefile.am | 1 |
3 files changed, 83 insertions, 3 deletions
diff --git a/src/Applet/CCApplet.cpp b/src/Applet/CCApplet.cpp index c230051..228c6b9 100644 --- a/src/Applet/CCApplet.cpp +++ b/src/Applet/CCApplet.cpp @@ -108,9 +108,13 @@ You should have received a copy of the GNU General Public License along with thi CApplet::CApplet() { - m_pStatusIcon = gtk_status_icon_new_from_stock(GTK_STOCK_DIALOG_WARNING); m_bDaemonRunning = true; - + /* set-up icon buffers */ + animator = 0; + animation_stage = ICON_DEFAULT; + load_icons(); + /* - animation - */ + m_pStatusIcon = gtk_status_icon_new_from_pixbuf(icon_stages_buff[ICON_DEFAULT]); notify_init("ABRT"); m_pNotification = notify_notification_new_with_status_icon("Warning", NULL, NULL, m_pStatusIcon); notify_notification_set_urgency(m_pNotification, NOTIFY_URGENCY_CRITICAL); @@ -215,18 +219,26 @@ void CApplet::OnMenuPopup_cb(GtkStatusIcon *status_icon, guint activate_time, gpointer user_data) { - if (((CApplet *)user_data)->m_pMenu != NULL) + CApplet *applet = (CApplet *)user_data; + /* stop the animation */ + applet->stop_animate_icon(); + gtk_status_icon_set_from_pixbuf(applet->m_pStatusIcon, applet->icon_stages_buff[ICON_DEFAULT]); + + if (applet->m_pMenu != NULL) { gtk_menu_popup(GTK_MENU(((CApplet *)user_data)->m_pMenu), NULL, NULL, gtk_status_icon_position_menu, status_icon, button, activate_time); } + } void CApplet::ShowIcon() { gtk_status_icon_set_visible(m_pStatusIcon, true); + animate_icon(); + //gtk_status_icon_set_visible(m_pStatusIcon, true); //Active wait for icon to be REALLY visible in status area //while(!gtk_status_icon_is_embedded(m_pStatusIcon)) continue; } @@ -246,6 +258,7 @@ void CApplet::onAbout_cb(GtkMenuItem *menuitem, gpointer dialog) void CApplet::HideIcon() { gtk_status_icon_set_visible(m_pStatusIcon, false); + stop_animate_icon(); } void CApplet::Disable(const char *reason) @@ -279,6 +292,52 @@ void CApplet::Enable(const char *reason) ShowIcon(); } +gboolean CApplet::update_icon(void *applet) +{ + if(((CApplet*)applet)->m_pStatusIcon && ((CApplet*)applet)->animation_stage < ICON_STAGE_LAST){ + gtk_status_icon_set_from_pixbuf(((CApplet*)applet)->m_pStatusIcon, + ((CApplet*)applet)->icon_stages_buff[((CApplet*)applet)->animation_stage++]); + } + else + error_msg("icon is null"); + if(((CApplet*)applet)->animation_stage == ICON_STAGE_LAST){ + ((CApplet*)applet)->animation_stage = 0; + } + return true; +} + +void CApplet::animate_icon() +{ + if(animator == 0) + { + animator = g_timeout_add(100, update_icon, this); + } +} + +void CApplet::stop_animate_icon() +{ + if(animator != 0){ + g_source_remove(animator); + animator = 0; + } +} + +void CApplet::load_icons() +{ + int stage = ICON_DEFAULT; + for(stage = ICON_DEFAULT; stage < ICON_STAGE_LAST; stage++) + { + char *name; + GError *error = NULL; + name = g_strdup_printf(ICON_DIR"/abrt%02d.png", stage); + icon_stages_buff[stage] = gdk_pixbuf_new_from_file(name, &error); + if(error != NULL) + error_msg("Can't load pixbuf from %s\n", name); + g_free(name); + } +} + + //int CApplet::AddEvent(int pUUID, const std::string& pProgname) //{ // m_mapEvents[pUUID] = "pProgname"; diff --git a/src/Applet/CCApplet.h b/src/Applet/CCApplet.h index 3ae8cff..e13c1d9 100644 --- a/src/Applet/CCApplet.h +++ b/src/Applet/CCApplet.h @@ -39,6 +39,22 @@ class CApplet NotifyNotification *m_pNotification; // std::map<int, std::string> m_mapEvents; bool m_bDaemonRunning; + GtkStatusIcon *tray_icon; + int animation_stage; + guint animator; + + enum ICON_STAGES + { + ICON_DEFAULT, + ICON_STAGE1, + ICON_STAGE2, + ICON_STAGE3, + ICON_STAGE4, + ICON_STAGE5, + /* this must be always the last */ + ICON_STAGE_LAST + } icon_stages; + GdkPixbuf *icon_stages_buff[ICON_STAGE_LAST]; public: CApplet(); @@ -67,6 +83,10 @@ class CApplet gpointer user_data); static void onHide_cb(GtkMenuItem *menuitem, gpointer applet); static void onAbout_cb(GtkMenuItem *menuitem, gpointer applet); + static gboolean update_icon(void *data); + void animate_icon(); + void stop_animate_icon(); + void load_icons(); }; #endif diff --git a/src/Applet/Makefile.am b/src/Applet/Makefile.am index d098044..6fca43a 100644 --- a/src/Applet/Makefile.am +++ b/src/Applet/Makefile.am @@ -15,6 +15,7 @@ abrt_applet_CPPFLAGS = \ -DDEBUG_DUMPS_DIR=\"$(DEBUG_DUMPS_DIR)\" \ -DPLUGINS_LIB_DIR=\"$(PLUGINS_LIB_DIR)\" \ -DPLUGINS_CONF_DIR=\"$(PLUGINS_CONF_DIR)\" \ + -DICON_DIR=\"${datadir}/icons/hicolor/48x48/apps\" \ $(GTK_CFLAGS) \ $(DBUS_CFLAGS) \ -D_GNU_SOURCE |