Share via


CRgn::CreateEllipticRgn

 

発行: 2016年7月

楕円空間を作成します。

構文

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

パラメーター

  • x1
    楕円に外接する四角形の左上隅の論理的な x 座標を指定します。

  • y1
    楕円に外接する四角形の左上隅の論理 y 座標を指定します。

  • x2
    楕円に外接する四角形の右下隅の論理的な x 座標を指定します。

  • y2
    楕円に外接する四角形の右下隅の論理 y 座標を指定します。

戻り値

操作が成功する場合は、; それ以外の場合は 0。

解説

領域は x1y1x2y2で指定された外接する四角形によって定義されます。 領域は CRgn のオブジェクトに格納されます。

領域のサイズは 32,767 の論理単位またはメモリの 32,767 KB により小さい、どの場合でも、制限されます。

これは CreateEllipticRgn 関数で作成された領域を使い終わったらアプリケーションは、デバイス コンテキストから領域を選択し、それを削除するに DeleteObject 関数を使用する必要があります。

使用例

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

必要条件

ヘッダー: afxwin.h

参照

CRgn クラス
階層図
CRgn::CreateEllipticRgnIndirect
CreateEllipticRgn