diff options
author | Martin Szulecki | 2010-01-20 21:51:17 +0100 |
---|---|---|
committer | Martin Szulecki | 2010-01-20 21:51:17 +0100 |
commit | a7b942539d4002397d846b3c2308433628323549 (patch) | |
tree | 2d60f369896b8d1eb8f777049c6d0c8f927eaeca /src | |
parent | ce0142bbe353e82b9b6d547995785a9d76b98a53 (diff) | |
download | sbmanager-a7b942539d4002397d846b3c2308433628323549.tar.gz sbmanager-a7b942539d4002397d846b3c2308433628323549.tar.bz2 |
Fade screen dark when controls are disabled and revert if enabled
Diffstat (limited to 'src')
-rw-r--r-- | src/sbmanager.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/src/sbmanager.c b/src/sbmanager.c index c908717..6c5de18 100644 --- a/src/sbmanager.c +++ b/src/sbmanager.c @@ -89,6 +89,7 @@ ClutterActor *clock_label = NULL; ClutterActor *battery_level = NULL; ClutterActor *page_indicator = NULL; ClutterActor *page_indicator_group = NULL; +ClutterActor *fade_rectangle = NULL; GMutex *selected_mutex = NULL; SBItem *selected_item = NULL; @@ -392,6 +393,34 @@ static void clock_update_cb(ClutterTimeline *timeline, gint msecs, SBManagerApp } /* gui */ +static void gui_fade_init() +{ + ClutterColor fade_color = { 0x00, 0x00, 0x00, 0xff }; + debug_printf("%s: enter\n", __func__); + fade_rectangle = clutter_rectangle_new_with_color(&fade_color); + clutter_container_add_actor (CLUTTER_CONTAINER (stage), fade_rectangle); + clutter_actor_set_position(fade_rectangle, 0, 0); + clutter_actor_set_size(fade_rectangle, STAGE_WIDTH, STAGE_HEIGHT); + clutter_actor_set_opacity(fade_rectangle, 0); + debug_printf("%s: leave\n", __func__); +} + +static void gui_fade_stop() +{ + debug_printf("%s: enter\n", __func__); + clutter_actor_raise_top(fade_rectangle); + clutter_actor_animate(CLUTTER_ACTOR(fade_rectangle), CLUTTER_EASE_OUT_QUAD, 1000, "opacity", 0, NULL); + debug_printf("%s: leave\n", __func__); +} + +static void gui_fade_start() +{ + debug_printf("%s: enter\n", __func__); + clutter_actor_raise_top(fade_rectangle); + clutter_actor_animate(CLUTTER_ACTOR(fade_rectangle), CLUTTER_EASE_OUT_QUAD, 250, "opacity", 200, NULL); + debug_printf("%s: leave\n", __func__); +} + static void gui_dock_align_icons(gboolean animated) { if (!dockitems) @@ -1139,11 +1168,13 @@ static void gui_set_iconstate(plist_t iconstate) static void gui_disable_controls() { gtk_widget_set_sensitive(toolbar, FALSE); + gui_fade_start(); } static void gui_enable_controls() { gtk_widget_set_sensitive(toolbar, TRUE); + gui_fade_stop(); } static gboolean wait_icon_load_finished(gpointer data) @@ -1482,6 +1513,8 @@ static void gui_init(SBManagerApp* app) clutter_group_add(CLUTTER_GROUP(stage), the_dock); clutter_actor_set_position(the_dock, dock_area.x1, dock_area.y1); + gui_fade_init(); + /* Show the stage */ clutter_actor_show(stage); |