CRgn::CreateEllipticRgn
Cria uma região elíptica.
BOOL CreateEllipticRgn(
int x1,
int y1,
int x2,
int y2
);
Parâmetros
x1
Especifica a coordenada x lógica do canto superior esquerdo do retângulo delimitador da elipse.y1
Especifica a coordenada y lógica do canto superior esquerdo do retângulo delimitador da elipse.x2
Especifica a coordenada x lógica do canto inferior direito do retângulo delimitador da elipse.y2
Especifica a coordenada y lógica do canto inferior direito do retângulo delimitador da elipse.
Valor de retorno
Diferente de zero se a operação foi bem-sucedida; caso contrário, 0.
Comentários
A região é definida pelo retângulo delimitador especificado por x1, y1, x2, e y2. A região é armazenada na CRgn objeto.
O dimensionar de uma região é limitado a 64 K de memória ou de unidades lógicas de 32.767 a 32.767, o que for menor.
Quando tiver concluído usando uma região criada com o CreateEllipticRgn função, um aplicativo deve selecionar a região do contexto de dispositivo e use o DeleteObject função para removê-lo.
Exemplo
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 ));
Requisitos
Cabeçalho: afxwin.h
Consulte também
Referência
CRgn::CreateEllipticRgnIndirect