html5 canvas fillRect坐标和大小的问题解决方法
2014-07-14来源:易贤网

fillRect(100,100,100,100) 前2个100是指坐标,后2个100是指宽和高。

今天学习html5 的canvas,发现fillRect的坐标和大小一直不对,研究了半天,发现canvas的宽度和高度必须内联在canvas标签中才对。郁闷了半天。

错误的方式1:

代码如下:

<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<style>

#mycanvas{

width: 200px;

height: 200px;

background: yellow;

}

</style>

</head>

<body>

<canvas id='mycanvas' ></canvas>

<script>

var c = document.getElementById('mycanvas');

var ctx = c.getContext("2d");

ctx.fillStyle='#f36';

ctx.fillRect(100, 100, 100, 100);

</script>

</body>

</html>

错误的方式2:

代码如下:

<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<canvas id='mycanvas' style='width:200px;height:200px;background:yellow'></canvas>

<script>

var c = document.getElementById('mycanvas');

var ctx = c.getContext("2d");

ctx.fillStyle='#f36';

ctx.fillRect(100, 100, 100, 100);

</script>

</body>

</html>

显示结果:

正确的方式:

代码如下:

<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<canvas id='mycanvas' width='200px' height='200px' style='background:yellow'></canvas>

<script>

var c = document.getElementById('mycanvas');

var ctx = c.getContext("2d");

ctx.fillStyle='#f36';

ctx.fillRect(100, 100, 100, 100);

</script>

</body>

</html>

更多信息请查看IT技术专栏

2025公考·省考培训课程试听预约报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
推荐信息