浅析canvas元素的html尺寸和css尺寸对元素视觉的影响


Posted in HTML / CSS onJuly 22, 2019

遇到的问题:canvas元素变形失真的原因

一个DOM元素存在三种尺寸:style尺寸,html尺寸,css尺寸。

使用canvas元素时,canvas元素默认宽高是300px * 150px。这里的默认尺寸是html尺寸。

为了更好地帮助理解,以作画为例。画板是css尺寸或者style尺寸,画布是html尺寸。

如果我们没有显示指定canvas元素的html尺寸,而在css文件中指定了它的css尺寸。结果是十分令人困惑。

例如我们在一个默认300px * 150px的画布上画了一个圆半径为50px的圆。

<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>canvas尺寸</title>
    <style>
        #canvas {
            width: 200px;
            height: 200px;
        }
    </style>
</head>
<body>
<div>
    <canvas id="canvas"></canvas>
</div>
<script>
    window.onload = function () {
        const canvas = document.getElementById("canvas");
        const ctx = canvas.getContext("2d");
        ctx.beginPath();
        ctx.strokeStyle = "#aaaaaa";
        ctx.arc(100, 100, 50, 0, 2 * Math.PI);
        ctx.stroke();
        ctx.closePath();
    };
</script>
</body>
</html>

最后显示的结果如下:

浅析canvas元素的html尺寸和css尺寸对元素视觉的影响

可以看出画布的尺寸确实是200 * 200。但是圆已经变成了椭圆,图形发生了形变。这是为什么呢?

如果移除css设定的尺寸又会怎么样呢?

浅析canvas元素的html尺寸和css尺寸对元素视觉的影响

可以看出此时图形是正常的。画布的尺寸确实是默认的300 * 150。

从对比以及想象中我们可以得出结论:

起初我们是在300 150的画布上绘制一个圆。绘制完成之后,我们又希望将画布的尺寸变成200 200,同时画布还是那块画布,不作更换。

可行的方法是将画布经行拉伸。假设画布存在弹性,那么一块画布从300 150拉伸成200 200。画布上的圆的长半轴变成原来的1.33倍,短半轴变成0.68倍。此时圆自然就是椭圆了。

结论:

在使用canvas画图的时候,为了避免不必要的麻烦,一定记得为canvas元素设定html尺寸的宽高。

总结

以上所述是小编给大家介绍的浅析canvas元素的html尺寸和css尺寸对元素视觉的影响,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

HTML / CSS 相关文章推荐
canvas之万花筒效果的简单实现(推荐)
Aug 16 HTML / CSS
CSS3 3D酷炫立方体变换动画的实现
Mar 26 HTML / CSS
基于 HTML5 WebGL 实现的垃圾分类系统
Oct 08 HTML / CSS
使用HTML5的链接预取功能(link prefetching)给网站提速
Dec 13 HTML / CSS
基于HTML5 FileSystem API的使用介绍
Apr 24 HTML / CSS
HTML5语音识别标签写法附图
Nov 18 HTML / CSS
html5实现微信打飞机游戏
Mar 27 HTML / CSS
html5表单及新增的改良元素详解
Jun 07 HTML / CSS
Canvas多边形绘制的实现方法
Aug 05 HTML / CSS
HTML5 客户端数据库简易使用:IndexedDB
Dec 19 HTML / CSS
html5手机键盘弹出收起的处理
Jan 20 HTML / CSS
html5+实现plus.io进行拍照和图片等获取
Jun 01 HTML / CSS
详解通过focusout事件解决IOS键盘收起时界面不归位的问题
Jul 18 #HTML / CSS
详解window.open被浏览器拦截的解决方案
Jul 18 #HTML / CSS
data:image data url 文件转为Blob上传后端的方法
Jul 16 #HTML / CSS
基于Html5 canvas实现裁剪图片和马赛克功能及又拍云上传图片 功能
Jul 09 #HTML / CSS
Html5移动端适配IphoneX等机型的方法
Jun 25 #HTML / CSS
微信小程序之html5 canvas绘图并保存到系统相册
Jun 20 #HTML / CSS
使用canvas一步步实现图片打码功能的方法
Jun 17 #HTML / CSS
You might like
PHP获取163、gmail、126等邮箱联系人地址【已测试2009.10.10】
2009/10/11 PHP
php将远程图片保存到本地服务器的实现代码
2015/08/03 PHP
关于laravel模板中生成URL的几种模式总结
2019/10/18 PHP
小议Function.apply()之二------利用Apply的参数数组化来提高 JavaScript程序性能
2006/11/30 Javascript
javascript css styleFloat和cssFloat
2010/03/15 Javascript
基于jquery可配置循环左右滚动例子
2011/09/09 Javascript
浅谈JavaScript中null和undefined
2015/07/09 Javascript
js实现的简单radio背景颜色选择器代码
2015/08/18 Javascript
跟我学习javascript创建对象(类)的8种方法
2015/11/20 Javascript
BootStrap3学习笔记(一)之网格系统
2016/05/20 Javascript
Bootstrap3使用typeahead插件实现自动补全功能
2016/07/07 Javascript
EasyUI中在表单提交之前进行验证
2016/07/19 Javascript
Vue2仿淘宝实现省市区三级联动
2020/04/15 Javascript
在React项目中使用Eslint代码检查工具及常见问题
2018/10/10 Javascript
js实现金山打字通小游戏
2020/07/24 Javascript
原生js 实现表单验证功能
2021/02/08 Javascript
[01:29:46]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第二局
2016/02/27 DOTA
Python中使用scapy模拟数据包实现arp攻击、dns放大攻击例子
2014/10/23 Python
基于scrapy实现的简单蜘蛛采集程序
2015/04/17 Python
简化Python的Django框架代码的一些示例
2015/04/20 Python
Python实现按特定格式对文件进行读写的方法示例
2017/11/30 Python
Django实现简单分页功能的方法详解
2017/12/05 Python
python3实现磁盘空间监控
2018/06/21 Python
解决pycharm 误删掉项目文件的处理方法
2018/10/22 Python
在Pycharm中项目解释器与环境变量的设置方法
2018/10/29 Python
Python学习笔记之迭代器和生成器用法实例详解
2019/08/08 Python
使用TensorFlow-Slim进行图像分类的实现
2019/12/31 Python
Django 返回json数据的实现示例
2020/03/05 Python
详解Python 实现 ZeroMQ 的三种基本工作模式
2020/03/24 Python
阿迪达斯丹麦官网:adidas丹麦
2016/10/01 全球购物
保卫科工作岗位职责
2014/03/01 职场文书
会计的岗位职责
2014/03/15 职场文书
实习公司领导推荐函
2014/05/21 职场文书
建筑专业毕业生求职信
2014/09/30 职场文书
2014年社区民政工作总结
2014/12/02 职场文书
mysql使用instr达到in(字符串)的效果
2022/04/03 MySQL