Add force desktop window type flag (#4)

* Add force desktop window type flag
This flag places xwinwrap behind desktop icons on ubuntu

* Update README.md
This commit is contained in:
Aaahh Ahh 2017-11-28 11:45:01 -05:00 committed by Ujjwal Verma
parent 099ea746da
commit ec32e9b725
2 changed files with 16 additions and 3 deletions

View File

@ -20,11 +20,12 @@ make clean
### Usage ### Usage
``` ```
Usage: xwinwrap [-g {w}x{h}+{x}+{y}] [-ni] [-argb] [-fs] [-s] [-st] [-sp] [-a] [-b] [-nf] [-o OPACITY] [-sh SHAPE] [-ov]-- COMMAND ARG1... Usage: xwinwrap [-g {w}x{h}+{x}+{y}] [-ni] [-argb] [-fdt] [-fs] [-s] [-st] [-sp] [-a] [-d] [-b] [-nf] [-o OPACITY] [-sh SHAPE] [-ov]-- COMMAND ARG1...
Options: Options:
-g - Specify Geometry (w=width, h=height, x=x-coord, y=y-coord. ex: -g 640x480+100+100) -g - Specify Geometry (w=width, h=height, x=x-coord, y=y-coord. ex: -g 640x480+100+100)
-ni - Ignore Input -ni - Ignore Input
-argb - RGB -argb - RGB
-fdt - force WID window a desktop type window
-fs - Full Screen -fs - Full Screen
-un - Undecorated -un - Undecorated
-s - Sticky -s - Sticky
@ -36,6 +37,7 @@ Options:
-o - Opacity value between 0 to 1 (ex: -o 0.20) -o - Opacity value between 0 to 1 (ex: -o 0.20)
-sh - Shape of window (choose between rectangle, circle or triangle. Default is rectangle) -sh - Shape of window (choose between rectangle, circle or triangle. Default is rectangle)
-ov - Set override_redirect flag (For seamless desktop background integration in non-fullscreenmode) -ov - Set override_redirect flag (For seamless desktop background integration in non-fullscreenmode)
-d - Daemonize
-debug - Enable debug messages -debug - Enable debug messages
``` ```
Example Example

View File

@ -133,12 +133,13 @@ static void sigHandler (int sig)
static void usage (void) static void usage (void)
{ {
fprintf(stderr, "%s \n", NAME); fprintf(stderr, "%s \n", NAME);
fprintf (stderr, "\nUsage: %s [-g {w}x{h}+{x}+{y}] [-ni] [-argb] [-fs] [-s] [-st] [-sp] [-a] " fprintf (stderr, "\nUsage: %s [-g {w}x{h}+{x}+{y}] [-ni] [-argb] [-fdt] [-fs] [-s] [-st] [-sp] [-a] [-d] "
"[-b] [-nf] [-o OPACITY] [-sh SHAPE] [-ov]-- COMMAND ARG1...\n", NAME); "[-b] [-nf] [-o OPACITY] [-sh SHAPE] [-ov]-- COMMAND ARG1...\n", NAME);
fprintf (stderr, "Options:\n \ fprintf (stderr, "Options:\n \
-g - Specify Geometry (w=width, h=height, x=x-coord, y=y-coord. ex: -g 640x480+100+100)\n \ -g - Specify Geometry (w=width, h=height, x=x-coord, y=y-coord. ex: -g 640x480+100+100)\n \
-ni - Ignore Input\n \ -ni - Ignore Input\n \
-argb - RGB\n \ -argb - RGB\n \
-fdt - force WID window a desktop type window\n \
-fs - Full Screen\n \ -fs - Full Screen\n \
-un - Undecorated\n \ -un - Undecorated\n \
-s - Sticky\n \ -s - Sticky\n \
@ -275,6 +276,7 @@ int main(int argc, char **argv)
bool have_argb_visual = false; bool have_argb_visual = false;
bool noInput = false; bool noInput = false;
bool argb = false; bool argb = false;
bool set_desktop_type = false;
bool fullscreen = false; bool fullscreen = false;
bool noFocus = false; bool noFocus = false;
bool override = false; bool override = false;
@ -309,6 +311,10 @@ int main(int argc, char **argv)
{ {
argb = true; argb = true;
} }
else if (strcmp (argv[i], "-fdt") == 0)
{
set_desktop_type = true;
}
else if (strcmp (argv[i], "-fs") == 0) else if (strcmp (argv[i], "-fs") == 0)
{ {
fullscreen = 1; fullscreen = 1;
@ -526,7 +532,12 @@ int main(int argc, char **argv)
xa = ATOM(_NET_WM_WINDOW_TYPE); xa = ATOM(_NET_WM_WINDOW_TYPE);
Atom prop; Atom prop;
if (set_desktop_type)
{
prop = ATOM(_NET_WM_WINDOW_TYPE_DESKTOP);
} else {
prop = ATOM(_NET_WM_WINDOW_TYPE_NORMAL); prop = ATOM(_NET_WM_WINDOW_TYPE_NORMAL);
}
XChangeProperty(display, window.window, xa, XA_ATOM, 32, XChangeProperty(display, window.window, xa, XA_ATOM, 32,
PropModeReplace, (unsigned char *) &prop, 1); PropModeReplace, (unsigned char *) &prop, 1);