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实现Win8风格的方格导航菜单效果
Apr 10 HTML / CSS
CSS去掉A标签(链接)虚线框的方法
Apr 01 HTML / CSS
利用CSS3实现圆角的outline效果的教程
Jun 05 HTML / CSS
css3翻牌翻数字的示例代码
Feb 07 HTML / CSS
CSS3 box-shadow属性实例详解
Jun 19 HTML / CSS
canvas基础之图形验证码的示例
Jan 02 HTML / CSS
HTML5 微格式和相关的属性名称
Feb 10 HTML / CSS
HTML5+css3:3D旋转木马效果相册
Jan 03 HTML / CSS
HTML5 canvas 瀑布流文字效果的示例代码
Jan 31 HTML / CSS
深入浅析HTML5中的article和section的区别
May 15 HTML / CSS
canvas学习和滤镜实现代码
Aug 22 HTML / CSS
CSS3实现的侧滑菜单
Apr 27 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
PHP4引用文件语句的对比
2006/10/09 PHP
关于php循环跳出的问题
2013/07/01 PHP
PHP采用超长(超大)数字运算防止数字以科学计数法显示的方法
2016/04/01 PHP
php中array_unshift()修改数组key注意事项分析
2016/05/16 PHP
Laravel+jQuery实现AJAX分页效果
2016/09/14 PHP
jquery提升性能最佳实践小结
2010/12/06 Javascript
使用upstart把nodejs应用封装为系统服务实例
2014/06/01 NodeJs
JavaScript生成的动态下雨背景效果实现方法
2015/02/25 Javascript
JavaScript编程中的Promise使用大全
2015/07/28 Javascript
jQuery中hover与mouseover和mouseout的区别分析
2015/12/24 Javascript
form+iframe解决跨域上传文件的方法
2016/11/18 Javascript
微信小程序开发之大转盘 仿天猫超市抽奖实例
2016/12/08 Javascript
jQuery仿IOS弹出框插件
2017/02/18 Javascript
JS设置时间无效问题的解决办法
2017/02/18 Javascript
Vuejs 用$emit与$on来进行兄弟组件之间的数据传输通信
2017/02/23 Javascript
轻松理解JavaScript之AJAX
2017/03/15 Javascript
jqueryUI tab标签页代码分享
2017/10/09 jQuery
JavaScript中严格判断NaN的方法
2018/02/16 Javascript
vue使用jsonp抓取qq音乐数据的方法
2018/06/21 Javascript
JS动态图片的实现方法完整示例
2020/01/13 Javascript
[03:27]《辉夜杯》线下训练营 导师CU和海涛指点迷津
2015/10/23 DOTA
[03:12]2016完美“圣”典风云人物:单车专访
2016/12/02 DOTA
python赋值操作方法分享
2013/03/23 Python
Python求算数平方根和约数的方法汇总
2016/03/09 Python
Python异常对代码运行性能的影响实例解析
2018/02/08 Python
TensorFlow搭建神经网络最佳实践
2018/03/09 Python
pandas数据框,统计某列数据对应的个数方法
2018/04/11 Python
Python中关键字global和nonlocal的区别详解
2018/09/03 Python
django mysql数据库及图片上传接口详解
2019/07/18 Python
Python使用Opencv实现图像特征检测与匹配的方法
2019/10/30 Python
HTML5中外部浏览器唤起微信分享
2020/01/02 HTML / CSS
迪拜领先运动补剂零售品牌中文站:Sporter商城
2019/08/20 全球购物
大学生水文观测实习自我鉴定
2013/09/29 职场文书
遗嘱格式范本
2015/08/07 职场文书
100句人生哲理语录集锦:强者征服今天,懒汉坐等明天
2019/10/18 职场文书
Python基于百度API识别并提取图片中文字
2021/06/27 Python