mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
- configure menuwin with the screen, then create the xft drawable using
the menu window since that's the only place on which we draw - elminate the need to change the drawable on every font draw
This commit is contained in:
parent
e14123210a
commit
270df196ac
3
calmwm.h
3
calmwm.h
@ -426,7 +426,6 @@ struct menu *menu_filter(struct screen_ctx *, struct menu_q *,
|
|||||||
char *, char *, int,
|
char *, char *, int,
|
||||||
void (*)(struct menu_q *, struct menu_q *, char *),
|
void (*)(struct menu_q *, struct menu_q *, char *),
|
||||||
void (*)(struct menu *, int));
|
void (*)(struct menu *, int));
|
||||||
void menu_init(struct screen_ctx *);
|
|
||||||
void menuq_clear(struct menu_q *);
|
void menuq_clear(struct menu_q *);
|
||||||
|
|
||||||
int parse_config(const char *, struct conf *);
|
int parse_config(const char *, struct conf *);
|
||||||
@ -463,7 +462,7 @@ void xu_ptr_ungrab(void);
|
|||||||
void xu_sendmsg(Window, Atom, long);
|
void xu_sendmsg(Window, Atom, long);
|
||||||
void xu_set_wm_state(Window win, int);
|
void xu_set_wm_state(Window win, int);
|
||||||
void xu_xft_draw(struct screen_ctx *, const char *,
|
void xu_xft_draw(struct screen_ctx *, const char *,
|
||||||
Drawable, int, int, int);
|
int, int, int);
|
||||||
int xu_xft_width(XftFont *, const char *, int);
|
int xu_xft_width(XftFont *, const char *, int);
|
||||||
void xu_xorcolor(XftColor, XftColor, XftColor *);
|
void xu_xorcolor(XftColor, XftColor, XftColor *);
|
||||||
|
|
||||||
|
15
conf.c
15
conf.c
@ -103,11 +103,6 @@ conf_screen(struct screen_ctx *sc)
|
|||||||
|
|
||||||
sc->gap = Conf.gap;
|
sc->gap = Conf.gap;
|
||||||
|
|
||||||
sc->xftdraw = XftDrawCreate(X_Dpy, sc->rootwin,
|
|
||||||
sc->visual, sc->colormap);
|
|
||||||
if (sc->xftdraw == NULL)
|
|
||||||
errx(1, "XftDrawCreate");
|
|
||||||
|
|
||||||
sc->xftfont = XftFontOpenName(X_Dpy, sc->which, Conf.font);
|
sc->xftfont = XftFontOpenName(X_Dpy, sc->which, Conf.font);
|
||||||
if (sc->xftfont == NULL)
|
if (sc->xftfont == NULL)
|
||||||
errx(1, "XftFontOpenName");
|
errx(1, "XftFontOpenName");
|
||||||
@ -134,6 +129,16 @@ conf_screen(struct screen_ctx *sc)
|
|||||||
if (!XftColorAllocValue(X_Dpy, sc->visual, sc->colormap,
|
if (!XftColorAllocValue(X_Dpy, sc->visual, sc->colormap,
|
||||||
&xc.color, &sc->xftcolor[CWM_COLOR_MENU_FONT_SEL]))
|
&xc.color, &sc->xftcolor[CWM_COLOR_MENU_FONT_SEL]))
|
||||||
warnx("XftColorAllocValue: '%s'", Conf.color[i]);
|
warnx("XftColorAllocValue: '%s'", Conf.color[i]);
|
||||||
|
|
||||||
|
sc->menuwin = XCreateSimpleWindow(X_Dpy, sc->rootwin, 0, 0, 1, 1,
|
||||||
|
Conf.bwidth,
|
||||||
|
sc->xftcolor[CWM_COLOR_MENU_FG].pixel,
|
||||||
|
sc->xftcolor[CWM_COLOR_MENU_BG].pixel);
|
||||||
|
|
||||||
|
sc->xftdraw = XftDrawCreate(X_Dpy, sc->menuwin,
|
||||||
|
sc->visual, sc->colormap);
|
||||||
|
if (sc->xftdraw == NULL)
|
||||||
|
errx(1, "XftDrawCreate");
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
|
15
menu.c
15
menu.c
@ -76,15 +76,6 @@ static int menu_calc_entry(struct menu_ctx *, int, int);
|
|||||||
static struct menu *menu_complete_path(struct menu_ctx *);
|
static struct menu *menu_complete_path(struct menu_ctx *);
|
||||||
static int menu_keycode(XKeyEvent *, enum ctltype *, char *);
|
static int menu_keycode(XKeyEvent *, enum ctltype *, char *);
|
||||||
|
|
||||||
void
|
|
||||||
menu_init(struct screen_ctx *sc)
|
|
||||||
{
|
|
||||||
sc->menuwin = XCreateSimpleWindow(X_Dpy, sc->rootwin, 0, 0, 1, 1,
|
|
||||||
Conf.bwidth,
|
|
||||||
sc->xftcolor[CWM_COLOR_MENU_FG].pixel,
|
|
||||||
sc->xftcolor[CWM_COLOR_MENU_BG].pixel);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct menu *
|
struct menu *
|
||||||
menu_filter(struct screen_ctx *sc, struct menu_q *menuq, char *prompt,
|
menu_filter(struct screen_ctx *sc, struct menu_q *menuq, char *prompt,
|
||||||
char *initial, int flags,
|
char *initial, int flags,
|
||||||
@ -417,7 +408,7 @@ menu_draw(struct menu_ctx *mc, struct menu_q *menuq, struct menu_q *resultq)
|
|||||||
mc->width, mc->height);
|
mc->width, mc->height);
|
||||||
|
|
||||||
if (mc->hasprompt) {
|
if (mc->hasprompt) {
|
||||||
xu_xft_draw(sc, mc->dispstr, sc->menuwin, CWM_COLOR_MENU_FONT,
|
xu_xft_draw(sc, mc->dispstr, CWM_COLOR_MENU_FONT,
|
||||||
0, sc->xftfont->ascent);
|
0, sc->xftfont->ascent);
|
||||||
n = 1;
|
n = 1;
|
||||||
} else
|
} else
|
||||||
@ -432,7 +423,7 @@ menu_draw(struct menu_ctx *mc, struct menu_q *menuq, struct menu_q *resultq)
|
|||||||
if (mc->y + y > xine.h)
|
if (mc->y + y > xine.h)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
xu_xft_draw(sc, text, sc->menuwin, CWM_COLOR_MENU_FONT, 0, y);
|
xu_xft_draw(sc, text, CWM_COLOR_MENU_FONT, 0, y);
|
||||||
n++;
|
n++;
|
||||||
}
|
}
|
||||||
if (mc->hasprompt && n > 1 && (mc->searchstr[0] != '\0')) {
|
if (mc->hasprompt && n > 1 && (mc->searchstr[0] != '\0')) {
|
||||||
@ -465,7 +456,7 @@ menu_draw_entry(struct menu_ctx *mc, struct menu_q *resultq,
|
|||||||
(sc->xftfont->height + 1) * entry, mc->width,
|
(sc->xftfont->height + 1) * entry, mc->width,
|
||||||
(sc->xftfont->height + 1) + sc->xftfont->descent);
|
(sc->xftfont->height + 1) + sc->xftfont->descent);
|
||||||
color = active ? CWM_COLOR_MENU_FONT_SEL : CWM_COLOR_MENU_FONT;
|
color = active ? CWM_COLOR_MENU_FONT_SEL : CWM_COLOR_MENU_FONT;
|
||||||
xu_xft_draw(sc, text, sc->menuwin, color,
|
xu_xft_draw(sc, text, color,
|
||||||
0, (sc->xftfont->height + 1) * entry + sc->xftfont->ascent + 1);
|
0, (sc->xftfont->height + 1) * entry + sc->xftfont->ascent + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ mousefunc_sweep_draw(struct client_ctx *cc)
|
|||||||
XMapWindow(X_Dpy, sc->menuwin);
|
XMapWindow(X_Dpy, sc->menuwin);
|
||||||
XClearWindow(X_Dpy, sc->menuwin);
|
XClearWindow(X_Dpy, sc->menuwin);
|
||||||
|
|
||||||
xu_xft_draw(sc, asize, sc->menuwin, CWM_COLOR_MENU_FONT,
|
xu_xft_draw(sc, asize, CWM_COLOR_MENU_FONT,
|
||||||
0, sc->xftfont->ascent + 1);
|
0, sc->xftfont->ascent + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
1
screen.c
1
screen.c
@ -56,7 +56,6 @@ screen_init(int which)
|
|||||||
TAILQ_INIT(&sc->mruq);
|
TAILQ_INIT(&sc->mruq);
|
||||||
|
|
||||||
group_init(sc);
|
group_init(sc);
|
||||||
menu_init(sc);
|
|
||||||
|
|
||||||
rootattr.cursor = Cursor_normal;
|
rootattr.cursor = Cursor_normal;
|
||||||
rootattr.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|
|
rootattr.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|
|
||||||
|
4
xutil.c
4
xutil.c
@ -442,10 +442,8 @@ xu_xft_width(XftFont *xftfont, const char *text, int len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
xu_xft_draw(struct screen_ctx *sc, const char *text,
|
xu_xft_draw(struct screen_ctx *sc, const char *text, int color, int x, int y)
|
||||||
Drawable d, int color, int x, int y)
|
|
||||||
{
|
{
|
||||||
XftDrawChange(sc->xftdraw, d);
|
|
||||||
XftDrawStringUtf8(sc->xftdraw, &sc->xftcolor[color], sc->xftfont,
|
XftDrawStringUtf8(sc->xftdraw, &sc->xftcolor[color], sc->xftfont,
|
||||||
x, y, (const FcChar8*)text, strlen(text));
|
x, y, (const FcChar8*)text, strlen(text));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user