copy old pixmap to new on resize
This commit is contained in:
		
							
								
								
									
										16
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								st.c
									
									
									
									
									
								
							@@ -1260,10 +1260,24 @@ tresize(int col, int row) {
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
xresize(int col, int row) {
 | 
			
		||||
	Pixmap newbuf;
 | 
			
		||||
	int oldw, oldh;
 | 
			
		||||
 | 
			
		||||
	oldw = xw.bufw;
 | 
			
		||||
	oldh = xw.bufh;
 | 
			
		||||
	xw.bufw = MAX(1, col * xw.cw);
 | 
			
		||||
	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);
 | 
			
		||||
	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
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user