]> Dogcows Code - chaz/openbox/commitdiff
improved frame flashing code, can start and stop it on command
authorDana Jansens <danakj@orodu.net>
Mon, 1 Sep 2003 03:41:53 +0000 (03:41 +0000)
committerDana Jansens <danakj@orodu.net>
Mon, 1 Sep 2003 03:41:53 +0000 (03:41 +0000)
openbox/frame.c
openbox/frame.h

index 7c26d7068eefca58a51c5fbc398031609906365c..700f2eac3d3c45be6342a7e85d9ea4b70d23f0ea 100644 (file)
@@ -785,7 +785,6 @@ void frame_frame_gravity(ObFrame *self, int *x, int *y)
 static void flash_done(gpointer data)
 {
     ObFrame *self = data;
-    self->flashing = FALSE;
 
     if (self->focused != self->flash_on)
         frame_adjust_focus(self, self->focused);
@@ -795,21 +794,20 @@ static gboolean flash_timeout(gpointer data)
 {
     ObFrame *self = data;
     GTimeVal now;
-    gboolean focused;
-
-    g_message("flash");
 
     g_get_current_time(&now);
     if (now.tv_sec > self->flash_end.tv_sec ||
         (now.tv_sec == self->flash_end.tv_sec &&
-         now.tv_usec >= self->flash_end.tv_usec)) {
-        g_message("done flashing");
+         now.tv_usec >= self->flash_end.tv_usec))
+        self->flashing = FALSE;
+
+    if (!self->flashing)
         return FALSE; /* we are done */
-    }
 
     self->flash_on = !self->flash_on;
-    g_message("on %d", self->flash_on);
     {
+        gboolean focused;
+        
         focused = self->focused; /* save the focused flag */
         frame_adjust_focus(self, self->flash_on);
         self->focused = focused;
@@ -818,18 +816,23 @@ static gboolean flash_timeout(gpointer data)
     return TRUE; /* go again */
 }
 
-void frame_flash(ObFrame *self)
+void frame_flash_start(ObFrame *self)
 {
     self->flash_on = self->focused;
 
     if (!self->flashing)
         ob_main_loop_timeout_add(ob_main_loop,
-                                 G_USEC_PER_SEC / 2,
+                                 G_USEC_PER_SEC * 0.75,
                                  flash_timeout,
                                  self,
                                  flash_done);
     g_get_current_time(&self->flash_end);
-    g_time_val_add(&self->flash_end, G_USEC_PER_SEC * 4);
+    g_time_val_add(&self->flash_end, G_USEC_PER_SEC * 5);
     
     self->flashing = TRUE;
 }
+
+void frame_flash_stop(ObFrame *self)
+{
+    self->flashing = FALSE;
+}
index d5a9c7ce0412711c6b946c755123ec180fb1741e..1de9090fe22bf6e92884c81b151007887711a0af 100644 (file)
@@ -149,6 +149,7 @@ void frame_client_gravity(ObFrame *self, int *x, int *y);
 */
 void frame_frame_gravity(ObFrame *self, int *x, int *y);
 
-void frame_flash(ObFrame *self);
+void frame_flash_start(ObFrame *self);
+void frame_flash_stop(ObFrame *self);
 
 #endif
This page took 0.026522 seconds and 4 git commands to generate.