ID2D1SimplifiedGeometrySink::Close メソッド
ジオメトリ シンクを閉じ、シンクがエラー状態かどうかを示して、シンクのエラー状態をリセットします。
構文
virtual HRESULT Close() = 0;
パラメーター
This にはパラメーターがありません。
戻り値
HRESULT
メソッドが成功した場合は、S_OK が返されます。 それ以外の場合は、エラー コードが返されます。HRESULT.
解説
図の処理中にジオメトリ シンクを閉じないでください。この操作を行った場合、ジオメトリ シンクがエラー状態になります。Close 操作を正常に完了するには、BeginFigure の呼び出しごとに 1 つの EndFigure の呼び出しが必要です。
このメソッドを呼び出すと、ジオメトリ シンクが使用できなくなる場合があります。Direct2D でのこのインターフェイスの実装により、ジオメトリ シンクを閉じた後に変更することはできなくなりました。ただし、他の実装では、この制限がない場合があります。
例
次の例では、ID2D1PathGeometry を作成してシンクを取得し、シンクを使用して砂時計の図形を定義します。
ID2D1GeometrySink *pSink = NULL;
// Create a path geometry.
if (SUCCEEDED(hr))
{
hr = m_pD2DFactory->CreatePathGeometry(&m_pPathGeometry);
if (SUCCEEDED(hr))
{
// Write to the path geometry using the geometry sink.
hr = m_pPathGeometry->Open(&pSink);
if (SUCCEEDED(hr))
{
pSink->BeginFigure(
D2D1::Point2F(0, 0),
D2D1_FIGURE_BEGIN_FILLED
);
pSink->AddLine(D2D1::Point2F(200, 0));
pSink->AddBezier(
D2D1::BezierSegment(
D2D1::Point2F(150, 50),
D2D1::Point2F(150, 150),
D2D1::Point2F(200, 200))
);
pSink->AddLine(D2D1::Point2F(0, 200));
pSink->AddBezier(
D2D1::BezierSegment(
D2D1::Point2F(50, 150),
D2D1::Point2F(50, 50),
D2D1::Point2F(0, 0))
);
pSink->EndFigure(D2D1_FIGURE_END_CLOSED);
hr = pSink->Close();
}
SafeRelease(&pSink);
}
}
要件
クライアントの最小要件 |
Windows 7, Windows Vista SP2 および Windows Vista 用のプラットフォーム更新プログラム |
サーバーの最小要件 |
Windows Server 2008 R2, Windows Server 2008 SP2 および Windows Server 2008 用のプラットフォーム更新プログラム |
ヘッダー |
D2d1.h |
ライブラリ |
D2d1.lib |
DLL |
D2d1.dll |