back to 3 colors
This commit is contained in:
		
							parent
							
								
									37faefb1aa
								
							
						
					
					
						commit
						65be999a3f
					
				| @ -4,7 +4,6 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #define FONT			"-*-terminus-medium-*-*-*-12-*-*-*-*-*-iso10646-*" | #define FONT			"-*-terminus-medium-*-*-*-12-*-*-*-*-*-iso10646-*" | ||||||
| #define NORMBGCOLOR		"#666699" | #define BGCOLOR			"#666699" | ||||||
| #define NORMFGCOLOR		"#eeeeee" | #define FGCOLOR			"#eeeeee" | ||||||
| #define SELBGCOLOR		"#eeeeee" | #define BORDERCOLOR		"#9999CC" | ||||||
| #define SELFGCOLOR		"#000088" |  | ||||||
|  | |||||||
| @ -4,7 +4,6 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #define FONT			"fixed" | #define FONT			"fixed" | ||||||
| #define NORMBGCOLOR		"#666699" | #define BGCOLOR			"#666699" | ||||||
| #define NORMFGCOLOR		"#eeeeee" | #define FGCOLOR			"#eeeeee" | ||||||
| #define SELBGCOLOR		"#eeeeee" | #define BORDERCOLOR		"#9999CC" | ||||||
| #define SELFGCOLOR		"#666699" |  | ||||||
|  | |||||||
							
								
								
									
										7
									
								
								dmenu.h
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								dmenu.h
									
									
									
									
									
								
							| @ -22,8 +22,9 @@ struct Fnt { | |||||||
| 
 | 
 | ||||||
| struct DC { /* draw context */ | struct DC { /* draw context */ | ||||||
| 	int x, y, w, h; | 	int x, y, w, h; | ||||||
| 	unsigned long bg[2]; | 	unsigned long bg; | ||||||
| 	unsigned long fg[2]; | 	unsigned long fg; | ||||||
|  | 	unsigned long border; | ||||||
| 	Drawable drawable; | 	Drawable drawable; | ||||||
| 	Fnt font; | 	Fnt font; | ||||||
| 	GC gc; | 	GC gc; | ||||||
| @ -34,7 +35,7 @@ extern Display *dpy; | |||||||
| extern DC dc; | extern DC dc; | ||||||
| 
 | 
 | ||||||
| /* draw.c */ | /* draw.c */ | ||||||
| extern void drawtext(const char *text, unsigned int colidx, Bool border); | extern void drawtext(const char *text, Bool invert, Bool border); | ||||||
| extern unsigned long getcolor(const char *colstr); | extern unsigned long getcolor(const char *colstr); | ||||||
| extern void setfont(const char *fontstr); | extern void setfont(const char *fontstr); | ||||||
| extern unsigned int textw(const char *text); | extern unsigned int textw(const char *text); | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								draw.c
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								draw.c
									
									
									
									
									
								
							| @ -24,19 +24,19 @@ textnw(const char *text, unsigned int len) | |||||||
| /* extern */ | /* extern */ | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| drawtext(const char *text, unsigned int colidx, Bool border) | drawtext(const char *text, Bool invert, Bool border) | ||||||
| { | { | ||||||
| 	int x, y, w, h; | 	int x, y, w, h; | ||||||
| 	static char buf[256]; | 	static char buf[256]; | ||||||
| 	unsigned int len, olen; | 	unsigned int len, olen; | ||||||
|  | 	XGCValues gcv; | ||||||
| 	XPoint points[5]; | 	XPoint points[5]; | ||||||
| 	XRectangle r = { dc.x, dc.y, dc.w, dc.h }; | 	XRectangle r = { dc.x, dc.y, dc.w, dc.h }; | ||||||
| 
 | 
 | ||||||
| 	XSetForeground(dpy, dc.gc, dc.bg[colidx]); | 	XSetForeground(dpy, dc.gc, invert ? dc.fg : dc.bg); | ||||||
| 	XFillRectangles(dpy, dc.drawable, dc.gc, &r, 1); | 	XFillRectangles(dpy, dc.drawable, dc.gc, &r, 1); | ||||||
| 
 | 
 | ||||||
| 	w = 0; | 	w = 0; | ||||||
| 	XSetForeground(dpy, dc.gc, dc.fg[colidx]); |  | ||||||
| 	if(border) { | 	if(border) { | ||||||
| 		points[0].x = dc.x; | 		points[0].x = dc.x; | ||||||
| 		points[0].y = dc.y; | 		points[0].y = dc.y; | ||||||
| @ -48,6 +48,7 @@ drawtext(const char *text, unsigned int colidx, Bool border) | |||||||
| 		points[3].y = 0; | 		points[3].y = 0; | ||||||
| 		points[4].x = 0; | 		points[4].x = 0; | ||||||
| 		points[4].y = -(dc.h - 1); | 		points[4].y = -(dc.h - 1); | ||||||
|  | 		XSetForeground(dpy, dc.gc, dc.border); | ||||||
| 		XDrawLines(dpy, dc.drawable, dc.gc, points, 5, CoordModePrevious); | 		XDrawLines(dpy, dc.drawable, dc.gc, points, 5, CoordModePrevious); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -79,11 +80,17 @@ drawtext(const char *text, unsigned int colidx, Bool border) | |||||||
| 	if(w > dc.w) | 	if(w > dc.w) | ||||||
| 		return; /* too long */ | 		return; /* too long */ | ||||||
| 
 | 
 | ||||||
| 	if(dc.font.set) | 	gcv.foreground = invert ? dc.bg : dc.fg; | ||||||
| 		XmbDrawString(dpy, dc.drawable, dc.font.set, dc.gc, x, y, buf, len); | 	gcv.background = invert ? dc.fg : dc.bg; | ||||||
|  | 	if(dc.font.set) { | ||||||
|  | 		XChangeGC(dpy, dc.gc, GCForeground | GCBackground, &gcv); | ||||||
|  | 		XmbDrawImageString(dpy, dc.drawable, dc.font.set, dc.gc, | ||||||
|  | 				x, y, buf, len); | ||||||
|  | 	} | ||||||
| 	else { | 	else { | ||||||
| 		XSetFont(dpy, dc.gc, dc.font.xfont->fid); | 		gcv.font = dc.font.xfont->fid; | ||||||
| 		XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len); | 		XChangeGC(dpy, dc.gc, GCForeground | GCBackground | GCFont, &gcv); | ||||||
|  | 		XDrawImageString(dpy, dc.drawable, dc.gc, x, y, buf, len); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								main.c
									
									
									
									
									
								
							| @ -77,17 +77,17 @@ drawmenu() | |||||||
| 	dc.y = 0; | 	dc.y = 0; | ||||||
| 	dc.w = mw; | 	dc.w = mw; | ||||||
| 	dc.h = mh; | 	dc.h = mh; | ||||||
| 	drawtext(NULL, 0, False); | 	drawtext(NULL, False, False); | ||||||
| 
 | 
 | ||||||
| 	/* print command */ | 	/* print command */ | ||||||
| 	if(cmdw && item) | 	if(cmdw && item) | ||||||
| 		dc.w = cmdw; | 		dc.w = cmdw; | ||||||
| 	drawtext(text[0] ? text : NULL, 0, False); | 	drawtext(text[0] ? text : NULL, False, False); | ||||||
| 	dc.x += cmdw; | 	dc.x += cmdw; | ||||||
| 
 | 
 | ||||||
| 	if(curr) { | 	if(curr) { | ||||||
| 		dc.w = SPACE; | 		dc.w = SPACE; | ||||||
| 		drawtext((curr && curr->left) ? "<" : NULL, 0, False); | 		drawtext((curr && curr->left) ? "<" : NULL, False, False); | ||||||
| 		dc.x += dc.w; | 		dc.x += dc.w; | ||||||
| 
 | 
 | ||||||
| 		/* determine maximum items */ | 		/* determine maximum items */ | ||||||
| @ -95,13 +95,13 @@ drawmenu() | |||||||
| 			dc.w = textw(i->text); | 			dc.w = textw(i->text); | ||||||
| 			if(dc.w > mw / 3) | 			if(dc.w > mw / 3) | ||||||
| 				dc.w = mw / 3; | 				dc.w = mw / 3; | ||||||
| 			drawtext(i->text, sel == i ? 1 : 0, sel == i); | 			drawtext(i->text, sel == i, sel == i); | ||||||
| 			dc.x += dc.w; | 			dc.x += dc.w; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		dc.x = mw - SPACE; | 		dc.x = mw - SPACE; | ||||||
| 		dc.w = SPACE; | 		dc.w = SPACE; | ||||||
| 		drawtext(next ? ">" : NULL, 0, False); | 		drawtext(next ? ">" : NULL, False, False); | ||||||
| 	} | 	} | ||||||
| 	XCopyArea(dpy, dc.drawable, win, dc.gc, 0, 0, mw, mh, 0, 0); | 	XCopyArea(dpy, dc.drawable, win, dc.gc, 0, 0, mw, mh, 0, 0); | ||||||
| 	XFlush(dpy); | 	XFlush(dpy); | ||||||
| @ -315,10 +315,9 @@ main(int argc, char *argv[]) | |||||||
| 		usleep(1000); | 		usleep(1000); | ||||||
| 
 | 
 | ||||||
| 	/* style */ | 	/* style */ | ||||||
| 	dc.bg[0] = getcolor(NORMBGCOLOR); | 	dc.bg = getcolor(BGCOLOR); | ||||||
| 	dc.fg[0] = getcolor(NORMFGCOLOR); | 	dc.fg = getcolor(FGCOLOR); | ||||||
| 	dc.bg[1] = getcolor(SELBGCOLOR); | 	dc.border = getcolor(BORDERCOLOR); | ||||||
| 	dc.fg[1] = getcolor(SELFGCOLOR); |  | ||||||
| 	setfont(FONT); | 	setfont(FONT); | ||||||
| 
 | 
 | ||||||
| 	wa.override_redirect = 1; | 	wa.override_redirect = 1; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Anselm R. Garbe
						Anselm R. Garbe