X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=utils%2Fgrabscreen.h;h=5193eea643efce4effd2b39164bb7fc5d28fb151;hb=2d04c4f22466851aedb6ed0f2919d148f726b889;hp=6d2503a1fcf38c0a4179466954e58377737edfc0;hpb=df7adbee81405e2849728a24b498ad2117784b1f;p=xscreensaver diff --git a/utils/grabscreen.h b/utils/grabscreen.h index 6d2503a1..5193eea6 100644 --- a/utils/grabscreen.h +++ b/utils/grabscreen.h @@ -1,4 +1,4 @@ -/* xscreensaver, Copyright (c) 1992, 1993, 1994, 1997 +/* xscreensaver, Copyright (c) 1992, 1993, 1994, 1997, 2001, 2003, 2004, 2005 * Jamie Zawinski * * Permission to use, copy, modify, distribute, and sell this software and its @@ -13,15 +13,70 @@ #ifndef __GRABSCREEN_H__ #define __GRABSCREEN_H__ -/* This will write a snapshot of the screen image into the given window. - Beware that the colormap of the window may also be changed (to match - the bits that were drawn.) +/* This will write an image onto the given Drawable. + The Drawable (arg 3) may be a Window or a Pixmap. + + The Window must be the top-level window. The image *may or may not* + be written to the window, though it will definitely be written to + the drawable. It's fine for args 2 and 3 to be the same window, or + for arg 2 to be a Window, and arg 3 to be a Pixmap. + + The loaded image might be from a file, or from a screen shot of the + desktop, or from the system's video input, depending on user + preferences. + + If it is from a file, then it will be returned in `filename_return'. + filename_return may be NULL; also, NULL may be returned (e.g., if + it's a screenshot or video capture.) You are responsible for + freeing this string. + + The size and position of the image is returned in `geometry_return'. + The image will generally have been scaled up to fit the window, but + if a loaded file had a different aspect ratio than the window, it + will have been centered, and the returned coords will describe that. + + Many colors may be allocated from the window's colormap. + */ +extern void load_random_image (Screen *screen, + Window top_level_window, + Drawable target_window_or_pixmap, + char **filename_return, + XRectangle *geometry_return); + +/* Like the above, but loads the image in the background and runs the + given callback once it has been loaded. Copy `name' if you want + to keep it. */ -extern void grab_screen_image (Screen *, Window); +extern void fork_load_random_image (Screen *screen, Window window, + Drawable drawable, + void (*callback) (Screen *, Window, + Drawable, + const char *name, + XRectangle *geometry, + void *closure), + void *closure); + /* Whether one should use GCSubwindowMode when drawing on this window (assuming a screen image has been grabbed onto it.) Yes, this is a total kludge. */ extern Bool use_subwindow_mode_p(Screen *screen, Window window); +/* Whether the given window is: + - the real root window; + - the virtual root window; + - a direct child of the root window; + - a direct child of the window manager's decorations. + */ +extern Bool top_level_window_p(Screen *screen, Window window); + + +/* Don't call this: this is for the "xscreensaver-getimage" program only. */ +extern void grab_screen_image_internal (Screen *, Window); + +/* Don't use these: this is how "xscreensaver-getimage" and "grabclient.c" + pass the file name around. */ +#define XA_XSCREENSAVER_IMAGE_FILENAME "_SCREENSAVER_IMAGE_FILENAME" +#define XA_XSCREENSAVER_IMAGE_GEOMETRY "_SCREENSAVER_IMAGE_GEOMETRY" + #endif /* __GRABSCREEN_H__ */