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 相关文章推荐
CSS实现限制字数功能当对象内文本溢出时显示省略标记
Aug 20 HTML / CSS
CSS3+js实现简单的时钟特效
Mar 18 HTML / CSS
CSS3效果:自定义“W”形运行轨迹实例
Mar 29 HTML / CSS
HTML5之SVG 2D入门2—图形绘制(基本形状)介绍及使用
Jan 30 HTML / CSS
HTML5资源预加载(Link prefetch)详细介绍(给你的网页加速)
May 07 HTML / CSS
HTML5实现WebSocket协议原理浅析
Jul 07 HTML / CSS
HTML5 Canvas中使用用路径描画圆弧
Jan 01 HTML / CSS
基于HTML5 Canvas的3D动态Chart图表的示例
Nov 02 HTML / CSS
使用canvas一步步实现图片打码功能的方法
Jun 17 HTML / CSS
HTML5 Blob 实现文件下载功能的示例代码
Nov 29 HTML / CSS
css3实现的加载动画效果
Apr 07 HTML / CSS
浅谈CSS不规则边框的生成方案
May 25 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的list()的一步操作给一组变量进行赋值的使用
2011/05/18 PHP
PHP面向对象的进阶学习(抽像类、接口、final、类常量)
2012/05/07 PHP
ThinkPHP3.1新特性之Action参数绑定
2014/06/19 PHP
php通过smtp邮件验证登陆的方法
2016/05/11 PHP
php微信公众账号开发之前五个坑(一)
2016/09/18 PHP
微信自定义分享php代码分析
2016/11/24 PHP
彻底搞懂JS无缝滚动代码
2007/01/03 Javascript
js event事件的传递与冒泡处理
2009/12/06 Javascript
解决css和js的{}与smarty定界符冲突问题的两种方法
2013/09/10 Javascript
js获取鼠标点击的位置实现思路及代码
2014/05/09 Javascript
浅谈JavaScript Math和Number对象
2015/01/26 Javascript
js实现当前输入框高亮显示的方法
2015/08/19 Javascript
AngularJS基础 ng-focus 指令简单示例
2016/08/01 Javascript
Javascript 使用ajax与C#获取文件大小实例详解
2017/01/13 Javascript
JavaScript+Html5实现按钮复制文字到剪切板功能(手机网页兼容)
2017/03/30 Javascript
BetterScroll 在移动端滚动场景的应用
2017/09/18 Javascript
详解vue.js数据传递以及数据分发slot
2018/01/20 Javascript
详解node.js的http模块实例演示
2018/07/12 Javascript
浅谈webpack4.x 入门(一篇足矣)
2018/09/05 Javascript
Element UI框架中巧用树选择器的实现
2018/12/12 Javascript
jQuery操作元素的内容和样式完整实例分析
2020/01/10 jQuery
js实现简单五子棋游戏
2020/05/28 Javascript
[01:06:30]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第二场 1月9日
2021/03/11 DOTA
python中datetime模块中strftime/strptime函数的使用
2018/07/03 Python
python批量下载网站马拉松照片的完整步骤
2018/12/05 Python
如何在Django中添加没有微秒的 DateTimeField 属性详解
2019/01/30 Python
python如何保存文本文件
2020/06/07 Python
THE OUTNET美国官网:国际设计师品牌折扣网站
2017/03/07 全球购物
俄罗斯极限运动网上商店:Board Shop №1
2020/12/18 全球购物
物业管理公司实习生自我鉴定
2013/09/19 职场文书
个人查摆问题整改措施
2014/10/04 职场文书
2014年店长工作总结
2014/11/17 职场文书
领导干部失职检讨书
2015/05/05 职场文书
生日赠语
2015/06/23 职场文书
Python中的turtle画箭头,矩形,五角星
2022/03/16 Python
如何基于python实现单目三维重建详解
2022/06/25 Python