CRgn::CreateRoundRectRgn
Cria uma região retangular com cantos arredondados que é armazenado na CRgn objeto.
BOOL CreateRoundRectRgn(
int x1,
int y1,
int x2,
int y2,
int x3,
int y3
);
Parâmetros
x1
Especifica a coordenada x lógica do canto superior esquerdo da região.y1
Especifica a coordenada y lógica do canto superior esquerdo da região.x2
Especifica a coordenada x lógica do canto inferior direito da região.y2
Especifica a coordenada y lógica do canto inferior direito da região.x 3
Especifica a largura da elipse usada para criar os cantos arredondados.y3
Especifica a altura da elipse usada para criar os cantos arredondados.
Valor de retorno
Diferente de zero se a operação foi bem-sucedida; caso contrário, 0.
Comentários
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 um aplicativo terminou de usar uma região criada com o CreateRoundRectRgn função, ele deve selecionar a região do contexto de dispositivo e use o CGDIObject::DeleteObjectfunção de membro para removê-lo.
Exemplo
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 ));
Requisitos
Cabeçalho: afxwin.h