1.绘制矩形轨迹

  • 相关语法:ctx.rect(x,y,width,height),根据传入的参数(起始坐标和宽高)用来绘制一个矩形轨迹
  • 注意:ctx.rect()和ctx.lineTo()绘制的都是轨迹,需要配合stroke或者fill()才能在画布中看到效果
<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 根据原点和宽高绘制矩形轨迹
ctx.rect(50,50,100,100)
// 设置描边的颜色
ctx.strokeStyle = "red"
// 设置直线宽度
ctx.lineWidth = 10
// 开始绘制描边
ctx.stroke() // 绘制填充的矩形
// 开启新路径
ctx.beginPath()
// 根据原点和宽高绘制矩形轨迹
ctx.rect(200,50,100,100)
// 设置填充颜色
ctx.fillStyle = "blue"
// 开始填充
ctx.fill()
</script>

2.绘制矩形

  • ctx.strokeRect(x,y,width,height):绘制描边的矩形,有独立路径
  • ctx.fillRect(x,y,width,height):绘制填充的矩形,有独立路径
  • 注意:这两个方法不同于rect(),它有独立的路径,且自带绘制,无需调用stroke()和fill()
<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 先设置描边颜色
ctx.strokeStyle= "red"
// 设置直线宽度
ctx.lineWidth = 10
// 绘制描边的矩形
ctx.strokeRect(50,50,100,100) // 设置填充的颜色
ctx.fillStyle = "blue"
// 绘制填充的矩形
ctx.fillRect(200,50,100,100)
</script>

3.清除区域内容

  • 相关语法:ctx.clearRect(x,y,width,height),清除这个矩形区域的内容(橡皮擦)
  • 示例1:清除整个画布的内容 400*300
<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 先设置描边颜色
ctx.strokeStyle= "red"
// 设置直线宽度
ctx.lineWidth = 10
// 绘制描边的矩形
ctx.strokeRect(50,50,100,100) // 设置填充的颜色
ctx.fillStyle = "blue"
// 绘制填充的矩形
ctx.fillRect(200,50,100,100) // 清除整个画布的内容
ctx.clearRect(0,0,400,300)
</script>
  • 示例2:清除一部分画布的内容
<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 先设置描边颜色
ctx.strokeStyle= "red"
// 设置直线宽度
ctx.lineWidth = 10
// 绘制描边的矩形
ctx.strokeRect(50,50,100,100) // 设置填充的颜色
ctx.fillStyle = "blue"
// 绘制填充的矩形
ctx.fillRect(200,50,100,100) // 清除一部分区域的内容
ctx.clearRect(200,50,100,100)
</script>

4.绘制线性渐变的矩形

  • 由来:前面绘制的矩形填充颜色都很单一,可以使用相关API来绘制一个线性渐变的矩形
  • 相关API:createLinearGradient(x0,y0,x1,y1),addColorStop(0.5, 'green')

步骤一:创建渐变方案 ,传入起点坐标和结束坐标,来确定渐变的方向

步骤二:设置渐变方案的颜色

步骤三:将其设置成填充颜色

<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 创建线性渐变方案(传入起点坐标和结束坐标)(长度200)(水平方向)
var linearGradient = ctx.createLinearGradient(50, 0, 250, 0)
// 设置渐变的颜色
linearGradient.addColorStop(0, "red") //起始颜色
linearGradient.addColorStop(0.5, "green") //中间颜色
linearGradient.addColorStop(1, "blue") //末尾颜色
// 使用渐变色
ctx.fillStyle = linearGradient // 绘制填充的矩形(长度200)(水平方向起点一致)
ctx.fillRect(50, 50, 200, 20)
// 绘制填充的矩形(长度100)(水平方向起点一致)
ctx.fillRect(50, 100, 100, 20)
// 绘制填充的矩形(长度250)(水平方向起点一致)
ctx.fillRect(50, 150, 250, 20) // 绘制填充的矩形(长度250)(水平方向起点0)
ctx.fillRect(0, 200, 250, 20)
</script>

PS:不在渐变方案坐标以内的颜色按0%和100%时的颜色填充(建议渐变方案起点和长度要和矩形一致)

5.绘制径向渐变的矩形

  • 相关API:createRadialGradient(x0,y0,r0,x1,y1,r1),创建放射状/圆形渐变对象,x0/y0,r0为渐变开始的圆,x1/y1/r1为渐变结束的圆
<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") // 创建径向渐变方案(传入两个圆的坐标和半径)
var radialGradient = ctx.createRadialGradient(200,150,20,200,150,100)
// 设置渐变的颜色
radialGradient.addColorStop(0,"red")
radialGradient.addColorStop(1,"blue")
// 使用渐变方案作为填充色
ctx.fillStyle = radialGradient // 绘制矩形(与渐变方案大小,位置一致)
ctx.fillRect(100,50,200,200)
</script>

PS:不在渐变方案坐标以内的颜色100%时的颜色填充(建议渐变方案起点和大小要和矩形一致)

6.自定义渐变的矩形

  • 思路:无数个不同颜色的小矩形就可以组成一个渐变的矩形

以红色渐变成绿色为例:红rgb(255,0,0) 蓝rgb(0,0,255) 修改其中的数值就可以得到介于红绿之间的颜色

<script>
var canvas = document.querySelector("canvas")
var ctx = canvas.getContext("2d") //起始颜色(红)
var R0 = 255,G0 = 0,B0 = 0
//结束颜色(蓝)
var R2 = 0,G2 = 0, B2 = 255
//当前颜色
var R=R0,G=G0,B=B0 //起点坐标
var x0 = 50,y0 = 50
// 矩形宽高
var width = 300,height = 50 //当前坐标
var x=x0,y=y0
for(var x=x0;x<x0+width;x++){
//计算颜色
R = R + (R2-R0)/width
G = G + (G2-G0)/width
B = B + (B2-B0)/width //设置颜色
ctx.fillStyle = `rgb(${R},${G},${B})`
//开启路径
ctx.beginPath()
//绘制填充的小矩形
ctx.fillRect(x,y,1,height)
}
</script>

效果图:

canvas(三)绘制矩形的更多相关文章

  1. [HTML5 Canvas学习]绘制矩形

    1.使用strokeRect和fillRect方法绘制矩形 a.strokeRect是绘制一个不填充的矩形 b.fillRect是绘制一个填充的矩形 代码: <script> var ca ...

  2. Javascript高级编程学习笔记(86)—— Canvas(3)绘制矩形

    绘制矩形 矩形是唯一一种可以直接在2D上下文中绘制的形状. 与矩形有关的方法包括: fillRect() strokeRect() clearRect() 上述方法都接收四个参数: 绘制矩形的 X 坐 ...

  3. Canvas:绘制矩形

    函数 CanvasPath.rect(x, y, w, h) 参数名 类型 描述 x Number 矩形起始位置 y Number 矩形起始位置 w Number 矩形宽度 h Number 矩形高度 ...

  4. canvas快速绘制圆形、三角形、矩形、多边形

    想看前面整理的canvas常用API的同学可以点下面: canvas学习之API整理笔记(一) canvas学习之API整理笔记(二) 本系列文章涉及的所有代码都将上传至:项目代码github地址,喜 ...

  5. canvas学习总结六:绘制矩形

    在第三章中(canvas学习总结三:绘制路径-线段)我们提高Canvas绘图环境中有些属于立即绘制图形方法,有些绘图方法是基于路径的. 立即绘制图形方法仅有两个strokeRect(),fillRec ...

  6. Canvas 绘制矩形,圆形,不规则图形(线条),渐变等图像效果

    绘制矩形: getContext("2d") 对象是内建的 HTML5 对象,拥有多种绘制路径.矩形.圆形.字符以及添加图像的方法. fillStyle 方法将其染成红色,fill ...

  7. canvas 绘制 矩形 圆形

    <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head> <tit ...

  8. canvas 绘制矩形和圆形

    canvas绘制有两神方法:1).填充(fill)填充是将图形内部填满. 2).绘制边框 (stroke)绘制边框是不把图形内部填满,只是绘制图形的外框. 当我们在绘制图形的时候,首先要设定好绘制的样 ...

  9. Canvas入门(1):绘制矩形、圆、直线、曲线等基本图形

    来源:http://www.ido321.com/968.html 一.Canvas的基础知识 Canvas是HTML 5中新增的元素,专门用于绘制图形.canvas元素就相当于一块“画布”,一块无色 ...

  10. canvas 绘制矩形

    XXX(x,y,width,height)   x矩形左上角x坐标                                   y矩形左上角y坐标                       ...

随机推荐

  1. Go runtime 调度器精讲(三):main goroutine 创建

    原创文章,欢迎转载,转载请注明出处,谢谢. 0. 前言 回顾下 上一讲 的内容.主线程 m0 蓄势待发,准备干活.g0 为 m0 提供了执行环境,P 和 m0 绑定,为 m0 提供活,也就是 goro ...

  2. EF Core – Table / Entity Splitting

    参考 Docs – Advanced table mapping Table Splitting Table Splitting 指的是把一个表映射到多个 Entity,或者反过来说就是把多个 Ent ...

  3. Azure 入门系列 (第五篇 Azure Storage)

    本系列 这个系列会介绍从 0 到 1 搭建一个 Web Application 的 Server. 间中还会带上一些真实开发常用的功能. 一共 6 篇 1. Virtual Machine (VM) ...

  4. mongodb 中rs.stauts()命令参数解析

    转载请注明出处: rs.status()命令用于获取MongoDB副本集的状态信息.它提供了关于副本集中各个节点的详细信息,包括节点的健康状况.角色.选举状态等. 以下是查看一个mongo集群状态返回 ...

  5. 一些OI常用小技巧啊

    1.卡常 \[---总有人以为自己比编译器聪明 \;\;\;by\;\;bezel \] 我们可能确实没有编译器聪明,但是,为了防止CCF的老人机出现什么问题,卡一卡常还是有必要的. 如果实在被逼无奈 ...

  6. 墨天轮最受DBA欢迎的数据库技术文档-监控篇

    好久不见,<墨天轮最受欢迎的技术文档>系列文章回归啦!本期主题数据库监控篇,希望能够帮助到大家!此外,为感谢大家支持,原文文末也给大家带来了返场福利,欢迎大家进入原文参与~ 数据库监控是许 ...

  7. text-align的对齐方式

    text-align的6种取值 left:左对齐 right:右对齐 center:居中 start:如果内容方向是左至右,则等于left,反之则为right. end:如果内容方向是左至右,则等于r ...

  8. 17. ES6怎么嵌入变量

    模板字符串 具体操作: 首先 , 使用反引号包裹字符串,然后使用 ${} 嵌入变量 :

  9. kotlin更多语言结构——>类型检测与类型转换 is 与 as

    is 与 !is 操作符 我们可以在运行时通过使用 is 操作符或其否定形式 !is 来检测对象是否符合给定类型: if (obj is String) { print(obj.length) } i ...

  10. KubeSphere v4 全解析:揭秘您最关心的 12 大热点问题

    为了助力大家更顺畅地使用 KubeSphere v4,我们精心汇总了十二个开发者高频关注的热点问题,这些问题全面覆盖了功能特性.性能表现.兼容性考量.安全保障以及升级流程等关键方面.接下来,我们将为大 ...