diff options
author | Ted Gould <ted@canonical.com> | 2009-02-12 16:43:32 -0600 |
---|---|---|
committer | Ted Gould <ted@canonical.com> | 2009-02-12 16:43:32 -0600 |
commit | 3eb4043f4a65d15996b8463502bef5b680019a57 (patch) | |
tree | f014bf2b82d73f9188e5db190ee6bc845c1b15f4 /tests/im-client.c | |
parent | 6b3a32c443111a23d2953d85be2f2f3b930ed405 (diff) | |
download | libayatana-indicator-3eb4043f4a65d15996b8463502bef5b680019a57.tar.gz libayatana-indicator-3eb4043f4a65d15996b8463502bef5b680019a57.tar.bz2 libayatana-indicator-3eb4043f4a65d15996b8463502bef5b680019a57.zip |
Adding in support for icons, specifically passing them back and forth on the bus
Diffstat (limited to 'tests/im-client.c')
-rw-r--r-- | tests/im-client.c | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/tests/im-client.c b/tests/im-client.c index aa2ef8c..d47903b 100644 --- a/tests/im-client.c +++ b/tests/im-client.c @@ -23,10 +23,14 @@ with this program. If not, see <http://www.gnu.org/licenses/>. #include "libindicate/server.h" #include "libindicate/indicator-message.h" +gchar * patha = "/usr/share/icons/hicolor/16x16/apps/empathy.png"; +gchar * pathb = "/usr/share/icons/hicolor/22x22/apps/empathy.png"; +gchar * lastpath = NULL; + static gboolean timeout_cb (gpointer data) { - g_debug("Modifying time"); + g_debug("Modifying properties"); IndicateIndicator * indicator = INDICATE_INDICATOR(data); @@ -34,6 +38,18 @@ timeout_cb (gpointer data) g_get_current_time(&time); indicate_indicator_set_property_time(INDICATE_INDICATOR(indicator), "time", &time); + if (lastpath == patha) { + lastpath = pathb; + } else { + lastpath = patha; + } + + GdkPixbuf * pixbuf = gdk_pixbuf_new_from_file(lastpath, NULL); + g_return_val_if_fail(pixbuf != NULL, TRUE); + + indicate_indicator_set_property_icon(INDICATE_INDICATOR(indicator), "icon", pixbuf); + g_object_unref(G_OBJECT(pixbuf)); + return TRUE; } @@ -66,7 +82,7 @@ main (int argc, char ** argv) g_signal_connect(G_OBJECT(indicator), INDICATE_INDICATOR_SIGNAL_DISPLAY, G_CALLBACK(display), NULL); - g_timeout_add_seconds(180, timeout_cb, indicator); + g_timeout_add_seconds(10, timeout_cb, indicator); g_main_loop_run(g_main_loop_new(NULL, FALSE)); |