• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

解决fillRect方法画矩形变形的问题

武飞扬头像
李默821
帮助1

一、问题发现

当我想用ctx.fillRect(0,0,100,100)在画布上画一个宽100px,高100px的正方形时,却发现画出了一个矩形,怀着困惑,我在菜鸟教程上找到了原因。

二、原因

该图片来自菜鸟教程对<canvas>元素的介绍:

学新通

为了更加方便大家的理解,我用分别三个画布画长100px,宽100px的正方形为例:

  1.  
    <!DOCTYPE html>
  2.  
    <html lang="en">
  3.  
    <head>
  4.  
    <meta charset="UTF-8">
  5.  
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6.  
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7.  
    <title>canvas</title>
  8.  
    </head>
  9.  
    <style>
  10.  
    #myCanvas1, #myCanvas2, #myCanvas3{
  11.  
    border: 1px solid black;
  12.  
    }
  13.  
    /* 用css给画布1设置宽高 */
  14.  
    #myCanvas1{
  15.  
    width: 300px;
  16.  
    height: 300px;
  17.  
    }
  18.  
    </style>
  19.  
    <body>
  20.  
    <canvas id="myCanvas1"></canvas>
  21.  
    <canvas id="myCanvas2"></canvas>
  22.  
    <canvas id="myCanvas3" width="300px" height="300px"></canvas>
  23.  
    <script>
  24.  
    // 画布1
  25.  
    var a = document.getElementById("myCanvas1");
  26.  
    var atx = a.getContext("2d");
  27.  
    atx.fillStyle = "#FF0000";
  28.  
    atx.fillRect(0,0,100,100);
  29.  
    // 画布2
  30.  
    var b = document.getElementById("myCanvas2");
  31.  
    var btx = b.getContext("2d");
  32.  
    btx.fillStyle = "#FF0000";
  33.  
    btx.fillRect(0,0,100,100);
  34.  
    // 画布3
  35.  
    var c = document.getElementById("myCanvas3");
  36.  
    var ctx = c.getContext("2d");
  37.  
    ctx.fillStyle = "#FF0000";
  38.  
    ctx.fillRect(0,0,100,100);
  39.  
    </script>
  40.  
    </body>
  41.  
    </html>
学新通

画布1是由css设置的大小,宽为300px,高为300px;

画布2未设置宽高。<canvas>默认宽300px,高150px,比例为2:1.

画布3是直接在<canvas>标签内设置宽高属性,宽为300px,高为300px;

学新通

解释:

由此我们可知在css中设置的是画布拉伸后的宽高,原始宽高未定义默认为宽300px,高150px。所以当在css中设置画布宽300px,高300px时,宽度不变,高度较原始高度拉长一倍,所以里面的矩形高度也应该拉长一倍(如图1)。在<canvas>中设置宽高属性,设置的是画布本身的宽高,所以在里面画的图像不会变形(如图2,图3)。

三、解决问题

那么如何设置画布为300px,300px,里面的矩形仍为100px,100px呢?

方法1:

直接在<canvas>中设置宽高分别为300px,300px(注意不是设置style属性,而是直接设置width,height属性),用fillRect(0,0,100,100)绘制矩形。

方法2:

知道了画布拉伸的原理,我们可用css设置宽高分别为300px,300px,(宽度不变,高度较原始高度拉长一倍),用fillRect(0,0,100,50)绘制矩形。(矩形高度100px缩减一倍,再拉长一倍仍为100px)。

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgffeba
系列文章
更多 icon
同类精品
更多 icon
继续加载