docs: don't use a loop for the docs shooter
This commit is contained in:
committed by
Matthias Clasen
parent
afa9339e71
commit
7796e7863c
@ -25,6 +25,8 @@
|
|||||||
#define _(x) (x)
|
#define _(x) (x)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void queue_show (void);
|
||||||
|
|
||||||
static Window
|
static Window
|
||||||
find_toplevel_window (Window xid)
|
find_toplevel_window (Window xid)
|
||||||
{
|
{
|
||||||
@ -127,7 +129,7 @@ take_window_shot (Window child,
|
|||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
GdkPixbuf *tmp, *tmp2;
|
GdkPixbuf *tmp, *tmp2;
|
||||||
GdkPixbuf *retval;
|
GdkPixbuf *retval = NULL;
|
||||||
|
|
||||||
if (include_decoration)
|
if (include_decoration)
|
||||||
xid = find_toplevel_window (child);
|
xid = find_toplevel_window (child);
|
||||||
@ -163,24 +165,104 @@ take_window_shot (Window child,
|
|||||||
tmp = gdk_pixbuf_get_from_window (window,
|
tmp = gdk_pixbuf_get_from_window (window,
|
||||||
x, y, width, height);
|
x, y, width, height);
|
||||||
|
|
||||||
if (include_decoration)
|
if (tmp != NULL)
|
||||||
tmp2 = remove_shaped_area (tmp, xid);
|
{
|
||||||
else
|
if (include_decoration)
|
||||||
tmp2 = add_border_to_shot (tmp);
|
tmp2 = remove_shaped_area (tmp, xid);
|
||||||
|
else
|
||||||
|
tmp2 = add_border_to_shot (tmp);
|
||||||
|
|
||||||
retval = create_shadowed_pixbuf (tmp2);
|
g_object_unref (tmp);
|
||||||
g_object_unref (tmp);
|
|
||||||
g_object_unref (tmp2);
|
if (tmp2 != NULL)
|
||||||
|
{
|
||||||
|
retval = create_shadowed_pixbuf (tmp2);
|
||||||
|
g_object_unref (tmp2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GList *toplevels;
|
||||||
|
static guint shot_id;
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
shoot_one (WidgetInfo *info)
|
||||||
|
{
|
||||||
|
GdkWindow *window;
|
||||||
|
XID id;
|
||||||
|
GdkPixbuf *screenshot = NULL;
|
||||||
|
|
||||||
|
if (g_list_find (toplevels, info) == NULL)
|
||||||
|
{
|
||||||
|
g_warning ("Widget not found in queue");
|
||||||
|
gtk_main_quit ();
|
||||||
|
}
|
||||||
|
|
||||||
|
window = gtk_widget_get_window (info->window);
|
||||||
|
id = gdk_x11_window_get_xid (window);
|
||||||
|
screenshot = take_window_shot (id, info->include_decorations);
|
||||||
|
if (screenshot != NULL)
|
||||||
|
{
|
||||||
|
char *filename;
|
||||||
|
filename = g_strdup_printf ("./%s.png", info->name);
|
||||||
|
gdk_pixbuf_save (screenshot, filename, "png", NULL, NULL);
|
||||||
|
g_free (filename);
|
||||||
|
g_object_unref (screenshot);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_warning ("unable to save shot of %s", info->name);
|
||||||
|
}
|
||||||
|
gtk_widget_destroy (info->window);
|
||||||
|
|
||||||
|
shot_id = 0;
|
||||||
|
|
||||||
|
/* remove from the queue and try to load up another */
|
||||||
|
toplevels = g_list_remove (toplevels, info);
|
||||||
|
if (toplevels == NULL)
|
||||||
|
gtk_main_quit ();
|
||||||
|
else
|
||||||
|
queue_show ();
|
||||||
|
|
||||||
|
return G_SOURCE_REMOVE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_show (WidgetInfo *info)
|
||||||
|
{
|
||||||
|
if (shot_id != 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
shot_id = g_timeout_add (1000, (GSourceFunc) shoot_one, info);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
show_one (void)
|
||||||
|
{
|
||||||
|
WidgetInfo *info = toplevels->data;
|
||||||
|
|
||||||
|
g_message ("shooting %s", info->name);
|
||||||
|
|
||||||
|
g_signal_connect_swapped (info->window,
|
||||||
|
"show",
|
||||||
|
G_CALLBACK (on_show),
|
||||||
|
info);
|
||||||
|
|
||||||
|
gtk_widget_show (info->window);
|
||||||
|
|
||||||
|
return G_SOURCE_REMOVE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
queue_show (void)
|
||||||
|
{
|
||||||
|
g_idle_add ((GSourceFunc) show_one, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
int main (int argc, char **argv)
|
int main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
GList *toplevels;
|
|
||||||
GdkPixbuf *screenshot = NULL;
|
|
||||||
GList *node;
|
|
||||||
|
|
||||||
/* If there's no DISPLAY, we silently error out. We don't want to break
|
/* If there's no DISPLAY, we silently error out. We don't want to break
|
||||||
* headless builds. */
|
* headless builds. */
|
||||||
if (! gtk_init_check (&argc, &argv))
|
if (! gtk_init_check (&argc, &argv))
|
||||||
@ -188,45 +270,8 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
toplevels = get_all_widgets ();
|
toplevels = get_all_widgets ();
|
||||||
|
|
||||||
for (node = toplevels; node; node = g_list_next (node))
|
queue_show ();
|
||||||
{
|
gtk_main ();
|
||||||
GtkAllocation allocation;
|
|
||||||
GdkWindow *window;
|
|
||||||
WidgetInfo *info;
|
|
||||||
XID id;
|
|
||||||
char *filename;
|
|
||||||
|
|
||||||
info = node->data;
|
|
||||||
|
|
||||||
gtk_widget_show (info->window);
|
|
||||||
|
|
||||||
window = gtk_widget_get_window (info->window);
|
|
||||||
gtk_widget_get_allocation (info->window, &allocation);
|
|
||||||
|
|
||||||
gtk_widget_show_now (info->window);
|
|
||||||
gtk_widget_queue_draw_area (info->window,
|
|
||||||
allocation.x, allocation.y,
|
|
||||||
allocation.width, allocation.height);
|
|
||||||
gdk_window_process_updates (window, TRUE);
|
|
||||||
|
|
||||||
while (gtk_events_pending ())
|
|
||||||
{
|
|
||||||
gtk_main_iteration ();
|
|
||||||
}
|
|
||||||
sleep (1);
|
|
||||||
|
|
||||||
while (gtk_events_pending ())
|
|
||||||
{
|
|
||||||
gtk_main_iteration ();
|
|
||||||
}
|
|
||||||
|
|
||||||
id = gdk_x11_window_get_xid (window);
|
|
||||||
screenshot = take_window_shot (id, info->include_decorations);
|
|
||||||
filename = g_strdup_printf ("./%s.png", info->name);
|
|
||||||
gdk_pixbuf_save (screenshot, filename, "png", NULL, NULL);
|
|
||||||
g_free(filename);
|
|
||||||
gtk_widget_hide (info->window);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -16,88 +16,6 @@
|
|||||||
#define LARGE_WIDTH 240
|
#define LARGE_WIDTH 240
|
||||||
#define LARGE_HEIGHT 240
|
#define LARGE_HEIGHT 240
|
||||||
|
|
||||||
static Window
|
|
||||||
find_toplevel_window (Window xid)
|
|
||||||
{
|
|
||||||
Window root, parent, *children;
|
|
||||||
guint nchildren;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (XQueryTree (GDK_DISPLAY_XDISPLAY (gdk_display_get_default ()), xid, &root,
|
|
||||||
&parent, &children, &nchildren) == 0)
|
|
||||||
{
|
|
||||||
g_warning ("Couldn't find window manager window");
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (root == parent)
|
|
||||||
return xid;
|
|
||||||
|
|
||||||
xid = parent;
|
|
||||||
}
|
|
||||||
while (TRUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
adjust_size_callback (WidgetInfo *info)
|
|
||||||
{
|
|
||||||
Window toplevel;
|
|
||||||
Window root;
|
|
||||||
GdkWindow *window;
|
|
||||||
gint tx;
|
|
||||||
gint ty;
|
|
||||||
guint twidth;
|
|
||||||
guint theight;
|
|
||||||
guint tborder_width;
|
|
||||||
guint tdepth;
|
|
||||||
gint target_width = 0;
|
|
||||||
gint target_height = 0;
|
|
||||||
|
|
||||||
window = gtk_widget_get_window (info->window);
|
|
||||||
toplevel = find_toplevel_window (GDK_WINDOW_XID (window));
|
|
||||||
XGetGeometry (GDK_WINDOW_XDISPLAY (window),
|
|
||||||
toplevel,
|
|
||||||
&root, &tx, &ty, &twidth, &theight, &tborder_width, &tdepth);
|
|
||||||
|
|
||||||
switch (info->size)
|
|
||||||
{
|
|
||||||
case SMALL:
|
|
||||||
target_width = SMALL_WIDTH;
|
|
||||||
target_height = SMALL_HEIGHT;
|
|
||||||
break;
|
|
||||||
case MEDIUM:
|
|
||||||
target_width = MEDIUM_WIDTH;
|
|
||||||
target_height = MEDIUM_HEIGHT;
|
|
||||||
break;
|
|
||||||
case LARGE:
|
|
||||||
target_width = LARGE_WIDTH;
|
|
||||||
target_height = LARGE_HEIGHT;
|
|
||||||
break;
|
|
||||||
case ASIS:
|
|
||||||
target_width = twidth;
|
|
||||||
target_height = theight;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (twidth > target_width ||
|
|
||||||
theight > target_height)
|
|
||||||
{
|
|
||||||
gtk_widget_set_size_request (info->window,
|
|
||||||
2 + target_width - (twidth - target_width), /* Dunno why I need the +2 fudge factor; */
|
|
||||||
2 + target_height - (theight - target_height));
|
|
||||||
}
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
realize_callback (GtkWidget *widget,
|
|
||||||
WidgetInfo *info)
|
|
||||||
{
|
|
||||||
gdk_threads_add_timeout (500, (GSourceFunc)adjust_size_callback, info);
|
|
||||||
}
|
|
||||||
|
|
||||||
static WidgetInfo *
|
static WidgetInfo *
|
||||||
new_widget_info (const char *name,
|
new_widget_info (const char *name,
|
||||||
GtkWidget *widget,
|
GtkWidget *widget,
|
||||||
@ -113,7 +31,6 @@ new_widget_info (const char *name,
|
|||||||
info->window = widget;
|
info->window = widget;
|
||||||
gtk_window_set_resizable (GTK_WINDOW (info->window), FALSE);
|
gtk_window_set_resizable (GTK_WINDOW (info->window), FALSE);
|
||||||
info->include_decorations = TRUE;
|
info->include_decorations = TRUE;
|
||||||
g_signal_connect (info->window, "realize", G_CALLBACK (realize_callback), info);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -126,7 +43,6 @@ new_widget_info (const char *name,
|
|||||||
}
|
}
|
||||||
info->no_focus = TRUE;
|
info->no_focus = TRUE;
|
||||||
|
|
||||||
gtk_widget_set_app_paintable (info->window, TRUE);
|
|
||||||
g_signal_connect (info->window, "focus", G_CALLBACK (gtk_true), NULL);
|
g_signal_connect (info->window, "focus", G_CALLBACK (gtk_true), NULL);
|
||||||
|
|
||||||
switch (size)
|
switch (size)
|
||||||
|
|||||||
Reference in New Issue
Block a user