Direct2D (5) : 绘制自定义图形
2011-03-31 21:09
459 查看
下面是通过自定义函数绘制菱形的测试代码。
效果图:
uses Direct2D, D2D1; {自定义的绘制菱形的函数} function GetDiamondPath(ptLeft, ptTop: TD2DPoint2f): ID2D1PathGeometry; //返回路径接口 var sink: ID2D1GeometrySink; //给路径添加图形的接口 ptRight,ptBottom: TD2DPoint2f; begin {算出另外两个点} ptRight := D2D1PointF((ptTop.x-ptLeft.x)*2+ptLeft.x, ptLeft.y); ptBottom := D2D1PointF(ptTop.x, (ptLeft.y-ptTop.y)*2+ptTop.y); {构建 ID2D1PathGeometry} D2DFactory.CreatePathGeometry(Result); {建立并启用 ID2D1GeometrySink} Result.Open(sink); {开始添加图形,} sink.BeginFigure(ptLeft, D2D1_FIGURE_BEGIN_FILLED); //选项 D2D1_FIGURE_BEGIN_FILLED 标识图形可以填充 sink.AddLine(ptTop); sink.AddLine(ptRight); sink.AddLine(ptBottom); {结束图形并关闭 ID2D1GeometrySink} sink.EndFigure(D2D1_FIGURE_END_CLOSED); //选项 D2D1_FIGURE_END_CLOSED 标识图形自动封闭 sink.Close; end; {绘制} procedure TForm1.FormPaint(Sender: TObject); var path: ID2D1PathGeometry; begin path := GetDiamondPath(D2D1PointF(ClientWidth/5, ClientHeight/2), D2D1PointF(ClientWidth/2, ClientHeight/5)); with TDirect2DCanvas.Create(Canvas, ClientRect) do begin Pen.Color := clRed; Brush.Color := clYellow; BeginDraw; FillGeometry(path); DrawGeometry(path); EndDraw; Free; end; end; procedure TForm1.FormResize(Sender: TObject); begin Repaint; end;
效果图:
相关文章推荐
- iOS边练边学--(Quartz2D)基本图形的绘制#附加自定义进度控件的练习
- Direct2D (3) : 使用浮点参数绘制基本图形
- Xcode9学习笔记84 - 使用Quarz2d绘制自定义图形
- 使用WIC将Direct2D绘制的图形保存为文件
- Direct2D教程II——绘制基本图形和线型(StrokeStyle)的设置详解
- 使用WIC将Direct2D绘制的图形保存为文件
- 使用WIC将Direct2D绘制的图形保存为文件
- iOS--Quartz2D使用(自定义UIImageView控件、绘制基本图形)
- WPF 使用 Direct2D1 画图 绘制基本图形
- 十一、Qt 2D绘图(一)绘制简单图形
- Direct2D WIC绘制图片
- Direct2D教程(六)图形也能做运算
- 猫猫学IOS(二十九)UI之Quartz2D自定义下载控件_画各种图形
- Android 2D图形绘制 汇总
- SVG 2D入门2 - 图形绘制
- iOS开发UI篇—Quartz2D简单图形绘制(二)直线,三角形,矩形,扇形,弧,圆
- Direct2D (39) : 使用 IDWriteTextLayout.Draw() 方法绘制文本
- 自定义View进阶-Canvas之绘制图形
- Quart 2D 绘制图形简单总结
- 自定义view--绘制图形