9term: adjust to dpi changes

R=rsc
http://codereview.appspot.com/6847105
This commit is contained in:
Russ Cox 2012-11-26 00:13:18 -05:00
parent 94dae4befc
commit a8a0a6422c

View file

@ -35,6 +35,14 @@ static Image *holdcol;
static Image *lightholdcol; static Image *lightholdcol;
static Image *paleholdcol; static Image *paleholdcol;
static int
wscale(Window *w, int n)
{
if(w == nil || w->i == nil)
return n;
return scalesize(w->i->display, n);
}
Window* Window*
wmk(Image *i, Mousectl *mc, Channel *ck, Channel *cctl, int scrolling) wmk(Image *i, Mousectl *mc, Channel *ck, Channel *cctl, int scrolling)
{ {
@ -58,7 +66,7 @@ wmk(Image *i, Mousectl *mc, Channel *ck, Channel *cctl, int scrolling)
} }
w = emalloc(sizeof(Window)); w = emalloc(sizeof(Window));
w->screenr = i->r; w->screenr = i->r;
r = insetrect(i->r, Selborder+1); r = insetrect(i->r, wscale(w, Selborder)+wscale(w, 1));
w->i = i; w->i = i;
w->mc = *mc; w->mc = *mc;
w->ck = ck; w->ck = ck;
@ -69,9 +77,9 @@ wmk(Image *i, Mousectl *mc, Channel *ck, Channel *cctl, int scrolling)
w->mouseread = chancreate(sizeof(Mousereadmesg), 0); w->mouseread = chancreate(sizeof(Mousereadmesg), 0);
w->wctlread = chancreate(sizeof(Consreadmesg), 0); w->wctlread = chancreate(sizeof(Consreadmesg), 0);
w->scrollr = r; w->scrollr = r;
w->scrollr.max.x = r.min.x+Scrollwid; w->scrollr.max.x = r.min.x+wscale(w, Scrollwid);
w->lastsr = ZR; w->lastsr = ZR;
r.min.x += Scrollwid+Scrollgap; r.min.x += wscale(w, Scrollwid)+wscale(w, Scrollgap);
frinit(&w->f, r, font, i, cols); frinit(&w->f, r, font, i, cols);
w->f.maxtab = maxtab*stringwidth(font, "0"); w->f.maxtab = maxtab*stringwidth(font, "0");
w->topped = ++topped; w->topped = ++topped;
@ -80,9 +88,9 @@ wmk(Image *i, Mousectl *mc, Channel *ck, Channel *cctl, int scrolling)
w->scrolling = scrolling; w->scrolling = scrolling;
w->dir = estrdup(startdir); w->dir = estrdup(startdir);
w->label = estrdup("<unnamed>"); w->label = estrdup("<unnamed>");
r = insetrect(w->i->r, Selborder); r = insetrect(w->i->r, wscale(w, Selborder));
draw(w->i, r, cols[BACK], nil, w->f.entire.min); draw(w->i, r, cols[BACK], nil, w->f.entire.min);
wborder(w, Selborder); wborder(w, wscale(w, Selborder));
wscrdraw(w); wscrdraw(w);
incref(&w->ref); /* ref will be removed after mounting; avoids delete before ready to be deleted */ incref(&w->ref); /* ref will be removed after mounting; avoids delete before ready to be deleted */
return w; return w;
@ -123,11 +131,11 @@ fprint(2, "res %p %p\n", w->i, i);
} }
/* wsetname(w); */ /* wsetname(w); */
/*XXX w->mc.image = i; */ /*XXX w->mc.image = i; */
r = insetrect(i->r, Selborder+1); r = insetrect(i->r, wscale(w, Selborder)+wscale(w, 1));
w->scrollr = r; w->scrollr = r;
w->scrollr.max.x = r.min.x+Scrollwid; w->scrollr.max.x = r.min.x+wscale(w, Scrollwid);
w->lastsr = ZR; w->lastsr = ZR;
r.min.x += Scrollwid+Scrollgap; r.min.x += wscale(w, Scrollwid)+wscale(w, Scrollgap);
if(move) if(move)
frsetrects(&w->f, r, w->i); frsetrects(&w->f, r, w->i);
else{ else{
@ -135,13 +143,13 @@ fprint(2, "res %p %p\n", w->i, i);
frinit(&w->f, r, w->f.font, w->i, cols); frinit(&w->f, r, w->f.font, w->i, cols);
wsetcols(w); wsetcols(w);
w->f.maxtab = maxtab*stringwidth(w->f.font, "0"); w->f.maxtab = maxtab*stringwidth(w->f.font, "0");
r = insetrect(w->i->r, Selborder); r = insetrect(w->i->r, wscale(w, Selborder));
draw(w->i, r, cols[BACK], nil, w->f.entire.min); draw(w->i, r, cols[BACK], nil, w->f.entire.min);
wfill(w); wfill(w);
wsetselect(w, w->q0, w->q1); wsetselect(w, w->q0, w->q1);
wscrdraw(w); wscrdraw(w);
} }
wborder(w, Selborder); wborder(w, wscale(w, Selborder));
w->topped = ++topped; w->topped = ++topped;
w->resized = TRUE; w->resized = TRUE;
w->mouse.counter++; w->mouse.counter++;
@ -154,9 +162,9 @@ wrefresh(Window *w, Rectangle r)
/* BUG: rectangle is ignored */ /* BUG: rectangle is ignored */
if(w == input) if(w == input)
wborder(w, Selborder); wborder(w, wscale(w, Selborder));
else else
wborder(w, Unselborder); wborder(w, wscale(w, Unselborder));
if(w->mouseopen) if(w->mouseopen)
return; return;
draw(w->i, insetrect(w->i->r, Borderwidth), w->f.cols[BACK], nil, w->i->r.min); draw(w->i, insetrect(w->i->r, Borderwidth), w->f.cols[BACK], nil, w->i->r.min);
@ -764,10 +772,10 @@ wrepaint(Window *w)
frredraw(&w->f); frredraw(&w->f);
} }
if(w == input){ if(w == input){
wborder(w, Selborder); wborder(w, wscale(w, Selborder));
wsetcursor(w, 0); wsetcursor(w, 0);
}else }else
wborder(w, Unselborder); wborder(w, wscale(w, Unselborder));
} }
int int
@ -890,7 +898,7 @@ wplumb(Window *w)
int int
winborder(Window *w, Point xy) winborder(Window *w, Point xy)
{ {
return ptinrect(xy, w->screenr) && !ptinrect(xy, insetrect(w->screenr, Selborder)); return ptinrect(xy, w->screenr) && !ptinrect(xy, insetrect(w->screenr, wscale(w, Selborder)));
} }
void void