Compartilhar via


CRgn::CreateRectRgnIndirect

Cria uma área retangular que é armazenada no objeto de CRgn .

BOOL CreateRectRgnIndirect(
   LPCRECT lpRect 
);

Parâmetros

  • lpRect
    Os pontos a RECT estrutura ou ao objeto de CRect que contêm as coordenadas lógicas cantos superior esquerdo e inferior direito da região.A estrutura de RECT tem a seguinte forma:

    typedef struct tagRECT {

    int left;

    int top;

    int right;

    int bottom;

    } RECT;

Valor de retorno

Diferente de zero se a operação foi bem-sucedida; se não 0.

Comentários

O tamanho de uma região é limitado a 32.767 por 32.767 unidades lógicas ou a 64K de memória, qualquer é menor.

Quando tiver terminado de usar uma região criada por CreateRectRgnIndirect, um aplicativo deve usar a função de membro de CGDIObject::DeleteObject 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

CRgn Class

Gráfico de hierarquia

CRgn::CreateRectRgn

CRgn::CreateRoundRectRgn

CreateRectRgnIndirect