CRgn::CreateRoundRectRgn
Prostokątny obszar tworzy zaokrąglone narożniki, które są przechowywane w CRgn obiektu.
BOOL CreateRoundRectRgn(
int x1,
int y1,
int x2,
int y2,
int x3,
int y3
);
Parametry
x1
Określa logiczną współrzędną x lewego górnego rogu regionu.y1
Określa logiczną współrzędną y lewego górnego rogu regionu.x2
Określa logiczną współrzędną x prawego dolnego rogu regionu.y2
Określa logiczną współrzędna y prawego dolnego rogu regionu.x 3
Określa szerokość elipsy, używany do tworzenia zaokrąglone narożniki.y3
Określa wysokość elipsy, używany do tworzenia zaokrąglone narożniki.
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.
Gdy aplikacja zakończy regionu utworzonych za pomocą CreateRoundRectRgn funkcji, to należy wybrać region out kontekstu urządzenia i wykorzystania CGDIObject::DeleteObject Członkowskich funkcji go usunąć.
Przykład
CRgn rgnA, rgnB, rgnC;
VERIFY(rgnA.CreateRoundRectRgn( 50, 50, 150, 150, 30, 30 ));
VERIFY(rgnB.CreateRoundRectRgn( 200, 75, 250, 125, 50, 50 ));
VERIFY(rgnC.CreateRectRgn( 0, 0, 50, 50 ));
int nCombineResult = rgnC.CombineRgn( &rgnA, &rgnB, RGN_OR );
ASSERT( nCombineResult != ERROR && nCombineResult != NULLREGION );
CBrush brA, brB, brC;
VERIFY(brA.CreateSolidBrush( RGB(255, 0, 0) ));
VERIFY(pDC->FillRgn( &rgnA, &brA)); // rgnA Red Filled
VERIFY(brB.CreateSolidBrush( RGB(0, 255, 0) ));
VERIFY(pDC->FillRgn( &rgnB, &brB)); // rgnB Green Filled
VERIFY(brC.CreateSolidBrush( RGB(0, 0, 255) )); // rgnC Blue
VERIFY(pDC->FrameRgn( &rgnC, &brC, 2, 2 ));
Wymagania
Nagłówek: afxwin.h