使用canvas绘制圆形,canvas绘制图形

 2023-09-20 阅读 22 评论 0

摘要:第一步:html5页面中添加canvas元素 <canvas id="myCanvas" width="300" height="300"></canvas> 1、javascript绘制图形(矩形) <script type="text/javascript"> var c=document.getElementByI

第一步:html5页面中添加canvas元素

<canvas id="myCanvas" width="300" height="300"></canvas>

1、javascript绘制图形(矩形)

<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");     //获取允许绘制图像的2D环境
cxt.fillStyle="#FF0000";        //fillStyle为绘制的图像填充颜色
cxt.fillRect(0,0,150,75);       //fillRect绘制矩形,前两个坐标为x,y轴,后面为宽高
</script>

使用canvas绘制圆形、除了可以使用fillStylefillRect,还可以使用strokeStylestrokeRectfill是填充,而stroke是轮廓,所有用strokeStyle和strokeRect是绘制的矩形轮廓,而fillStyle与fillRect绘制的是实体矩形。

 

2、绘制直线(使用 moveTo、lineTo、stroke方法)

canvas绘制图片的方法。moveTo(x,y):用于建立新的子路径,规定起始点为 (x,y)

lineTo(x,y):用于从moveTo方法规定的起始点开始绘制一条到规定坐标的直线。

stroke():用于沿着该路径绘制一条直接。

<script type="text/javascript">
window.onload = function(){var c = document.getElementById('myCanvas');var content = c.getContext('2d');content.moveTo(0,0);content.lineTo(300,300);content.stroke();
};
</script>

canvas绘图代码、3、绘制圆形(用到beginPath、arc、closePath、fill这四个方法)

beginPath():用于开始绘制路径

closePath():用于将图形闭合起来

canvas绘制圆形,arc(x,y,radius,startAngle,endAngle,anticlockwise):用于绘制圆形,x,y为坐标,radius为半径,startAngle为开始的角度,endAngle为结束的半径,anticlockwise为是否按顺时针方向绘制图形。

<script type="text/javascript">
window.onload = function(){var c = document.getElementById('myCanvas');var content = c.getContext('2d');content.fillStyle="#FA7E2A";content.beginPath();content.arc(50,50,50,0,Math.PI*2,true);content.closePath();content.fill();
};
</script>

 

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
*{padding: 0;margin:0;}
body{background: #1b1b1b;}
#div1{margin:50px auto; width:300px; height: 300px;}
canvas{background: #fff;}
</style>
<script type="text/javascript">
window.onload = function(){var c = document.getElementById('myCanvas');var content = c.getContext('2d');for(var i=0; i<=15; i++){content.fillStyle = '#FA7E2A';content.beginPath();content.arc(0,150,i*10,0,Math.PI*3/2,true);//content.closePath();
        content.stroke();}};
</script>
</head>
<body><div id="div1"><canvas id="myCanvas" width="300" height="150"></canvas></div>
</body>
</html>

 

4、绘制三角形

清除:clearRect(x,y,width,height);    x,y为坐标

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
*{padding: 0;margin:0;}
#div1{margin:50px auto; width:300px; height: 300px;}
canvas{border:1px solid #000;}
</style>
<script type="text/javascript">
window.onload = function(){var c = document.getElementById('myCanvas');var content = c.getContext('2d');content.fillStyle = '#FA7E2A';content.beginPath();content.moveTo(25,25);content.lineTo(150,25);content.lineTo(25,150);content.closePath();content.fill();document.getElementsByTagName('input')[0].onclick = function(){content.clearRect(0,0,300,300);};
};
</script>
</head>
<body><div id="div1"><canvas id="myCanvas" width="300" height="300"></canvas><input type="button" value="清除画布" /></div>
</body>
</html>

 

转载于:https://www.cnblogs.com/wxydigua/p/4204064.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/5/80216.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息