Udostępnij za pośrednictwem


CRgn::CreateEllipticRgn

Tworzy eliptycznego regionu.

BOOL CreateEllipticRgn(
   int x1,
   int y1,
   int x2,
   int y2 
);

Parametry

  • x1
    Określa logiczną współrzędną x lewego górnego rogu prostokąta obwiedni elipsy.

  • y1
    Określa logiczną współrzędną y lewego górnego rogu prostokąta obwiedni elipsy.

  • x2
    Określa logiczną współrzędną x prawego dolnego rogu prostokąta obwiedni elipsy.

  • y2
    Określa logiczną współrzędna y prawego dolnego rogu prostokąta obwiedni elipsy.

Wartość zwracana

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

Uwagi

Region jest zdefiniowany przez prostokąta obwiedni, określonej przez x1, y1, x2, i y2.Region jest przechowywany w CRgn obiektu.

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

Po zakończeniu regionu, utworzone przy użyciu CreateEllipticRgn funkcji aplikacji należy wybrać region out kontekstu urządzenia i wykorzystania DeleteObject funkcji go usunąć.

Przykład

CRgn   rgnA, rgnB, rgnC;

VERIFY(rgnA.CreateEllipticRgn(200, 100, 350, 250));
VERIFY(rgnB.CreateRectRgn( 0, 0, 50, 50 ));
VERIFY(rgnB.CopyRgn( &rgnA ));
int nOffsetResult = rgnB.OffsetRgn( -75, 75 );
ASSERT( nOffsetResult != ERROR && nOffsetResult != NULLREGION );

VERIFY(rgnC.CreateRectRgn( 0, 0, 1, 1));
int nCombineResult = rgnC.CombineRgn( &rgnA, &rgnB, RGN_AND );
ASSERT( nCombineResult != ERROR && nOffsetResult != NULLREGION );

CBrush brA, brB, brC;
VERIFY(brC.CreateHatchBrush( HS_FDIAGONAL, RGB(0, 0, 255) )); // Blue
VERIFY(pDC->FillRgn( &rgnC, &brC ));
VERIFY(brA.CreateSolidBrush( RGB(255, 0, 0) ));  // rgnA Red
VERIFY(pDC->FrameRgn( &rgnA, &brA, 2, 2 ));
VERIFY(brB.CreateSolidBrush( RGB(0, 255, 0) ));  // rgnB Green
VERIFY(pDC->FrameRgn( &rgnB, &brB, 2, 2 ));   

Wymagania

Nagłówek: afxwin.h

Zobacz też

Informacje

Klasa CRgn

Wykres hierarchii

CRgn::CreateEllipticRgnIndirect

CreateEllipticRgn