X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=hacks%2Fslidescreen.c;h=dde3a21a5936da401ef191753ed345557d72d877;hb=40eacb5812ef7c0e3374fb139afbb4f5bc8bbfb5;hp=366cdfb9ab5072257a3d763c3b361c68ae75e601;hpb=0bd2eabab3e404c6769fe8f59b639275e960c415;p=xscreensaver diff --git a/hacks/slidescreen.c b/hacks/slidescreen.c index 366cdfb9..dde3a21a 100644 --- a/hacks/slidescreen.c +++ b/hacks/slidescreen.c @@ -1,5 +1,5 @@ -/* xscreensaver, Copyright (c) 1992, 1993, 1994, 1996, 1997 - * Jamie Zawinski +/* xscreensaver, Copyright (c) 1992, 1993, 1994, 1996, 1997, 1998, 2001, 2003 + * Jamie Zawinski * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that @@ -36,9 +36,7 @@ init_slide (Display *dpy, Window window) Visual *visual; XGetWindowAttributes (dpy, window, &xgwa); - grab_screen_image (xgwa.screen, window); - - XGetWindowAttributes (dpy, window, &xgwa); /* re-retrieve colormap */ + load_random_image (xgwa.screen, window, window); cmap = xgwa.colormap; visual = xgwa.visual; max_width = xgwa.width; @@ -50,6 +48,12 @@ init_slide (Display *dpy, Window window) pix_inc = get_integer_resource ("pixelIncrement", "Integer"); border = get_integer_resource ("internalBorderWidth", "InternalBorderWidth"); + /* Don't let the grid be smaller than 3x3 */ + if (grid_size > xgwa.width / 3) + grid_size = xgwa.width / 3; + if (grid_size > xgwa.height / 3) + grid_size = xgwa.height / 3; + { XColor fgc, bgc; char *fgs = get_string_resource("background", "Background"); @@ -197,7 +201,7 @@ init_slide (Display *dpy, Window window) XFillRectangle (dpy, d, gc, 0, bitmap_h - yoff, bitmap_w, yoff); } - XSync (dpy, True); + XSync (dpy, False); if (delay2) usleep (delay2 * 2); for (i = 0; i < grid_size; i += pix_inc) { @@ -228,7 +232,7 @@ init_slide (Display *dpy, Window window) points[2].y = points[1].y; XFillPolygon (dpy, window, gc, points, 3, Convex, CoordModeOrigin); - XSync (dpy, True); + XSync (dpy, False); if (delay) usleep (delay); } @@ -309,7 +313,7 @@ slide1 (Display *dpy, Window window) break; } - XSync (dpy, True); + XSync (dpy, False); if (delay) usleep (delay); } switch (dir) @@ -357,6 +361,7 @@ screenhack (Display *dpy, Window window) while (1) { slide1 (dpy, window); + screenhack_handle_events (dpy); if (delay2) usleep (delay2); } }