浅析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 相关文章推荐
纯css3实现的动画按钮的实例教程
Nov 17 HTML / CSS
css3实例教程 一款纯css3实现的发光屏幕旋转特效
Dec 07 HTML / CSS
css3 transform及原生js实现鼠标拖动3D立方体旋转
Jun 20 HTML / CSS
canvas三角函数模拟水波效果的示例代码
Jul 03 HTML / CSS
HTML5 Canvas实现平移/放缩/旋转deom示例(附截图)
Jul 04 HTML / CSS
HTML5 embed 标签使用方法介绍
Aug 13 HTML / CSS
深入剖析HTML5 内联框架iFrame
May 04 HTML / CSS
如何用canvas实现在线签名的示例代码
Jul 10 HTML / CSS
使用html5实现表格实现标题合并的实例代码
May 13 HTML / CSS
解决html5中的video标签ios系统中无法播放使用的问题
Aug 10 HTML / CSS
HTML5基础学习之文本标签控制
Mar 25 HTML / CSS
HTML中link标签属性的具体用法
May 07 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操作Memcache实例介绍
2013/06/14 PHP
解析smarty模板中类似for的功能实现
2013/06/18 PHP
php curl基本操作详解
2013/07/23 PHP
php+xml实现在线英文词典之添加词条的方法
2015/01/23 PHP
JavaScript脚本性能优化注意事项
2008/11/18 Javascript
基于jquery的模态div层弹出效果
2010/08/21 Javascript
JS 表单验证大全
2011/11/23 Javascript
模拟jQuery中的ready方法及实现按需加载css,js实例代码
2013/09/27 Javascript
探讨jQuery的ajax使用场景(c#)
2013/12/03 Javascript
给html超链接设置事件不使用href来完成跳
2014/04/20 Javascript
值得分享的JavaScript实现图片轮播组件
2016/11/21 Javascript
ajax与json 获取数据并在前台使用简单实例
2017/01/19 Javascript
微信JS SDK接入的几点注意事项(必看篇)
2017/06/23 Javascript
JavaScript模块详解
2017/12/18 Javascript
NodeJS实现自定义流的方法
2018/08/01 NodeJs
通过vue-cli3构建一个SSR应用程序的方法
2018/09/13 Javascript
对node通过fs模块判断文件是否是文件夹的实例讲解
2019/06/10 Javascript
JavaScript中继承原理与用法实例入门
2020/05/09 Javascript
Python作用域用法实例详解
2016/03/15 Python
Python使用PyCrypto实现AES加密功能示例
2017/05/22 Python
python+pandas分析nginx日志的实例
2018/04/28 Python
解决DataFrame排序sort的问题
2018/06/07 Python
python引入不同文件夹下的自定义模块方法
2018/10/27 Python
python在OpenCV里实现投影变换效果
2019/08/30 Python
python安装scipy的步骤解析
2019/09/28 Python
python编程进阶之类和对象用法实例分析
2020/02/21 Python
python+requests接口压力测试500次,查看响应时间的实例
2020/04/30 Python
python opencv 实现读取、显示、写入图像的方法
2020/06/08 Python
学会迭代器设计模式,帮你大幅提升python性能
2021/01/03 Python
HTML5录音实践总结(Preact)
2020/05/07 HTML / CSS
材料加工硕士生求职信
2013/10/10 职场文书
个性发展自我评价
2014/02/11 职场文书
小学教研工作总结2015
2015/05/13 职场文书
运动会通讯稿600字
2015/07/20 职场文书
2016高三毕业赠言寄语
2015/12/04 职场文书
python中requests库+xpath+lxml简单使用
2021/04/29 Python