back to 3 colors
This commit is contained in:
		
							parent
							
								
									de7fc0011e
								
							
						
					
					
						commit
						9833610356
					
				
					 5 changed files with 35 additions and 38 deletions
				
			
		|  | @ -8,10 +8,9 @@ const char *tags[] = { "work", "net", "fnord", NULL }; | ||||||
| 
 | 
 | ||||||
| #define DEFMODE			dotile /* dofloat */ | #define DEFMODE			dotile /* dofloat */ | ||||||
| #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" |  | ||||||
| #define MODKEY			Mod1Mask | #define MODKEY			Mod1Mask | ||||||
| #define MASTERW			60 /* percent */ | #define MASTERW			60 /* percent */ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -8,10 +8,9 @@ const char *tags[] = { "1", "2", "3", "4", "5", NULL }; | ||||||
| 
 | 
 | ||||||
| #define DEFMODE			dotile /* dofloat */ | #define DEFMODE			dotile /* dofloat */ | ||||||
| #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" |  | ||||||
| #define MODKEY			Mod1Mask | #define MODKEY			Mod1Mask | ||||||
| #define MASTERW			60 /* percent */ | #define MASTERW			60 /* percent */ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										47
									
								
								draw.c
									
										
									
									
									
								
							
							
						
						
									
										47
									
								
								draw.c
									
										
									
									
									
								
							|  | @ -22,15 +22,16 @@ textnw(const char *text, unsigned int len) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
| drawtext(const char *text, unsigned int colidx, Bool highlight) | drawtext(const char *text, Bool invert, Bool highlight) | ||||||
| { | { | ||||||
| 	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); | ||||||
| 	points[0].x = dc.x; | 	points[0].x = dc.x; | ||||||
| 	points[0].y = dc.y; | 	points[0].y = dc.y; | ||||||
|  | @ -42,7 +43,7 @@ drawtext(const char *text, unsigned int colidx, Bool highlight) | ||||||
| 	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.fg[colidx]); | 	XSetForeground(dpy, dc.gc, dc.border); | ||||||
| 	XDrawLines(dpy, dc.drawable, dc.gc, points, 5, CoordModePrevious); | 	XDrawLines(dpy, dc.drawable, dc.gc, points, 5, CoordModePrevious); | ||||||
| 
 | 
 | ||||||
| 	if(!text) | 	if(!text) | ||||||
|  | @ -73,24 +74,22 @@ drawtext(const char *text, unsigned int colidx, Bool highlight) | ||||||
| 
 | 
 | ||||||
| 	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; | ||||||
|  | 	gcv.background = invert ? dc.fg : dc.bg; | ||||||
|  | 	if(dc.font.set) { | ||||||
|  | 		XChangeGC(dpy, dc.gc, GCForeground | GCBackground, &gcv); | ||||||
| 		XmbDrawString(dpy, dc.drawable, dc.font.set, dc.gc, x, y, buf, len); | 		XmbDrawString(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; | ||||||
|  | 		XChangeGC(dpy, dc.gc, GCForeground | GCBackground | GCFont, &gcv); | ||||||
| 		XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len); | 		XDrawString(dpy, dc.drawable, dc.gc, x, y, buf, len); | ||||||
| 	} | 	} | ||||||
| 	if(highlight) { | 	if(highlight) { | ||||||
| 		points[0].x = dc.x + 1; | 		r.x = dc.x + 2; | ||||||
| 		points[0].y = dc.y + 1; | 		r.y = dc.y + 2; | ||||||
| 		points[1].x = dc.w - 3; | 		r.width = r.height = 3; | ||||||
| 		points[1].y = 0; | 		XFillRectangles(dpy, dc.drawable, dc.gc, &r, 1); | ||||||
| 		points[2].x = 0; |  | ||||||
| 		points[2].y = dc.h - 3; |  | ||||||
| 		points[3].x = -(dc.w - 3); |  | ||||||
| 		points[3].y = 0; |  | ||||||
| 		points[4].x = 0; |  | ||||||
| 		points[4].y = -(dc.h - 3); |  | ||||||
| 		XDrawLines(dpy, dc.drawable, dc.gc, points, 5, CoordModePrevious); |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -114,16 +113,16 @@ drawstatus() | ||||||
| 
 | 
 | ||||||
| 	dc.x = dc.y = 0; | 	dc.x = dc.y = 0; | ||||||
| 	dc.w = bw; | 	dc.w = bw; | ||||||
| 	drawtext(NULL, istile ? 1 : 0, False); | 	drawtext(NULL, !istile, False); | ||||||
| 
 | 
 | ||||||
| 	dc.w = 0; | 	dc.w = 0; | ||||||
| 	for(i = 0; i < ntags; i++) { | 	for(i = 0; i < ntags; i++) { | ||||||
| 		dc.x += dc.w; | 		dc.x += dc.w; | ||||||
| 		dc.w = textw(tags[i]); | 		dc.w = textw(tags[i]); | ||||||
| 		if(istile) | 		if(istile) | ||||||
| 			drawtext(tags[i], seltag[i] ? 0 : 1, sel && sel->tags[i]); | 			drawtext(tags[i], seltag[i], sel && sel->tags[i]); | ||||||
| 		else | 		else | ||||||
| 			drawtext(tags[i], seltag[i] ? 1 : 0, sel && sel->tags[i]); | 			drawtext(tags[i], !seltag[i], sel && sel->tags[i]); | ||||||
| 	} | 	} | ||||||
| 	x = dc.x + dc.w; | 	x = dc.x + dc.w; | ||||||
| 	dc.w = textw(stext); | 	dc.w = textw(stext); | ||||||
|  | @ -132,11 +131,11 @@ drawstatus() | ||||||
| 		dc.x = x; | 		dc.x = x; | ||||||
| 		dc.w = bw - x; | 		dc.w = bw - x; | ||||||
| 	} | 	} | ||||||
| 	drawtext(stext, istile ? 1 : 0, False); | 	drawtext(stext, !istile, False); | ||||||
| 
 | 
 | ||||||
| 	if(sel && ((dc.w = dc.x - x) > bh)) { | 	if(sel && ((dc.w = dc.x - x) > bh)) { | ||||||
| 		dc.x = x; | 		dc.x = x; | ||||||
| 		drawtext(sel->name, istile ? 0 : 1, False); | 		drawtext(sel->name, istile, False); | ||||||
| 	} | 	} | ||||||
| 	XCopyArea(dpy, dc.drawable, barwin, dc.gc, 0, 0, bw, bh, 0, 0); | 	XCopyArea(dpy, dc.drawable, barwin, dc.gc, 0, 0, bw, bh, 0, 0); | ||||||
| 	XSync(dpy, False); | 	XSync(dpy, False); | ||||||
|  | @ -151,15 +150,15 @@ drawtitle(Client *c) | ||||||
| 	if(c == sel && issel) { | 	if(c == sel && issel) { | ||||||
| 		drawstatus(); | 		drawstatus(); | ||||||
| 		XUnmapWindow(dpy, c->twin); | 		XUnmapWindow(dpy, c->twin); | ||||||
| 		XSetWindowBorder(dpy, c->win, dc.fg[1]); | 		XSetWindowBorder(dpy, c->win, dc.fg); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	XSetWindowBorder(dpy, c->win, dc.bg[0]); | 	XSetWindowBorder(dpy, c->win, dc.bg); | ||||||
| 	XMapWindow(dpy, c->twin); | 	XMapWindow(dpy, c->twin); | ||||||
| 	dc.x = dc.y = 0; | 	dc.x = dc.y = 0; | ||||||
| 	dc.w = c->tw; | 	dc.w = c->tw; | ||||||
| 	drawtext(c->name, istile ? 1 : 0, False); | 	drawtext(c->name, !istile, False); | ||||||
| 	XCopyArea(dpy, dc.drawable, c->twin, dc.gc, 0, 0, c->tw, c->th, 0, 0); | 	XCopyArea(dpy, dc.drawable, c->twin, dc.gc, 0, 0, c->tw, c->th, 0, 0); | ||||||
| 	XSync(dpy, False); | 	XSync(dpy, False); | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								dwm.h
									
										
									
									
									
								
							
							
						
						
									
										5
									
								
								dwm.h
									
										
									
									
									
								
							|  | @ -36,8 +36,9 @@ typedef struct { | ||||||
| 
 | 
 | ||||||
| typedef struct { /* draw context */ | typedef struct { /* 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; | ||||||
|  |  | ||||||
							
								
								
									
										7
									
								
								main.c
									
										
									
									
									
								
							
							
						
						
									
										7
									
								
								main.c
									
										
									
									
									
								
							|  | @ -121,10 +121,9 @@ setup() | ||||||
| 	seltag[0] = True; | 	seltag[0] = True; | ||||||
| 
 | 
 | ||||||
| 	/* 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); | ||||||
| 
 | 
 | ||||||
| 	sx = sy = 0; | 	sx = sy = 0; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Anselm R. Garbe
						Anselm R. Garbe