ID2D1SimplifiedGeometrySink::EndFigure 方法 (d2d1.h)
结束绘制当前图形;视需要,可将其闭合。
语法
void EndFigure(
D2D1_FIGURE_END figureEnd
);
参数
figureEnd
类型: D2D1_FIGURE_END
指示当前图形是否闭合的值。 如果图形关闭,则会在当前点和 BeginFigure 指定的起点之间绘制一条线。
返回值
无
备注
在没有 对 BeginFigure 的匹配调用的情况下调用此方法会将几何接收器置于错误状态;后续调用将被忽略,调用 Close 方法时将返回总体失败。
示例
以下示例创建 ID2D1PathGeometry,检索接收器,使用它定义沙漏形状,然后使用D2D1_FIGURE_END_CLOSED值调用 EndFigure 以结束沙漏的创建。 有关完整示例,请参阅 如何绘制和填充复杂形状。
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、带 SP2 的 Windows Vista 和适用于 Windows Vista 的平台更新 [桌面应用 |UWP 应用] |
最低受支持的服务器 | Windows Server 2008 R2、Windows Server 2008 SP2 和适用于 Windows Server 2008 的平台更新 [桌面应用 |UWP 应用] |
目标平台 | Windows |
标头 | d2d1.h |
Library | D2d1.lib |
DLL | D2d1.dll |