back to 3 colors
							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