Partilhar via


CRgn::CreateRectRgnIndirect

Cria uma região retangular que é armazenada na CRgn objeto.

BOOL CreateRectRgnIndirect(
   LPCRECT lpRect 
);

Parâmetros

  • lpRect
    Aponta para um RECT estrutura de ou CRect objeto que contém as coordenadas lógicas dos cantos superior esquerdo e inferior direito da região. The RECT estrutura tem a seguinte forma:

    typedef struct tagRECT {

    int left;

    } RECT;

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 tiver concluído usando uma região criada por CreateRectRgnIndirect, um aplicativo deve usar o CGDIObject::DeleteObjectfunção de membro para remover a região.

Exemplo

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

Requisitos

Cabeçalho: afxwin.h

Consulte também

Referência

Classe CRgn

Gráfico de hierarquia

CRgn::CreateRectRgn

CRgn::CreateRoundRectRgn

CreateRectRgnIndirect

Outros recursos

CRgn membros