summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJiri Moskovcak <jmoskovc@redhat.com>2009-11-16 10:08:03 +0100
committerJiri Moskovcak <jmoskovc@redhat.com>2009-11-16 10:08:03 +0100
commitb497ec740fa242d71d9c5bb2b168707ac13b001b (patch)
tree2cb0d01208a09ace9d50268aee25b9f6b3ef58f7 /src
parentc5f8a36751a164937b6d70c5e0ef2e228213848f (diff)
downloadabrt-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')
-rw-r--r--src/Applet/CCApplet.cpp65
-rw-r--r--src/Applet/CCApplet.h20
-rw-r--r--src/Applet/Makefile.am1
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