CRgn::CreateRectRgnIndirect
Crea un'area rettangolare archiviata nell'oggetto CRgn.
BOOL CreateRectRgnIndirect(
LPCRECT lpRect
);
Parametri
lpRect
Punta a RECT struttura o all'oggetto CRect che contengono le coordinate logiche di in alto a sinistra e gli angoli inferiore destro dell'area. La struttura RECT ha il formato seguente:typedef struct tagRECT {
int left;
int top;
int right;
int bottom;
} RECT;
Valore restituito
Diverso da zero se l'operazione ha esito positivo; in caso contrario 0.
Note
La dimensione di un'area è limitata a 32.767 per 32.767 unità logiche o della memoria, le dimensioni inferiori.
Quando ha terminato l'utilizzo di un'area creata da CreateRectRgnIndirect, un'applicazione deve utilizzare la funzione membro CGDIObject::DeleteObject per rimuovere l'area.
Esempio
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 ));
Requisiti
Header: afxwin.h