panel snapshot

git-svn-id: http://tint2.googlecode.com/svn/trunk@260 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
This commit is contained in:
thilor77 2009-11-10 21:11:31 +00:00
parent 6057106425
commit 07fff0ca72
3 changed files with 42 additions and 20 deletions

View file

@ -52,7 +52,7 @@
// global path
char *config_path = 0;
char *thumbnail_path = 0;
char *snapshot_path = 0;
// --------------------------------------------------
// backward compatibility

View file

@ -10,7 +10,7 @@
#define CONFIG_H
extern char *config_path;
extern char *thumbnail_path;
extern char *snapshot_path;
void init_config();
void cleanup_config();

View file

@ -49,21 +49,27 @@ void signal_handler(int sig)
void init (int argc, char *argv[])
{
int c;
int i;
// read options
while ((c = getopt(argc , argv, "c:j:v")) != -1) {
switch (c) {
case 'c':
config_path = strdup (optarg);
break;
case 'j':
thumbnail_path = strdup (optarg);
break;
case 'v':
printf("tint2 version 0.7-svn\n");
for (i = 1; i < argc; ++i) {
if (!strcmp(argv[i], "-h") || !strcmp(argv[i], "--help")) {
printf("Usage: tint2 [-c] <config_file>\n");
exit(0);
break;
}
if (!strcmp(argv[i], "-v") || !strcmp(argv[i], "--version")) {
printf("tint2 version 0.7.svn\n");
exit(0);
}
if (!strcmp(argv[i], "-c")) {
i++;
if (i < argc)
config_path = strdup(argv[i]);
}
if (!strcmp(argv[i], "-s")) {
i++;
if (i < argc)
snapshot_path = strdup(argv[i]);
}
}
@ -91,7 +97,7 @@ void init (int argc, char *argv[])
server.visual = DefaultVisual (server.dsp, server.screen);
server.desktop = server_get_current_desktop ();
XGCValues gcv;
server.gc = XCreateGC (server.dsp, server.root_win, (unsigned long)0, &gcv) ;
server.gc = XCreateGC (server.dsp, server.root_win, (unsigned long)0, &gcv);
XSetErrorHandler ((XErrorHandler) server_catch_error);
@ -105,7 +111,6 @@ void init (int argc, char *argv[])
setlocale (LC_ALL, "");
// load default icon
int i;
char *path;
const gchar * const *data_dirs;
data_dirs = g_get_system_data_dirs ();
@ -138,7 +143,7 @@ void cleanup()
imlib_free_image();
}
if (config_path) g_free(config_path);
if (thumbnail_path) g_free(thumbnail_path);
if (snapshot_path) g_free(snapshot_path);
if (server.monitor) free(server.monitor);
XFreeGC(server.dsp, server.gc);
@ -146,6 +151,24 @@ void cleanup()
}
void get_snapshot(const char *path)
{
Panel *panel = &panel1[0];
if (panel->temp_pmap) XFreePixmap(server.dsp, panel->temp_pmap);
panel->temp_pmap = XCreatePixmap(server.dsp, server.root_win, panel->area.width, panel->area.height, server.depth);
refresh(&panel->area);
Imlib_Image img = NULL;
imlib_context_set_drawable(panel->temp_pmap);
img = imlib_create_image_from_drawable(0, 0, 0, panel->area.width, panel->area.height, 0);
imlib_context_set_image(img);
imlib_save_image(path);
}
Taskbar *click_taskbar (Panel *panel, int x, int y)
{
Taskbar *tskbar;
@ -718,9 +741,8 @@ int main (int argc, char *argv[])
}
init_panel();
cleanup_config();
if (thumbnail_path) {
// usage: tint2 -j <file> for internal use
printf("file %s\n", thumbnail_path);
if (snapshot_path) {
get_snapshot(snapshot_path);
cleanup();
exit(0);
}