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 3D立方体效果示例-transform也不过如此
Dec 05 HTML / CSS
css3 border-radius属性详解
Jul 05 HTML / CSS
深入CSS3 动画效果的总结详解
May 09 HTML / CSS
使用css3和jquery实现可伸缩搜索框
Feb 12 HTML / CSS
HTML5 File接口在web页面上使用文件下载
Feb 27 HTML / CSS
html5的新增的标签和废除的标签简要概述
Feb 20 HTML / CSS
html5 自定义播放器核心代码
Dec 20 HTML / CSS
HTML5 video 视频标签使用介绍
Feb 03 HTML / CSS
Canvas中设置width与height的问题浅析
Nov 01 HTML / CSS
HTML5在微信内置浏览器下右上角菜单的调整字体导致页面显示错乱的问题
Jan 19 HTML / CSS
CSS 还能这样玩?奇思妙想渐变的艺术
Apr 27 HTML / CSS
CSS link与@import的区别和用法解析
May 07 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中简单的图形处理(经典)
2015/10/26 PHP
[原创]php简单隔行变色功能实现代码
2016/07/09 PHP
php 将json格式数据转换成数组的方法
2018/08/21 PHP
HTML页面如何象ASP一样接受参数
2007/02/07 Javascript
看了就知道什么是JSON
2007/12/09 Javascript
javascript 写类方式之七
2009/07/05 Javascript
javaScript面向对象继承方法经典实现
2013/08/20 Javascript
js的.innerHTML = &quot;&quot;IE9下显示有错误的解决方法
2013/09/16 Javascript
node.js中的fs.readdirSync方法使用说明
2014/12/17 Javascript
jQuery实现自动调整字体大小的方法
2015/06/15 Javascript
JS基于VML技术实现的五角星礼花效果代码
2015/10/26 Javascript
jQuery ajax 当async为false时解决同步操作失败的问题
2016/11/18 Javascript
AngularJS实现给动态生成的元素绑定事件的方法
2016/12/14 Javascript
浅谈Vue.js应用的四种AJAX请求数据模式
2017/08/30 Javascript
详解Angular5 路由传参的3种方法
2018/04/28 Javascript
Angular 数据请求的实现方法
2018/05/07 Javascript
layer.msg()去掉默认时间,实现手动关闭的方法
2019/09/12 Javascript
JavaScript实现4位随机验证码的生成
2021/01/28 Javascript
Python continue语句用法实例
2014/03/11 Python
Python抓取淘宝下拉框关键词的方法
2015/07/08 Python
Python使用tablib生成excel文件的简单实现方法
2016/03/16 Python
python 列表降维的实例讲解
2018/06/28 Python
解决在Python编辑器pycharm中程序run正常debug错误的问题
2019/01/17 Python
Python实现简单层次聚类算法以及可视化
2019/03/18 Python
详解Python对JSON中的特殊类型进行Encoder
2019/07/15 Python
python操作excel让工作自动化
2019/08/09 Python
利用python生成照片墙的示例代码
2020/04/09 Python
Python打印不合法的文件名
2020/07/31 Python
socket.io 和canvas 实现的共享画板功能
2019/05/22 HTML / CSS
英国家电直销:Appliances Direct
2016/09/22 全球购物
2013届毕业生求职信范文
2013/11/20 职场文书
建议书怎么写
2014/03/12 职场文书
领导干部廉政承诺书
2014/03/27 职场文书
奉献爱心演讲稿
2014/09/04 职场文书
求职信:会计求职的写作技巧
2019/04/24 职场文书