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 相关文章推荐
HTML5如何适配 iPhone IOS 底部黑条
Mar 09 HTML / CSS
7款设计巧妙的css3飘带状3D立体效果的导航菜单和表单窗口
Feb 04 HTML / CSS
任意一块网页内容实现“活”的背景(目前火狐浏览器专有)
May 07 HTML / CSS
利用CSS3实现平移动画效果示例代码
Oct 12 HTML / CSS
CSS3 :not()选择器实现最后一行li去除某种css样式
Oct 19 HTML / CSS
CSS3 中filter(滤镜)属性使用详解
Apr 07 HTML / CSS
HTML5 微格式和相关的属性名称
Feb 10 HTML / CSS
HTML5+CSS3应用详解
Feb 24 HTML / CSS
HTML5学习笔记之History API
Feb 26 HTML / CSS
用HTML5制作数字时钟的教程
May 11 HTML / CSS
HTML5标签大全
Nov 23 HTML / CSS
HTML5 移动页面自适应手机屏幕四类方法总结
Aug 17 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
人尽可用的Windows技巧小贴士之下篇
2007/03/22 PHP
详解在PHP的Yii框架中使用行为Behaviors的方法
2016/03/18 PHP
PHP递归遍历文件夹去除注释并压缩php源代码的方法示例
2018/05/23 PHP
js版本A*寻路算法
2006/12/22 Javascript
Javascript miscellanea -display data real time, using window.status
2007/01/09 Javascript
JavaScript 监听textarea中按键事件
2009/10/08 Javascript
JavaScript中的apply()方法和call()方法使用介绍
2012/07/25 Javascript
JS实现的一个简单的Autocomplete自动完成例子
2014/04/16 Javascript
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
AngularJS中如何使用$http对MongoLab数据表进行增删改查
2016/01/23 Javascript
jquery ajax双击div可直接修改div中的内容
2016/03/04 Javascript
基于jQuery实现动态搜索显示功能
2016/05/05 Javascript
一个简单不报错的summernote 图片上传案例
2016/07/11 Javascript
javascript实现的上下无缝滚动效果
2016/09/19 Javascript
jQuery Ajax传值到Servlet出现乱码问题的解决方法
2016/10/09 Javascript
JavaScript中的ajax功能的概念和示例详解
2016/10/17 Javascript
jQuery插件form-validation-engine正则表达式操作示例
2017/02/09 Javascript
Vue.js鼠标悬浮更换图片功能
2017/05/17 Javascript
如何让你的JS代码更好看易读
2017/12/01 Javascript
python选择排序算法的实现代码
2013/11/21 Python
Python中判断子串存在的性能比较及分析总结
2019/06/23 Python
python从ftp获取文件并下载到本地
2020/12/05 Python
10个顶级Python实用库推荐
2021/03/04 Python
澳大利亚天然护肤品、化妆品和健康产品一站式商店:Nourished Life
2018/12/02 全球购物
优秀少先队大队辅导员事迹材料
2014/05/04 职场文书
产品设计开发计划书
2014/05/07 职场文书
经典禁毒标语
2014/06/16 职场文书
2014小学教师年度考核工作总结
2014/12/03 职场文书
考博导师推荐信范文
2015/03/27 职场文书
五星级酒店宣传口号
2015/12/25 职场文书
银行客户经理培训心得体会
2016/01/09 职场文书
2016年感恩节活动总结大全
2016/04/01 职场文书
python 下划线的多种应用场景总结
2021/05/12 Python
实体类或对象序列化时,忽略为空属性的操作
2021/06/30 Java/Android
nginx请求限制配置方法
2021/07/09 Servers
windows server2008 开启端口的实现方法
2022/06/25 Servers