Udostępnij za pośrednictwem


CRgn::CreateRectRgnIndirect

Tworzy prostokątny obszar, który jest przechowywany w CRgn obiektu.

BOOL CreateRectRgnIndirect(
   LPCRECT lpRect 
);

Parametry

  • lpRect
    Wskazuje na RECT struktury lub CRect obiekt, który zawiera współrzędne logiczne narożniki lewym górnym i dolnym regionu.RECT Struktura ma następującą postać:

    typedef struct tagRECT {

    int left;

    int top;

    int right;

    int bottom;

    } RECT;

Wartość zwracana

Niezerowa, jeśli operacja powiodła się; 0 inaczej.

Uwagi

Rozmiar regionu jest ograniczona do 32 767 przez 32 767 logiczne jednostki lub 64 K pamięci, jest mniejsze.

Po zakończeniu przy użyciu regionu, utworzony przez CreateRectRgnIndirect, należy użyć aplikacji CGDIObject::DeleteObject funkcji składowej, aby usunąć region.

Przykład

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 ));

Wymagania

Nagłówek: afxwin.h

Zobacz też

Informacje

Klasa CRgn

Wykres hierarchii

CRgn::CreateRectRgn

CRgn::CreateRoundRectRgn

CreateRectRgnIndirect