canvas绘图不清晰怎么办
这篇文章主要介绍了canvas绘图不清晰怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
现象描述
同样大小的图片(60x60px)用canvas和DOM绘制,结果发现canvas的画面质量要差很多。结果如下图所示。
上图中,左侧红框中的金币采用DOM绘制,右侧和下方的金币和文字等使用canvas绘制,结果canvas绘制的图片模糊不清。
原因分析
假设dpr = 2;图片大小为60x60px;对dpr有一定的了解基础。
1.DOM呈现图片过程
图片——》浏览器css像素(显示尺寸)——》屏幕实际像素
60x60 30x30 60x60
图片像素——》实际像素
1: 1
2.canvas绘制过程
图片像素——》canvas像素(画布尺寸)——》css像素(显示尺寸)——》屏幕实际像素
60x60 30x30 30x30 60x60
图片像素——》画布像素——》实际像素
4: 1: 4
也就是说,canvas的绘制过程中图片到画布的过程中进行了像素的抽稀,画布到屏幕像素时又进行了插值,所以造成图片质量下降。
解决方案
放大画布的尺寸,但是canvas显示尺寸不变;
图片像素——》canvas像素(画布尺寸)——》css像素(显示尺寸)——》屏幕实际像素
60x60 60x60 30x30 60x60
图片像素——》实际像素
1: 1
而canvas的设计的时候正好有对象的属性来分别管理画布尺寸和显示尺寸;canvas的width、height属性用于管理画布尺寸;canvas的style属性中的width、height正好是显示尺寸。
也就是说解决方案就是设置舞台的尺寸和图片像素的尺寸一致,显示尺寸为正常显示尺寸;假设canvas的显示尺寸为窗口宽度,创建canvas的时候指定canvas的width属性为2 * body.clientHeight;style.widht为body.clientHeight + 'px';
改变后的效果图如下:
感谢你能够认真阅读完这篇文章,希望小编分享的“canvas绘图不清晰怎么办”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341