Canvas学习笔记02:canvas的路径扫盲,附代码案例

hello,我是贝格前端工场,最近在学习canvas,分享一些canvas的一些知识点笔记,本期分享canvas的路径知识,欢迎老铁们一同学习,欢迎关注,如有前端项目可以私信贝格。

一、什么是canvas路径

Canvas路径(Canvas Path)是指在HTML5的Canvas元素上绘制的图形的路径。路径是由一系列的线段和曲线组成的,可以用来描述和绘制复杂的图形。

Canvas路径包括两种基本的绘制命令:线段(line)和曲线(curve)。

  1. 线段:线段是由起点和终点组成的直线。绘制线段的命令是lineTo(x, y),其中(x, y)是线段的终点坐标。
  2. 曲线:曲线可以是贝塞尔曲线或弧线。绘制贝塞尔曲线的命令有quadraticCurveTo(cp1x, cp1y, x, y)和bezierCurveTo(cp1x, cp1y, cp2x, cp2y, x, y),其中(cp1x, cp1y)和(cp2x, cp2y)是控制点坐标,(x, y)是曲线的终点坐标。绘制弧线的命令是arcTo(x1, y1, x2, y2, radius),其中(x1, y1)和(x2, y2)是曲线的起点和终点,radius是曲线的半径。

通过使用这些绘制命令,可以在Canvas上创建复杂的路径,然后可以使用fill()或stroke()等命令填充或描边路径,从而实现各种形状和图形的绘制。


 


 

除了基本的绘制命令,还可以使用moveTo(x, y)命令将当前绘制位置移动到指定的坐标,closePath()命令闭合路径,arc(x, y, radius, startAngle, endAngle, anticlockwise)命令绘制弧形等。

Canvas路径提供了强大的绘制功能,可以实现各种复杂的图形和效果,如绘制线条、多边形、圆形、曲线、文字等。

二、canvas路径的用途

Canvas路径提供了丰富的绘制功能,可以实现各种复杂的图形和效果。以下是一些Canvas路径可以实现的常见功能:


 

  1. 绘制基本形状:使用Canvas路径可以绘制基本的形状,如线段、矩形、圆形、椭圆等。
  2. 绘制多边形:通过连接多个线段,可以绘制多边形,如三角形、四边形、五边形等。
  3. 绘制曲线:Canvas路径支持绘制贝塞尔曲线和弧线,可以实现平滑的曲线效果。
  4. 绘制文字:使用Canvas路径可以绘制文字,可以通过路径来控制文字的形状和布局。
  5. 绘制复杂图形:通过组合和变换路径,可以绘制复杂的图形,如复杂的几何图形、图标、图表等。
  6. 填充和描边路径:可以使用填充和描边命令来给路径添加颜色和样式,实现填充和描边效果。
  7. 裁剪路径:可以使用裁剪命令来限制绘制的范围,只在指定的路径内进行绘制,实现裁剪效果。
  8. 动画效果:通过不断更新路径的属性和重新绘制,可以实现动画效果,如移动的路径、变形的路径等。

总之,Canvas路径提供了丰富的绘制功能,可以实现各种复杂的图形和效果,可以用于制作图表、图标、游戏、动画等各种应用场景。

三、如何使用canvas路径

要使用Canvas路径,需要以下步骤:

  1. 获取Canvas元素:首先,需要获取到Canvas元素的引用,可以使用document.getElementById()或其他方法获取到Canvas元素的引用。
  2. 获取绘图上下文:通过Canvas元素的getContext()方法,可以获取到绘图上下文对象。绘图上下文对象是实际执行绘图操作的对象,可以通过该对象进行路径的绘制和其他绘图操作。
var canvas = document.getElementById("myCanvas");
var ctx = canvas.getContext("2d");
  1. 绘制路径:通过调用绘图上下文对象的路径绘制命令,可以创建和绘制路径。可以使用beginPath()方法开始一个新的路径,然后使用路径绘制命令(如lineTo()、quadraticCurveTo()、bezierCurveTo()、arcTo()等)来定义路径的形状。
ctx.beginPath();
ctx.moveTo(50, 50);
ctx.lineTo(150, 50);
ctx.lineTo(150, 150);
ctx.lineTo(50, 150);
ctx.closePath();
  1. 填充或描边路径:可以使用fill()方法来填充路径,使用stroke()方法来描边路径。填充和描边路径之前,可以通过设置绘图上下文对象的属性(如fillStyle、strokeStyle、lineWidth等)来设置填充和描边的样式。
ctx.fillStyle = "red";
ctx.fill();ctx.strokeStyle = "blue";
ctx.lineWidth = 2;
ctx.stroke();
  1. 其他路径操作:除了绘制路径之外,还可以使用其他路径操作命令来对路径进行操作。例如,可以使用moveTo()方法移动当前绘制位置,使用closePath()方法闭合路径,使用clip()方法裁剪路径等。
ctx.moveTo(100, 100);
ctx.lineTo(200, 200);
ctx.closePath();
ctx.clip();

通过以上步骤,就可以使用Canvas路径进行绘图操作。可以根据需要,组合和变换路径,实现各种复杂的图形和效果。

四、示例:一个圆沿着曲线滚动

下是一个使用Canvas路径实现圆形在一条曲线上运动的示例代码:

var canvas = document.getElementById("myCanvas");
var ctx = canvas.getContext("2d");// 定义曲线路径
ctx.beginPath();
ctx.moveTo(50, 200);
ctx.quadraticCurveTo(200, 50, 350, 200);
ctx.lineWidth = 2;
ctx.strokeStyle = "blue";
ctx.stroke();// 定义圆形的初始位置和半径
var x = 50;
var y = 200;
var radius = 10;function drawCircle() {// 清除画布ctx.clearRect(0, 0, canvas.width, canvas.height);// 绘制曲线路径ctx.beginPath();ctx.moveTo(50, 200);ctx.quadraticCurveTo(200, 50, 350, 200);ctx.lineWidth = 2;ctx.strokeStyle = "blue";ctx.stroke();// 绘制圆形ctx.beginPath();ctx.arc(x, y, radius, 0, 2 * Math.PI);ctx.fillStyle = "red";ctx.fill();// 更新圆形的位置x += 1;y = 200 + Math.sin(x / 100) * 100;// 循环绘制requestAnimationFrame(drawCircle);
}// 开始绘制
drawCircle();

在上述代码中,首先定义了一条曲线路径,使用quadraticCurveTo()方法绘制二次贝塞尔曲线。然后定义了圆形的初始位置和半径。在drawCircle()函数中,先清除画布,然后重新绘制曲线路径和圆形,再更新圆形的位置。通过不断更新圆形的位置和重新绘制,使用requestAnimationFrame()实现动画效果。最后调用drawCircle()函数开始绘制。

后记:贝格前端工场也开始研究canvas,欢迎志同道合的朋友一块学习,分享中如有不足之处欢迎指正。

往期回顾


Canvas学习笔记01:可供canvas操作对象及主要作用

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2807842.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

大模型 Advanced-RAG(高级检索增强生成):从理论到 LlamaIndex 实战!

最近关于检索增强生成进行了调查,总结了三种最近发展的范式: Naive RAG(简单RAG)Advanced RAG(高级RAG)Modular RAG(模块化RAG) 本文首先讨论这些技术,接着分享如何使…

数字电路 第二章—第二节(半导体二极管、三极管和MOS管的开关特性)

一、理想开关的开关特性 1、静态特性 (1)断开时,无论在多大范围内变化,其等效电阻,通过其中的电流。 (2)闭合时,无论流过其中的电流在多大范围内变化,其等效电阻&…

Spark大数据分析与实战笔记(第三章 Spark RDD 弹性分布式数据集-05)

文章目录 每日一句正能量第3章 Spark RDD弹性分布式数据集章节概要3.7 Spark的任务调度3.7.1 DAG的概念3.7.2 RDD在Spark中的运行流程 总结 每日一句正能量 成功的速度一定要超过父母老去的速度,努力吧。做事不必与俗同,亦不与俗异;做事不必令…

Mysql运维篇(六) 部署MHA--一主二从部署

MAH架构图 一、上传MySQL软件 1、同步MySQL软件 [rootmysql01 ~]# ls -lrt total 626112 -rw-r--r--. 1 root root 641127384 Jan 30 15:13 mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz -rw-------. 1 root root 1697 Feb 3 12:09 anaconda-ks.cfg -rw-r--r--. 1 root…

[SpringDataMongodb开发游戏服务器实战]

背景: xdb其实足够完美了,现在回想一下,觉得有点复杂,我们不应该绑定语言,最好有自己的架构思路。 七号堡垒作为成功的商业项目,告诉我:其实数据是多读少写的,有修改的时候直接改库也…

推荐一个 Obsidian 的 ChatGPT 插件

源码地址:https://github.com/nhaouari/obsidian-textgenerator-plugin Text Generator 是目前我使用过的最好的 Obsidian 中的 ChatGPT 功能插件。它旨在智能生成内容,以便轻松记笔记。它不仅可以在 Obsidian 中直接使用 ChatGPT,还提供了优…

Python staticmethod函数

Python是一种功能强大且灵活的编程语言,具有许多特性和功能,其中之一就是staticmethod函数。staticmethod函数是Python中用于定义静态方法的一种特殊装饰器。在本文中,将深入探讨staticmethod函数的用法、优势以及与其他方法类型的比较。 什…

【力扣 - 将有序数组转化为二叉搜索树】

题目描述 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 题解 前言 二叉搜索树的中序遍历是升序序列&a…

黑马JavaWeb开发跟学(一)Web前端开发HTML、CSS基础

黑马JavaWeb开发一.Web前端开发HTML、CSS基础 引子、Web开发介绍传统路线本课程全新路线本课程适用人群课程收获一、什么是web开发二、网站的工作流程三、网站的开发模式四、网站的开发技术 前端开发基础一、前端开发二、HTML & CSS2.1 HTML快速入门2.1.1 操作第一步第二步…

Arduino中安装ESP32网络抽风无法下载 暴力解决办法 python

不知道什么仙人设计的arduino连接网络部分,死活下不下来。(真的沙口,第一次看到这么抽风的下载口) 操作 给爷惹火了我踏马解析json选zip直接全部下下来 把这个大家的开发板管理地址下下来跟后面python放在同一目录下&#xff0c…

FDTD算法总结

计算电磁学(Computational Electromagnetics, CEM)是通过数值计算来研究电磁场的交叉学科。 数值求解电磁学问题的方法可以分成频域(Frequency Doamin, FD)、时域(Time Domain, TD)等两类。 频域法基于时谐微分,通过对多个采样值的傅里叶逆变换得到所需的脉冲响应…

构建高效教学平台系统:关键要素与最佳实践

随着在线教育的迅速发展,教学平台系统成为了教育行业不可或缺的一部分。本文将总结构建高效教学平台系统的关键要素,并介绍最佳实践,以帮助教育机构和企业打造具有竞争力的教学平台系统。 引言: 随着信息技术的不断进步和普及&…

神经网络系列---分类度量

文章目录 分类度量混淆矩阵(Confusion Matrix):二分类问题二分类代码多分类问题多分类宏平均法:多分类代码多分类微平均法: 准确率(Accuracy):精确率(Precision)&#xf…

K8s安全一

Kubernetes是一个开源的,用于编排云平台中多个主机上的容器化的应用,目标是让部署容器化的应用能简单并且高效的使用, 提供了应用部署,规划,更新,维护的一种机制。其核心的特点就是能够自主的管理容器来保证云平台中的…

值得推荐收藏的5款顶级免费数据恢复软件!

今天分享5个超级简单又适合电脑小白的恢复删除的文件的恢复方法! 在我们的日常生活中,偶尔会因为误删除或者清空回收站等原因导致数据丢失。对于电脑小白来说,这或许是一个非常棘手的问题。但是,不用太担心,今天我为大…

【C++那些事儿】C++入门 | 命名空间 | 缺省参数 | 引用 | 内联函数 | auto关键字 | 范围for循环 | nullptr

📷 江池俊: 个人主页 🔥个人专栏: ✅数据结构冒险记 ✅C那些事儿 🌅 有航道的人,再渺小也不会迷途。 文章目录 前言1. C关键字(C98)2. 命名空间2.1 命名空间定义2.2 命名空间使用 3. C输入&输出4. 缺…

模型上下文长度达到10000000,又一批创业者完蛋了?

没有疑问,Gemini 1.5 Pro的隆重推出被Sora抢了风头。 社交平台X上OpenAI介绍Sora的第一条动态,现在已经被浏览了超过9000万次,而关于Gemini 1.5 Pro热度最高的一条,来自谷歌首席科学家Jeff Dean,区区123万人。 或许J…

【设计模式】策略模式及函数式编程的替代

本文介绍策略模式以及使用函数式编程替代简单的策略模式。 策略模式 在策略模式(Strategy Pattern)中一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为型模式。 在策略模式定义了一系列算法或策略,并将每个算法封装在独立…

Jenkins解决Host key verification failed (2)

Jenkins解决Host key verification failed 分析原因情况 一、用OpenSSH的人都知ssh会把你每个你访问过计算机的公钥(public key)都记录在~/.ssh/known_hosts。当下次访问相同计算机时,OpenSSH会核对公钥。如果公钥不同,OpenSSH会发出警告,避免…

基于SpringBoot的航班进出港管理系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式 🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 &…