Browse Source

copy old pixmap to new on resize

master
Devin J. Pohly 14 years ago
parent
commit
d85f7319a2
1 changed files with 15 additions and 1 deletions
  1. +15
    -1
      st.c

+ 15
- 1
st.c View File

@ -1260,10 +1260,24 @@ tresize(int col, int row) {
void void
xresize(int col, int row) { xresize(int col, int row) {
Pixmap newbuf;
int oldw, oldh;
oldw = xw.bufw;
oldh = xw.bufh;
xw.bufw = MAX(1, col * xw.cw); xw.bufw = MAX(1, col * xw.cw);
xw.bufh = MAX(1, row * xw.ch); xw.bufh = MAX(1, row * xw.ch);
newbuf = XCreatePixmap(xw.dis, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dis, xw.scr));
XCopyArea(xw.dis, xw.buf, newbuf, dc.gc, 0, 0, xw.bufw, xw.bufh, 0, 0);
XFreePixmap(xw.dis, xw.buf); XFreePixmap(xw.dis, xw.buf);
xw.buf = XCreatePixmap(xw.dis, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dis, xw.scr));
XSetForeground(xw.dis, dc.gc, dc.col[DefaultBG]);
if(xw.bufw > oldw)
XFillRectangle(xw.dis, newbuf, dc.gc, oldw, 0,
xw.bufw-oldw, MIN(xw.bufh, oldh));
if(xw.bufh > oldh)
XFillRectangle(xw.dis, newbuf, dc.gc, 0, oldh,
xw.bufw, xw.bufh-oldh);
xw.buf = newbuf;
} }
void void


Loading…
Cancel
Save