CRgn::CreateRectRgnIndirect
Cria uma área retangular que é armazenada no objeto de CRgn .
BOOL CreateRectRgnIndirect(
LPCRECT lpRect
);
Parâmetros
lpRect
Os pontos a RECT estrutura ou ao objeto de CRect que contêm as coordenadas lógicas cantos superior esquerdo e inferior direito da região. A estrutura de RECT tem a seguinte forma:typedef struct tagRECT {
int left;
int top;
int right;
int bottom;
} RECT;
Valor de retorno
Diferente de zero se a operação foi bem-sucedida; se não 0.
Comentários
O tamanho de uma região é limitado a 32.767 por 32.767 unidades lógicas ou a 64K de memória, qualquer é menor.
Quando tiver terminado de usar uma região criada por CreateRectRgnIndirect, um aplicativo deve usar a função de membro de CGDIObject::DeleteObject para remover a região.
Exemplo
CRgn rgnA, rgnB, rgnC;
CRect rectA(50, 50, 150, 150);
CRect rectB(100, 50, 200, 150);
VERIFY(rgnA.CreateRectRgnIndirect(&rectA));
VERIFY(rgnB.CreateEllipticRgnIndirect(&rectB));
VERIFY(rgnC.CreateRectRgn( 0, 0, 50, 50 ));
int nCombineResult = rgnC.CombineRgn( &rgnA, &rgnB, RGN_AND );
ASSERT( nCombineResult != ERROR && nCombineResult != NULLREGION );
CBrush brA, brB, brC;
VERIFY(brA.CreateSolidBrush( RGB(255, 0, 0) ));
VERIFY(pDC->FrameRgn( &rgnA, &brA, 2, 2 )); // rgnA Red
VERIFY(brB.CreateSolidBrush( RGB(0, 255, 0) ));
VERIFY(pDC->FrameRgn( &rgnB, &brB, 2, 2 )); // rgnB Green
VERIFY(brC.CreateSolidBrush( RGB(0, 0, 255) )); // rgnC Blue
VERIFY(pDC->FrameRgn( &rgnC, &brC, 2, 2 ));
Requisitos
Cabeçalho: afxwin.h