canvas画图被放大且模糊的解决方法


Posted in HTML / CSS onAugust 11, 2020

先来理解canvas的这几个宽度和高度

canvas.width是画布的大小,而canvas.style.width是浏览器渲染的canvas的尺寸

第一个问题:画布的高度和宽度

画布的宽和高一定要在canvas标签中设置,如果是在css样式中设置,则不起作用,画布会按照默认尺寸width:300px,height:150px显示

//在标签中设置宽和高
<canvas id="canvas" width="324" height="622" >

除了直接在canvas标签设置,还可以在绘制的时候设置,注意画布的宽高不需要单位

canvas.width = 324;
canvas.height = 622;

第二个问题:绘制的图形被放大,图像模糊

这是由于手机的设备独立像素和物理像素不一致,设备像素比=物理像素/设备独立像素,大部分手机的设备像素比为2,这意味着100px的图像要放在200px中才可以正常显示

用devicePixelRatio可以获取到设备像素比,获取到像素比后,我们就可以控制图形的缩放比例

scale = window.devicePixelRatio;

刚刚说了,canvas.style.width是浏览器渲染的canvas的尺寸,那要想你画的图形正确且清楚的显示在画布中,你需要设置正确的style.width和style.height,如下图,注意加上单位。

canvas.style.width = canvas.width / scale + 'px';
canvas.style.height= canvas.height/ scale + 'px';

上面我们设置了画布的宽度为324,如果不设置style.width,则画的图形会被放大到2倍显示。

到此这篇关于canvas画图被放大且模糊的解决方法的文章就介绍到这了,更多相关canvas图被放大且模糊内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木! 

HTML / CSS 相关文章推荐
CSS3五个技巧给你的网站带来出色的效果
Apr 02 HTML / CSS
让IE支持CSS3的不完全兼容方案
Sep 19 HTML / CSS
CSS3的Flexbox布局的简明入门指南
Apr 08 HTML / CSS
HTML5的video标签的浏览器兼容性增强方案分享
May 19 HTML / CSS
html5+css3实现一款注册表单实例
Apr 17 HTML / CSS
html5版canvas自由拼图实例
Oct 15 HTML / CSS
5 个强大的HTML5 API 函数推荐
Nov 19 HTML / CSS
详解HTML5中download属性的应用
Aug 06 HTML / CSS
H5 meta小结(前端必看篇)
Aug 24 HTML / CSS
使用HTML5做的导航条详细步骤
Oct 19 HTML / CSS
详解CSS开发过程中的20个快速提升技巧
May 21 HTML / CSS
CSS实现切角+边框+投影+内容背景色渐变效果
Nov 01 HTML / CSS
在html页面中取得session中的值的方法
Aug 11 #HTML / CSS
canvas实现滑动验证的实现示例
Aug 11 #HTML / CSS
解决html5中的video标签ios系统中无法播放使用的问题
Aug 10 #HTML / CSS
Html5 webview元素定位工具的实现
Aug 07 #HTML / CSS
HTML5 video循环播放多个视频的方法步骤
Aug 06 #HTML / CSS
html5 video全屏播放/自动播放的实现示例
Aug 06 #HTML / CSS
HTML5 通过Vedio标签实现视频循环播放的示例代码
Aug 05 #HTML / CSS
You might like
php中邮箱地址正则表达式实现与详解
2012/04/24 PHP
PHP的几个常用数字判断函数代码
2012/04/24 PHP
PHP以及MYSQL日期比较方法
2012/11/29 PHP
PHP递归删除目录几个代码实例
2014/04/21 PHP
PHP引用返回用法示例
2016/05/28 PHP
Yii中srbac权限扩展模块工作原理与用法分析
2016/07/14 PHP
6个DIV 135或246间隔一秒轮番显示效果
2010/07/24 Javascript
10款非常有用的 Ajax 插件分享
2012/03/14 Javascript
基于jQuery选择器的整理集合
2013/04/26 Javascript
Javascript自定义事件详解
2017/01/13 Javascript
angular中实现控制器之间传递参数的方式
2017/04/24 Javascript
jQuery实现的文字逐行向上间歇滚动效果示例
2017/09/06 jQuery
详解刷新页面vuex数据不消失和不跳转页面的解决
2018/01/30 Javascript
JS实现的tab页切换效果完整示例
2018/12/18 Javascript
React学习之受控组件与数据共享实例分析
2020/01/06 Javascript
JavaScript基于用户照片姓名生成海报
2020/05/29 Javascript
手机浏览器唤起微信分享(JS)
2020/10/11 Javascript
[03:55]DOTA2完美大师赛选手传记——LFY.MONET
2017/11/18 DOTA
TensorFlow实现MLP多层感知机模型
2018/03/09 Python
tensorflow 获取模型所有参数总和数量的方法
2018/06/14 Python
python通过微信发送邮件实现电脑关机
2018/06/20 Python
替换python字典中的key值方法
2018/07/06 Python
python实现决策树分类(2)
2018/08/30 Python
Python matplotlib通过plt.scatter画空心圆标记出特定的点方法
2018/12/13 Python
详解PANDAS 数据合并与重塑(join/merge篇)
2019/07/09 Python
python使用ctypes调用扩展模块的实例方法
2020/01/28 Python
基于python求两个列表的并集.交集.差集
2020/02/10 Python
python 爬虫如何实现百度翻译
2020/11/16 Python
纽约的奢华内衣店:Journelle
2016/07/29 全球购物
Nike加拿大官网:Nike.com (CA)
2019/04/09 全球购物
个人求职简历的自我评价
2013/10/19 职场文书
二年级班级文化建设方案
2014/05/10 职场文书
幼儿园大班开学寄语(2016秋季)
2015/12/03 职场文书
python如何做代码性能分析
2021/04/26 Python
python实现MD5进行文件去重的示例代码
2021/07/09 Python
nginx结合openssl实现https的方法
2021/07/25 Servers