CRgn::CreateRectRgnIndirect
Crea un área rectangular que se almacena en el objeto de CRgn .
BOOL CreateRectRgnIndirect(
LPCRECT lpRect
);
Parámetros
lpRect
Señala una estructura de RECT o un objeto de CRect que contiene las coordenadas lógicas superior izquierda y las esquinas inferior derecha de la región. La estructura de RECT tiene el siguiente formato:typedef struct tagRECT {
int left;
int top;
int right;
int bottom;
} RECT;
Valor devuelto
Distinto de cero si la operación se realizó correctamente; si no 0.
Comentarios
El tamaño de una región está limitado a 32.767 por 32.767 unidades lógicas o a de memoria de, lo que sea menor.
Cuando haya terminado de utilizar una región creada por CreateRectRgnIndirect, una aplicación debe utilizar la función miembro de CGDIObject:: DeleteObject para quitar la región.
Ejemplo
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
encabezado: afxwin.h