欢迎光临
我的个人博客网站

WPF 关于绘图个人总结

内容均为个人总结。

如果错误请告知,并多多见谅。

总的来说绘图是分为两个范围,一是形状,二是像素填充。

形状也就是绘制矩形,圆形,复杂组合形状。

像素填充例如图像填充,但更多是位图操作,同样也是可以绘制形状,不过对于形状的填充算法相对很难,是需要独立进行计算。

在WPF中,对应着分为控件绘图,位图操作。

对于简单的绘图我也不多加复述,通常一般的难点,也就是复杂性绘图,大规模绘图等。

一般呢,对于有形状绘图有一下方案

1 直接重载OnRender方法并在内使用DrawingContext进行绘图

2 劫持承载控件,并创建继承DrawingVisual控件,并使用RenderOpen方法进行绘制

3 使用GDI+绘图并配合Bitmap后使用DrawingContext后经行绘图

通常,方法1,可能使用范围过小,方法3呢效果不错,但是放大后效果不好。

所以我们重点说一下方法2

使用方法很简单,主要是里面绘制的方法。

最好的办法就是使用DrawGeometry。

但是问题是是提交多个控件绘图对应内容呢? 还是提交一次后内部多次绘制呢?

举例来说,我之前发的矩形格子,使用的是多次提交,每次提交少量绘制,当绘制大量内容后意味大量提交,大量绘制,虽然单次绘图很快基本0.2毫秒,但架不住多啊,也就造成卡顿。

所以正确的方法应该是少量提交,内部多次绘制,减少不必要卡顿。

其次,绘图的方式最好使用streamgeometry,这是真的快。并使用线性背景色,不过使用ImageBrush会是更好的选择。

例图 2*2像素的格子,大小是1920*1010,使用的是ImageBrush。同时画笔冻结等方式,性能也会提交。

WPF 关于绘图个人总结

一般情况下,大部分是绘制图表等方式,性能不行其实是可以通过一些方式避免,例如对数据进行处理,归一化,抽样等方式,将绘制的东西减少。

还有说的,就是位图。

一般情况下,WPF2D绘图最快的就是可写位图,真的是快,不论大小,内容还是对颜色上的控制,相对快很多,但是缺点是什么? 是放大后,是需要重新对局部处理。这又是一些其他的开销。

2D绘图的使用效果一般很够用了。

使用顺序可以用是 控件绘制-可写位图,如果这些效果还不好,那就上大招D3Image,因为前面的绘制的东西,使用显卡效率不高。D3Image是直接Dx所以会高很多。所以效果很好。

 

相关代码下载【没有位图操作,D3Image等内容,具体使用相对不难,而找到具体使用差距才是本意,后续会补充】

 

赞(0) 打赏
未经允许不得转载:张拓的天空 » WPF 关于绘图个人总结
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

专业的IT技术经验分享 更专业 更方便

联系我们本站主机

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏