7. path路径绘制:使用path绘制曲线

曲线在SVG中通常是通过贝塞尔曲线命令来绘制的,包括二次贝塞尔曲线(Q)和三次贝塞尔曲线(C)。这些命令允许我们创建平滑的曲线路径。

贝塞尔曲线的原理

贝塞尔曲线的基本原理是通过控制点和锚点来定义一条曲线的形状。对于二次贝塞尔曲线,有一个起点、一个控制点和一个终点;而三次贝塞尔曲线则有两个控制点。控制点决定了曲线的弯曲程度和方向。

绘制过程
  1. 二次贝塞尔曲线(Quadratic Bézier Curve):
    • 使用Q命令,后跟一个控制点和一个终点坐标。
    • 控制点决定了从起点到终点的曲线弯曲的程度和方向。

在这里插入图片描述

  1. 三次贝塞尔曲线(Cubic Bézier Curve):
    • 使用C命令,后跟两个控制点和一个终点坐标。
    • 第一个控制点影响曲线起始部分的方向和长度,第二个控制点影响曲线结束部分的方向和长度。

在这里插入图片描述

绘制二次贝塞尔曲线(Q)

二次贝塞尔曲线由一个起点、一个控制点和一个终点定义。其命令格式如下:

<path d="M x1 y1 Q x2 y2 x3 y3" />
  • M x1 y1 表示路径的起点。
  • Q 是二次贝塞尔曲线的指令。
  • x2 y2 是控制点的坐标,它决定了曲线的弯曲程度和方向。
  • x3 y3 是曲线的终点。
二次贝塞尔曲线示例
<!-- SVG容器 -->
<svg width="200" height="200"><!-- 绘制二次贝塞尔曲线 --><path d="M 10 80Q 95 10 180 80" stroke="black" fill="transparent"/><!-- 起点 --><circle cx="10" cy="80" r="3" fill="red"/><!-- 控制点 --><circle cx="95" cy="10" r="3" fill="green"/><!-- 终点 --><circle cx="180" cy="80" r="3" fill="blue"/>
</svg>
  • M 10 80 表示移动到起点(10,80)。
  • Q 95 10 180 80 表示绘制二次贝塞尔曲线。95 10 是控制点,180 80 是终点。
  • stroke="black" 设置曲线颜色为黑色。
  • fill="transparent" 设置填充颜色为透明。
  • <circle> 元素用来标示起点、控制点和终点。
绘制三次贝塞尔曲线(C)

三次贝塞尔曲线比二次贝塞尔曲线多了一个控制点,因此提供了更高的控制精度。其命令格式如下:

<path d="M x1 y1 C x2 y2 x3 y3 x4 y4" />
  • M x1 y1 表示路径的起点。
  • C 是三次贝塞尔曲线的指令。
  • x2 y2x3 y3 是控制点的坐标,它们共同决定了曲线的形状。
  • x4 y4 是曲线的终点。
三次贝塞尔曲线示例
<!-- SVG容器 -->
<svg width="200" height="200"><!-- 绘制三次贝塞尔曲线 --><path d="M 10 150C 40 10, 150 10, 180 150" stroke="black" fill="transparent"/><!-- 起点 --><circle cx="10" cy="150" r="3" fill="red"/><!-- 第一个控制点 --><circle cx="40" cy="10" r="3" fill="green"/><!-- 第二个控制点 --><circle cx="150" cy="10" r="3" fill="green"/><!-- 终点 --><circle cx="180" cy="150" r="3" fill="blue"/>
</svg>
  • M 10 150 表示移动到起点(10,150)。
  • C 40 10, 150 10, 180 150 表示绘制三次贝塞尔曲线。40 10 和 150 10 是控制点,180 150 是终点。
  • stroke="black"fill="transparent" 的设置与二次贝塞尔曲线相同。
  • <circle> 元素同样用来标示起点、控制点和终点。

以上代码中,红色的圆点表示起点,绿色的圆点表示控制点,蓝色的圆点表示终点。通过调整控制点的位置,可以改变曲线的形状

示例:绘制一个心形

下面是一个使用三次贝塞尔曲线绘制心形的示例:

<svg width="100" height="100"><path d="M 10 30C 10 10, 30 10, 30 30C 30 50, 10 50, 10 30Z" fill="red"/>
</svg>

在这个例子中,我们使用了两个C命令来绘制心形的上半部分,然后用Z命令闭合路径。

通过调整控制点的位置,你可以改变曲线的形状。实践中,你可能需要多次尝试来找到合适的控制点位置,以便绘制出理想的曲线形状。

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

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

相关文章

Shell循环语句之while

一.while语句 重复测试某个条件&#xff0c;只要条件成立则反复执行 whlie 条件测试操作 do 命令序列 done 示例&#xff1a; 1.计算1到100所有整数的和 2.提示用户输入一个小于100的整数&#xff0c;并计算从1到该数之间所有整数的和 3.求从1到100所有整数的偶数和、奇数和…

基于Springboot的家教管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的家教管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&…

JVM 类的使用与卸载

文章目录 1. 类的使用2. 类的卸载2.1 类、类的加载器、类的实例之间的引用关系2.2 何种情况会被卸载2.3 类卸载在实际生产中情况如何2.4 方法区的垃圾回收 上一篇文章: JVM 类的加载过程详解 介绍了类的加载过程, 这篇文章来介绍类在完成加载后的使用及其卸载. 1. 类的使用 任何…

设计模式-结构型-适配器模式-Adapter

地址类 public class Address {public void street() {System.out.println("普通的街道");}public void zip() {System.out.println("普通的邮政编码");}public void city() {System.out.println("普通的城市");} } 荷兰地址类 public class …

青蒿素优化算法(AO)-2024年新算法-公式原理详解与性能测评 Matlab代码免费获取

声明&#xff1a;文章是从本人公众号中复制而来&#xff0c;因此&#xff0c;想最新最快了解各类智能优化算法及其改进的朋友&#xff0c;可关注我的公众号&#xff1a;强盛机器学习&#xff0c;不定期会有很多免费代码分享~ 目录 原理简介 一、初始化阶段 二、综合淘汰阶…

GPT 大型语言模型可视化教程

网址&#xff1a; LLM Visualization 简介 欢迎来到 GPT 大型语言模型演练&#xff01;在这里&#xff0c;我们将探索只有 85,000 个参数的 nano-gpt 模型。 它的目标很简单&#xff1a;取一个由六个字母组成的序列&#xff1a; C B A B B C 并按字母顺序排列&#xff0c;即…

微软为美国情报机构打造定制GPT-4

近日&#xff0c;微软公司宣布成功为美国情报机构打造了一款定制化的GPT-4生成式AI模型&#xff0c;该模型与互联网完全断开连接&#xff0c;标志着大型语言模型首次在安全环境中得到应用。这项技术突破将为情报分析工作带来革命性的变革&#xff0c;同时也引发了业界对人工智能…

poll 机制

poll 机制 一、poll机制概述二、使用流程三、编程3.1 驱动编程3.1 应用编程 四、POLL 机制的内核代码详解五、编译后上机实验 poll 机制与休眠唤醒机制的区别&#xff1a; 休眠唤醒方式时&#xff0c;进程如果没有得到唤醒信号&#xff0c;需要一直休眠&#xff0c;进程就干不了…

练习队列的相关操作:循环队列

1. 思路解析 循环队列就是在只有有限的空间时使用队列实现循环存储数据&#xff0c;有双向链表和数组两种选择&#xff0c;这里我们使用数组实现循环队列&#xff08;因为链表我不会 >-<&#xff09; 2. 相关函数及其实现 2.1 判空与判满 判空&#xff1a;直接返回头尾…

---随笔--Java实现TCP通信(双端通信接收与发送)

---随笔--Java实现TCP通信&#xff08;双端通信接收与发送&#xff09; 引言1. 什么是TCP通信2. 服务器与客户端核心代码2.1 服务器ServerSocket端核心代码2.2 用户Socket端核心代码2.3 小贴士之关于try-with-resources自动关闭资源的使用 3. 具体服务器端实现4. 具体客户端实现…

ONES 功能上新 | 近期产品新功能一览

支持在 ONES Project 中通过弹窗查看、编辑 ONES Wiki 页面。 应用场景&#xff1a; 当需要在 ONES Project 中查看 ONES Wiki 的页面内容时&#xff0c;可以直接点击工作项关联的 ONES Wiki 页面或项目文档组件中的页面&#xff0c;即可在 ONES Project 中通过弹窗查看 ONES W…

计算机毕业设计python+spark知识图谱音乐推荐系统 音乐数据分析可视化大屏 音乐爬虫 LSTM情感分析 大数据毕设 深度学习 机器学习

本科毕业设计&#xff08;论文&#xff09;开题报告 课题名称 基于Spark的音乐推荐与数据分析系统 的设计与实现 课题类型 系统设计 学院 大数据与人工智能学院 班级 专业 数据科学与大数据技术 指导教师 职称 学生姓名 学号 重庆工程学院教务处制 1.课…

机器学习中的精确度、召回率、F1分数

精确度与召回率 上图左边为混淆矩阵&#xff0c;四个区域分别为&#xff1a;真阳性&#xff08;True positive&#xff09;&#xff0c;真阴性&#xff08;True negative&#xff09;&#xff0c;假阳性&#xff08;False positive&#xff09;&#xff0c;假阴性&#xff08;F…

华为学习之旅,创建应用全流程

快速入门 开发准备 对于HarmonyOS应用开发的初学者。通过构建一个简单的具有页面跳转/返回功能的应用(如下) &#xff0c;快速了解工程目录的主要文件&#xff0c;熟悉HarmonyOS应用开发流程。 基本概念 UI框架 HarmonyOS提供了一套UI开发框架&#xff0c;即方舟开发框架&am…

【python量化交易】qteasy使用教程07——创建更加复杂的自定义交易策略

创建更加复杂的自定义交易策略 使用交易策略类&#xff0c;创建更复杂的自定义策略开始前的准备工作本节的目标继承Strategy类&#xff0c;创建一个复杂的多因子选股策略策略和回测参数配置&#xff0c;并开始回测 本节回顾 使用交易策略类&#xff0c;创建更复杂的自定义策略 …

JCR一区 | Matlab实现1D-2D-GASF-CNN-BiLSTM-MATT的多通道输入数据分类预测

JCR一区 | Matlab实现1D-2D-GASF-CNN-BiLSTM-MATT的多通道输入数据分类预测 目录 JCR一区 | Matlab实现1D-2D-GASF-CNN-BiLSTM-MATT的多通道输入数据分类预测分类效果基本介绍程序设计参考资料 分类效果 基本介绍 Matlab实现1D-2D-GASF-CNN-BiLSTM-MATT的多通道输入数据分类预…

Maven 自动化构建

优质博文&#xff1a;IT-BLOG-CN 一、Maven&#xff1a;是一款服务于 Java平台的自动化构建工具 【1】Maven可以将一个项目按模块划分成不同的工程&#xff0c;利于分工协作; 【2】Maven可以将 jar包保存在自己的中央“仓库”中进行统一管理&#xff0c;有需要使用的工程引用这…

C语言 | Leetcode C语言题解之第85题最大矩形

题目&#xff1a; 题解&#xff1a; int maximalRectangle(char** matrix, int matrixSize, int* matrixColSize) {int m matrixSize;if (m 0) {return 0;}int n matrixColSize[0];int left[m][n];memset(left, 0, sizeof(left));for (int i 0; i < m; i) {for (int j …

重学JavaScript高阶知识点(三)—— 详解Js中的内存管理

详解Js中的内存管理 1. 简介2. 内存生命周期3. JavaScript 的内存分配4. 垃圾回收 1. 简介 很多底层语言一般都有底层的内存管理接口&#xff0c;比如 C语言&#xff0c;可以调用对应的API去创建和释放内存空间。意思是需要手动去创建和释放内存空间&#xff0c;很明显&#x…

mapreduce | 自定义Partition分区(案例2)

1.需求 统计每个手机号消费总金额&#xff0c;按照消费金额降序排序&#xff0c;最终联通、电信、移动分别写入不同的文件。 130、131、132&#xff08;联通&#xff09; 133&#xff08;电信&#xff09; 135、136、137、138、139 &#xff08;移动&#xff09; 手机号,消费记…