CRgn::CreateEllipticRgn
発行: 2016年7月
楕円空間を作成します。
構文
BOOL CreateEllipticRgn(
int x1,
int y1,
int x2,
int y2
);
パラメーター
x1
楕円に外接する四角形の左上隅の論理的な x 座標を指定します。y1
楕円に外接する四角形の左上隅の論理 y 座標を指定します。x2
楕円に外接する四角形の右下隅の論理的な x 座標を指定します。y2
楕円に外接する四角形の右下隅の論理 y 座標を指定します。
戻り値
操作が成功する場合は、; それ以外の場合は 0。
解説
領域は x1、y1、x2と y2で指定された外接する四角形によって定義されます。 領域は 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