diff options
| author | Craig Jennings <craigmartinjennings@gmail.com> | 2023-07-23 15:01:35 -0500 | 
|---|---|---|
| committer | Craig Jennings <craigmartinjennings@gmail.com> | 2023-07-23 15:01:35 -0500 | 
| commit | a43109a9a14548c20e0aa87a55a3b685d4ed35e0 (patch) | |
| tree | d9939800ee8f16a83d8786e9bea694876574ba1c /x.c | |
| parent | 91bfd1195774903ba6b0877634526773fd3b93d5 (diff) | |
alpha patch applied
Diffstat (limited to 'x.c')
| -rw-r--r-- | x.c | 43 | 
1 files changed, 33 insertions, 10 deletions
| @@ -106,6 +106,7 @@ typedef struct {  	XSetWindowAttributes attrs;  	int scr;  	int isfixed; /* is fixed geometry? */ +	int depth; /* bit depth */  	int l, t; /* left and top offset */  	int gm; /* geometry mask */  } XWindow; @@ -755,7 +756,7 @@ xresize(int col, int row)  	XFreePixmap(xw.dpy, xw.buf);  	xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, -			DefaultDepth(xw.dpy, xw.scr)); +			xw.depth);  	XftDrawChange(xw.draw, xw.buf);  	xclear(0, 0, win.w, win.h); @@ -815,6 +816,10 @@ xloadcols(void)  			else  				die("could not allocate color %d\n", i);  		} + +	dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha); +	dc.col[defaultbg].pixel &= 0x00FFFFFF; +	dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24;  	loaded = 1;  } @@ -845,6 +850,12 @@ xsetcolorname(int x, const char *name)  	XftColorFree(xw.dpy, xw.vis, xw.cmap, &dc.col[x]);  	dc.col[x] = ncolor; +	if (x == defaultbg) { +		dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha); +		dc.col[defaultbg].pixel &= 0x00FFFFFF; +		dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24; +	} +  	return 0;  } @@ -1137,11 +1148,23 @@ xinit(int cols, int rows)  	Window parent;  	pid_t thispid = getpid();  	XColor xmousefg, xmousebg; +	XWindowAttributes attr; +	XVisualInfo vis;  	if (!(xw.dpy = XOpenDisplay(NULL)))  		die("can't open display\n");  	xw.scr = XDefaultScreen(xw.dpy); -	xw.vis = XDefaultVisual(xw.dpy, xw.scr); + +	if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) { +		parent = XRootWindow(xw.dpy, xw.scr); +		xw.depth = 32; +	} else { +		XGetWindowAttributes(xw.dpy, parent, &attr); +		xw.depth = attr.depth; +	} + +	XMatchVisualInfo(xw.dpy, xw.scr, xw.depth, TrueColor, &vis); +	xw.vis = vis.visual;  	/* font */  	if (!FcInit()) @@ -1151,7 +1174,7 @@ xinit(int cols, int rows)  	xloadfonts(usedfont, 0);  	/* colors */ -	xw.cmap = XDefaultColormap(xw.dpy, xw.scr); +	xw.cmap = XCreateColormap(xw.dpy, parent, xw.vis, None);  	xloadcols();  	/* adjust fixed window geometry */ @@ -1171,19 +1194,15 @@ xinit(int cols, int rows)  		| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask;  	xw.attrs.colormap = xw.cmap; -	if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) -		parent = XRootWindow(xw.dpy, xw.scr);  	xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t, -			win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput, +			win.w, win.h, 0, xw.depth, InputOutput,  			xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity  			| CWEventMask | CWColormap, &xw.attrs);  	memset(&gcvalues, 0, sizeof(gcvalues));  	gcvalues.graphics_exposures = False; -	dc.gc = XCreateGC(xw.dpy, parent, GCGraphicsExposures, -			&gcvalues); -	xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, -			DefaultDepth(xw.dpy, xw.scr)); +	xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, xw.depth); +	dc.gc = XCreateGC(xw.dpy, xw.buf, GCGraphicsExposures, &gcvalues);  	XSetForeground(xw.dpy, dc.gc, dc.col[defaultbg].pixel);  	XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, win.w, win.h); @@ -2041,6 +2060,10 @@ main(int argc, char *argv[])  	case 'a':  		allowaltscreen = 0;  		break; +	case 'A': +		alpha = strtof(EARGF(usage()), NULL); +		LIMIT(alpha, 0.0, 1.0); +		break;  	case 'c':  		opt_class = EARGF(usage());  		break; | 
