次の方法で共有


CDC::Pie

中央と 2 のエンドポイント行で結合された楕円の円弧を描画して扇形を描画します。

BOOL Pie(
   int x1,
   int y1,
   int x2,
   int y2,
   int x3,
   int y3,
   int x4,
   int y4 
);
BOOL Pie(
   LPCRECT lpRect,
   POINT ptStart,
   POINT ptEnd 
);

パラメーター

  • x1
    外接する四角形の左上隅の x 座標を指定します (論理単位で)。

  • y1
    外接する四角形の左上隅の y 座標を指定します (論理単位で)。

  • x2
    外接する四角形の右上隅の x 座標を指定します (論理単位で)。

  • y2
    外接する四角形の右下隅の y 座標を指定します (論理単位で)。

  • x3
    円弧の開始点の x 座標を指定します (論理単位で)。このポイントは円弧に対応する必要はありません。

  • y3
    円弧の開始位置の y 座標を指定します (論理単位で)。このポイントは円弧に対応する必要はありません。

  • x4
    円弧のエンドポイントの x 座標を指定します (論理単位で)。このポイントは円弧に対応する必要はありません。

  • y4
    円弧のエンドポイントの y 座標を指定します (論理単位で)。このポイントは円弧に対応する必要はありません。

  • lpRect
    外接する四角形を指定します。このパラメーターの RECT の構造体への CRect のオブジェクトまたはポインターを渡すことができます。

  • ptStart
    円弧の開始点を指定します。このポイントは円弧に対応する必要はありません。このパラメーターの [ポイント] の構造や CPoint のオブジェクトを渡すこともできます。

  • ptEnd
    円弧のエンドポイントを指定します。このポイントは円弧に対応する必要はありません。このパラメーターの [ポイント] の構造や CPoint のオブジェクトを渡すこともできます。

戻り値

正常終了した場合は 0 以外を返します。それ以外の場合は 0 を返します。

解説

円弧の中心は x1、y1、x2と y2 で指定された外接する四角形の中心です (または lpRectなど) 円弧の開始と終了点は、x3y3、x4y4 として指定します (または ptStart と ptEndなど)

円弧は反時計回りで実行される選択されているペンで描画します。2 個の行は、エンドポイントから円弧の中心への描画します。扇形型の領域が現在のブラシで塗りつぶされます。x3 がx4 に相当し、y3 が y4に等しい場合、結果は楕円の中心点から点 (x3、y3) に単一行で楕円または (x4、y4)。

この関数は、図で描画されるまで継続しますが、右、下座標は含まれません。これは、図形の高さが y2 –図の y1 と幅 x2 あります。x1がであることを意味します。外接する四角形の幅と高さはどちらも 2 単位、32,767 未満の単位を超えることはできません。

使用例

void CDCView::DrawPie(CDC* pDC)
{
   // Fill the client area with a simple pie chart. A
   // big blue slice covers 75% of the pie, from
   // 6 o'clock to 3 o'clock. This portion is filled
   // with blue and has a blue edge. The remaining 25%
   // is filled with a red, diagonal hatch and has
   // a red edge.

   // Get the client area.
   CRect rectClient;
   GetClientRect(rectClient);

   // Make a couple of pens and similar brushes.
   CPen penBlue, penRed;
   CBrush brushBlue, brushRed;
   CBrush* pOldBrush;
   CPen* pOldPen;

   brushBlue.CreateSolidBrush(RGB(0, 0, 255));
   brushRed.CreateHatchBrush(HS_FDIAGONAL, RGB(255, 0, 0));
   penBlue.CreatePen(PS_SOLID | PS_COSMETIC, 1, RGB(0, 0, 255));
   penRed.CreatePen(PS_SOLID | PS_COSMETIC, 1, RGB(255, 0, 0));

   // Draw from 3 o'clock to 6 o'clock, counterclockwise,
   // in a blue pen with a solid blue fill.

   pOldPen = pDC->SelectObject(&penBlue);
   pOldBrush = pDC->SelectObject(&brushBlue);

   pDC->Pie(rectClient,
      CPoint(rectClient.right, rectClient.CenterPoint().y),
      CPoint(rectClient.CenterPoint().x, rectClient.right));

   // Draw the remaining quarter slice from 6 o'clock
   // to 3 o'clock, counterclockwise, in a red pen with
   // the hatched brush.
   pDC->SelectObject(&penRed);
   pDC->SelectObject(&brushRed);

   // Same parameters, but reverse start and end points.
   pDC->Pie(rectClient,
      CPoint(rectClient.CenterPoint().x, rectClient.right),
      CPoint(rectClient.right, rectClient.CenterPoint().y));

   // Restore the previous pen.
   pDC->SelectObject(pOldPen);
}

必要条件

ヘッダー: afxwin.h

参照

関連項目

CDC クラス

階層図

CDC::Chord

Pie

RECT 構造体

POINT 構造体

CRect クラス

CPoint クラス