]> Dogcows Code - chaz/tint2/blobdiff - src/tooltip/tooltip.c
added customised tintwizard
[chaz/tint2] / src / tooltip / tooltip.c
index 157b65cd13376fe8462810798468a5f3a219e025..d7d4f2e1dc92f9f1196e4b82f878bb37ef6e39b7 100644 (file)
@@ -61,10 +61,11 @@ void init_tooltip()
 
 void cleanup_tooltip()
 {
+       alarm(0);
        tooltip_hide();
        g_tooltip.enabled = False;
+       g_tooltip.current_state = TOOLTIP_ABOUT_TO_HIDE;
        if (g_tooltip.task) {
-               alarm(0);
                g_tooltip.task = 0;
        }
        if (g_tooltip.window) {
@@ -116,7 +117,7 @@ void tooltip_show()
        if (!g_tooltip.mapped) {
                g_tooltip.mapped = True;
                XMapWindow(server.dsp, g_tooltip.window);
-               tooltip_update();
+               //tooltip_update();
                alarm(0);
        }
 }
@@ -145,7 +146,8 @@ void tooltip_update_geometry()
        else if (panel_position & LEFT)
                x = panel->posx + panel->area.width;
        else
-                       x = panel->posx - width;
+               x = panel->posx - width;
+
        g_object_unref(layout);
        cairo_destroy(c);
        cairo_surface_destroy(cs);
@@ -159,8 +161,8 @@ void tooltip_adjust_geometry()
 
        int min_x, min_y, max_width, max_height;
        Panel* panel = g_tooltip.task->area.panel;
-       int screen_width = server.monitor[panel->monitor].width;
-       int screen_height = server.monitor[panel->monitor].height;
+       int screen_width = server.monitor[panel->monitor].x + server.monitor[panel->monitor].width;
+       int screen_height = server.monitor[panel->monitor].y + server.monitor[panel->monitor].height;
        if ( x+width <= screen_width && y+height <= screen_height && x>=0 && y>=0)
                return;    // no adjustment needed
 
@@ -183,10 +185,10 @@ void tooltip_adjust_geometry()
                        min_x=0;
        }
 
-       if (x+width > server.monitor[panel->monitor].width)
-               x = server.monitor[panel->monitor].width-width;
-       if ( y+height>server.monitor[panel->monitor].height)
-               y = server.monitor[panel->monitor].height-height;
+       if (x+width > server.monitor[panel->monitor].x + server.monitor[panel->monitor].width)
+               x = server.monitor[panel->monitor].x + server.monitor[panel->monitor].width - width;
+       if ( y+height > server.monitor[panel->monitor].y + server.monitor[panel->monitor].height)
+               y = server.monitor[panel->monitor].y + server.monitor[panel->monitor].height - height;
 
        if (x<min_x)
                x=min_x;
@@ -205,6 +207,7 @@ void tooltip_update()
                return;
        }
 
+       //printf("tooltip_update\n");
        tooltip_update_geometry();
        tooltip_adjust_geometry();
        XMoveResizeWindow(server.dsp, g_tooltip.window, x, y, width, height);
This page took 0.023601 seconds and 4 git commands to generate.