下面有三个绘图函数需要一个指向矩形结构的指针:
FillRect(hdc,&rect,hbursh);//填充
FrameRect(hdc,&rect,hbrush);//掏空
InvertRect(hdc,&rect);//内部取反
case WM_PAINT:
hdc=BeginPaint(hwnd,&ps);
//GetClientRect(hwnd,&rect);
//hrgn=CreateRectRgn(100,100,300,300);
//hbrush=CreateSolidBrush(RGB(255,0,0));
//FillRgn(hdc,hrgn,hbrush);
//InvertRgn(hdc,hrgn);//取反
//FrameRgn(hdc,hrgn,hbrush,0,0);
r1.left=100;
r1.top=100;
r1.right=200;
r1.bottom=200;
hbrush=CreateSolidBrush(RGB(255,0,0));//创建画刷
FillRect(hdc,&r1,hbrush);
r2.left=200;
r2.top=100;
r2.right=300;
r2.bottom=200;
FrameRect(hdc,&r2,hbrush);
r3.left=300;
r3.top=100;
r3.right=400;
r3.bottom=200;
InvertRect(hdc,&r3);
EndPaint(hwnd,&ps);
return 0;
下面还有八个关于矩形的操作:
OffsetRect(&rect,x,y) | 将矩形移动 |
InflateRect(&rect,x,y) | 增大缩小矩形的尺寸 |
SetRectEmpty(&rect) | 把矩形结构各字段设置为0 |
CopyRect(&DestRect,&ScrRect) | 将一个矩形结构复制到另一个矩形结构 |
IntersectRect(&destRect,&SrcRect1,&SrcRect2) | 获取两个矩形的交集 |
UnionRect(&DestRect,&SrcRect1,&SrcRect2) | 获取两个矩形的并集 |
bEmpty=IsRectEmpty(&Rect) | 判断矩形是否为空 |
bInRect=PtInRect(&rect,point) | 判断点是否在矩形内部 |
区域跟矩形一样,有以下四个绘图函数
FillRgn(hdc,hrgn,hbrush);
FrameRgn(hdc,hbrush,xFrame,yFrame);
InvertRgn(hdc,hrgn);
PaintRgn(hdc,hrgn);
DeleteObject(hrgn);
SelectObject(hdc,hrgn)=SelectClipRgn(hdc,hrgn);
使得矩形,区域有效和无效的函数
InvalidateRect ValidateRect
InvalidateRgn ValidateRgn
下面是简单的例子:
case WM_PAINT:
hdc=BeginPaint(hwnd,&ps);
//GetClientRect(hwnd,&rect);
//hrgn=CreateRectRgn(100,100,300,300);
//hbrush=CreateSolidBrush(RGB(255,0,0));
//FillRgn(hdc,hrgn,hbrush);
//InvertRgn(hdc,hrgn);//取反
//FrameRgn(hdc,hrgn,hbrush,0,0);
r1.left=100;
r1.top=100;
r1.right=200;
r1.bottom=200;
hbrush=CreateSolidBrush(RGB(255,0,0));//创建画刷
//FillRect(hdc,&r1,hbrush);
r2.left=150;
r2.top=100;
r2.right=250;
r2.bottom=200;
//FrameRect(hdc,&r2,hbrush);
IntersectRect(&r3,&r1,&r2);//r1,r2矩形取交集,存放在r3
FillRect(hdc,&r3,hbrush);
flag=(int)IsRectEmpty(&r3);//判断矩形是否为空
TextOut(hdc,300,300,szBuffer,wsprintf(szBuffer,TEXT("%d"),flag));
EndPaint(hwnd,&ps);
return 0;
hrgn=CreateRectRgn(xleft,ytop,xright,ybottom);
hrgn=CreateRectRgnIndirect(&rect);
hrgn=CreateEllipticRgn(xleft,ytop,xright,ybottom);
hrgn=CreatePolygonRgn(&point,icount,ipolyFillMode);