浅析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实现给头像加个光芒四射且旋转的背景动画效果
May 07 HTML / CSS
HTML5+CSS3实例 :canvas 模拟实现电子彩票刮刮乐代码
Dec 30 HTML / CSS
CSS3 实现弹幕的示例代码
Aug 07 HTML / CSS
利用Canvas模仿百度贴吧客户端loading小球的方法示例
Aug 13 HTML / CSS
HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题
Apr 24 HTML / CSS
使用jTopo给Html5 Canva中绘制的元素添加鼠标事件
May 15 HTML / CSS
利用HTML5的新特点实现图片文件异步上传
May 29 HTML / CSS
实例教程 HTML5 Canvas 超炫酷烟花绽放动画实现代码
Nov 05 HTML / CSS
HTML5全屏(Fullscreen)API详细介绍
Apr 24 HTML / CSS
html5组织内容_动力节点Java学院整理
Jul 10 HTML / CSS
video下autoplay属性无效的解决方法(添加muted属性)
May 19 HTML / CSS
HTML基本元素标签介绍
Feb 28 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
基于Zend的Config机制的应用分析
2013/05/02 PHP
PHP取余函数介绍MOD(x,y)与x%y
2014/05/15 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(八)
2014/06/23 PHP
解决安装WampServer时提示缺少msvcr110.dll文件的问题
2017/07/09 PHP
PHP添加文字水印或图片水印的水印类完整源代码与使用示例
2019/03/18 PHP
js玩一玩WSH吧
2007/02/23 Javascript
javascript实现的动态文字变换
2007/07/28 Javascript
获取当前网页document.url location.href区别总结
2008/05/10 Javascript
js模拟弹出效果代码修正版
2008/08/07 Javascript
Jquery Ajax学习实例3 向WebService发出请求,调用方法返回数据
2010/03/16 Javascript
javascript开发技术大全-第1章javascript概述
2011/07/03 Javascript
如何在指定的地方插入html内容和文本内容
2013/12/23 Javascript
完美实现仿QQ空间评论回复特效
2015/05/06 Javascript
javascript实现的网站访问量统计代码
2015/12/20 Javascript
详解AngularJS 模态对话框
2016/04/07 Javascript
原JS实现banner图的常用功能
2017/06/12 Javascript
5 种JavaScript编码规范
2018/01/30 Javascript
微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例
2018/12/11 Javascript
python将多个文本文件合并为一个文本的代码(便于搜索)
2011/03/13 Python
用Python的Tornado框架结合memcached页面改善博客性能
2015/04/24 Python
Python实现图像几何变换
2015/07/06 Python
Python闭包思想与用法浅析
2018/12/27 Python
python批量检查两个对应的txt文件的行数是否一致的实例代码
2020/10/31 Python
css3 利用transform打造走动的2D时钟
2020/10/20 HTML / CSS
淘宝活动策划方案
2014/02/06 职场文书
英文请假条
2014/04/11 职场文书
分公司总经理岗位职责
2014/07/30 职场文书
见习报告格式要求
2014/11/04 职场文书
2014年村党支部工作总结
2014/12/04 职场文书
事业单位考察材料范文
2014/12/25 职场文书
经理聘任证明
2015/03/02 职场文书
工作失职检讨书范文
2015/05/05 职场文书
运动会广播稿20字
2015/08/19 职场文书
幼儿园家长心得体会
2016/01/21 职场文书
详解如何用Python实现感知器算法
2021/06/18 Python
Android RecyclerView实现九宫格效果
2022/06/28 Java/Android