canvas绘制实心三角形和空心三角形

从上几篇文章中,我们学习到了canvas可以绘制一些图形,本节课将讲一下绘制实心、空心、直角、等边等渐变的三角形。实心和空心的区别在于最后是使用fill()填充还是使用stroke()来绘制路径。

HTML代码统一使用

<canvas id=”caibaojian” width=”200″ height=”200″>https://qdkfweb.cn/canvas-triangle.html</canvas>

第一个:实心等边三角形

zuobiaosanjiaoxing

 

代码和演示地址

var bg = document.getElementById('caibaojian');
var ctx = bg.getContext('2d');
//填充三角形(等边)
ctx.beginPath();
var height = 200*Math.sin(Math.PI/3);//计算等边三角形的高
ctx.moveTo(100,0); //从A(100,0)开始
ctx.lineTo(0,height);//从A(100,0)开始,画到B (0,173)结束
ctx.lineTo(200,height); //B(0,173)-C(200,173)
//ctx.fillStyle='#00ff00';//以纯色绿色填充
var grd = ctx.createLinearGradient(0,0,200,0);//使用渐变颜色填充,从(0,0)到(200,0) (左到右)
grd.addColorStop(0,"#4CE8B2"); //起始颜色
grd.addColorStop(1,"#EFD458"); //终点颜色
ctx.fillStyle=grd; //以上面定义的渐变填充
ctx.fill(); //闭合形状并且以填充方式绘制出来

演示地址

第二个:空心的直角三角形

sanjiaoxing2

代码和演示地址

var bg = document.getElementById('caibaojian');
var ctx = bg.getContext('2d');
ctx.beginPath();
ctx.moveTo(10,10);
ctx.lineTo(10,180);
ctx.lineTo(180,180);
ctx.closePath();//闭合路径
ctx.lineWidth=10;//线的边框为10像素
//ctx.strokeStyle='#00ff00';
var grd = ctx.createLinearGradient(0,0,0,190); //从上到下
grd.addColorStop(0,"#4CE8B2"); //起始颜色
grd.addColorStop(1,"#EFD458"); //终点颜色
ctx.strokeStyle = grd;
ctx.stroke();//绘制定义的图形

演示地址


关注我

我的微信公众号:前端开发博客,在后台回复以下关键字可以获取资源。

  • 回复「小抄」,领取Vue、JavaScript 和 WebComponent 小抄 PDF
  • 回复「Vue脑图」获取 Vue 相关脑图
  • 回复「思维图」获取 JavaScript 相关思维图
  • 回复「简历」获取简历制作建议
  • 回复「简历模板」获取精选的简历模板
  • 回复「加群」进入500人前端精英群
  • 回复「电子书」下载我整理的大量前端资源,含面试、Vue实战项目、CSS和JavaScript电子书等。
  • 回复「知识点」下载高清JavaScript知识点图谱

每日分享有用的前端开发知识,加我微信:caibaojian89 交流