酷游SVG-地址路径

news2024/11/15 14:04:15

说到SVG中最复杂的东西,路径(Path)绝对是一个大魔王,它有太多的commands可以用来定义路径。【娜娜提供酷游地kw9㍠neт地址】透过Path虽然可以绘制效果不错的SVG图形,但是要自己定义一个个坐标点,再去把它们完美的串连在一起,实在是件非常困难的事。

W3Schools的SVG Path教学在最后提到,因为Path太复杂的关系,建议使用SVG Editor做图形的设计,而非自己动手刻SVG的Path。尽管如此,稍微了解如何使用Path也能帮助看懂SVG图形背后的逻辑与规则。

SVG: 路径

指令意义(英)意义(中)
搬去移动路径初始点
大号线托从当前点连线到另一点
H横线从当前点水平连线到相同y坐标的一点
垂直线从当前点垂直连线到相同x坐标的一点
C曲线图从当前点画贝兹曲线到指定点(画最基础的贝兹曲线)
小号平滑曲线从当前点画贝兹曲线到指定点(与C同时使用,用处是镜射前一个控制点)
二次贝塞尔曲线从当前点画二次贝兹曲线到指定点(共用控制点)
光滑的二次贝塞尔曲线

从当前点画二次贝兹曲线到指定点 (与Q同时使用,用处是镜射前一个共用控制点)

A椭圆弧画椭圆圆弧
关闭路径关闭路径
  1. 要绘制贝兹曲线需要使用到"控制点"这个东西,至于控制点又是什么呢? 简单来说,可以把控制点视为控制曲线弯曲程度的点。
  2. SVG Path的Commands有大小写之分,大写代表绝对位置(absolutely positioned),小写则是相对位置(relatively positioned)。以M 100 0 L 100 150M 100 0 l 0 150为例,两者都是从(100,0)连线到(100,150),相对位置与绝对位置不同,它是以前一点做为出发位置并相对移动多少,可以想成在x、y上做加法计算。

范例1 - 基础线

  • M(移动)

    • 有2个可以带入的参数x、y
    • 移动起始点的座标
  • L(线托)

    • 有2个可以带入的参数x、y
    • 从上一点连线到当前这一点
  • Z(闭合路径)

    • 没有参数
    • 关闭路径,没关闭路径的话,描边(Stroke)会有破洞

有关闭路径:

移动初始点到(50,50),然后连线到(200,200),再连线到(50,200),最后关闭路径。

 

<svg width="500" height="500">
    <path d="M 50 50 L 200 200 L 50 200 Z" stroke="pink" stroke-width="4" ></path>
</svg>

没关闭路径:

移动初始点到(50,50),然后连线到(200,200),再连线到(50,200),最后不关闭路径。

<svg width="500" height="500">
    <path d="M 50 50 L 200 200 L 50 200" stroke="pink" stroke-width="4" ></path>
</svg>

 

范例2 - 水平线、铅直线

  • H
    • 有1个可带入参数x
    • 从上一点水平连线到当前的x坐标
    • 有1个可带入参数y
    • 从上一点垂直连线到当前的y坐标

蓝色水平线,移动初始点到(50,50),然后水平连线到(200,50)。
红色铅直线,移动初始点到(100,60),然后垂直连线到(100,200)。

 

<svg width="500" height="500">
    <path d="M 50 50 H 200" stroke="blue" stroke-width="4" ></path>
    <path d="M 100 60 V 200" stroke="red" stroke-width="4" ></path>
</svg>

范例3 - 曲线、平滑曲线(C、S不共用控制点)

  • C

    • 有6个可以带入的参数x1、y1、x2、y2、x、y
    • x1、y1是贝兹曲线的第一个控制点
    • x2、y2是贝兹曲线的第二个控制点
    • x、y是曲线的终点

  • (图片取自SVG 研究之路(4) - Path 基础篇)

要画出曲线,我们会需要透过控制点帮忙把曲线的弯曲弧度"拉"出来,上图有2个控制点分别是(40,40)和(60,40),曲线始于(0,0)在(100,0)结束。

 

<svg width="500" height="500">
    <path d="M 0 0 C 40 40 60 40 100 0" stroke="blue" fill="transparent"></path>
</svg>
  • 小号

    • 通常与C同时做使用
    • 有4个可以带入的参数x2、y2、x、y
    • x1、y1是镜射前一个控制点(以相同斜率产生,不必带入参数)
    • x2、y2是贝兹曲线的第二个控制点
    • x、y是曲线的终点


    (图片取自SVG 研究之路(4) - Path 基础篇)

     

要画出曲线,我们会需要透过控制点帮忙把曲线的弯曲弧度"拉"出来,透过S可以只设定第二个控制点,而第一个控制点可以直接镜射C的第二个控制点。

上图使用C产生(0,0)到(100,0)的曲线,并使用S产生(100,0)到(200,0)的曲线,S那边我们只给(150,-40)这个控制点,另外的控制点则直接复制(镜射)前个控制点(60,40)的斜率产生,镜射产生的控制点为(140,-40)。

<svg width="500" height="500">
    <path d="M 0 0 C 40 40 60 40 100 0 S150 -40 200 0" 
    stroke="blue" fill="transparent"></path>
</svg>

范例4 - 二次曲线、平滑曲线(Q、T共用控制点)

    • 可以想成共用控制点的C
    • 因为共用控制点,所以只需要一个控制点
    • 有4个可以带入的参数x1、y1、x、y
    • x1、y1是贝兹曲线的第一个控制点(共用)
    • x、y是曲线的终点


    (图片取自SVG 研究之路(4) - Path 基础篇)

     

与前面画出曲线都要用到二个控制点不同,使用Q我们可以指定一个共用的控制点就得以画出曲线。上图我们将(50,50)定为共用控制点,曲线始于(0,0)在(100,0)结束。

<svg width="500" height="500">
    <path d="M 0 0 Q 50 50 100 0" stroke="blue" fill="transparent"></path>
</svg>
    • 可以想成共用控制点的S
    • 因为共用控制点,所以只需要一个控制点
    • 有2个可以带入的参数x、y
    • x1、y1是镜射前一个共用控制点(以相同斜率产生,不必带入参数)
    • x、y是曲线的终点
    <svg width="500" height="500">
        <path d="M 0 0 Q 50 50 100 0 T 200 0" 
        stroke="blue" fill="transparent"></path>
    </svg>


    (图片取自SVG 研究之路(4) - Path 基础篇)

T和S有十分相似的地方,它们都会镜射前一个控制点,可以减少自订控制点的数量。而两者间的不同之处在于,T是共用控制点,而控制点是复制(镜射)前一个共用控制点(50,50)斜率产生,镜射产生的共用控制点为(150,-50)

<svg width="500" height="500">
    <path d="M 0 0 Q 50 50 100 0 T 200 0" 
    stroke="blue" fill="transparent"></path>
</svg>

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

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

相关文章

《银行从业法律法规》第二章——金融基础知识

第二章 金融基础知识 第二节 货币政策 【 知识点1】 货币政策目标 制定和实施货币政策&#xff0c; 首先必须明确货币政策最终要达到的目的&#xff0c; 即货币政策的最终目标。中央银行通过货币政策工具操作直接引起操作目标的变动&#xff0c;操作目标的变动又通过一定的途…

libarchive 如何在Ubuntu中进行安装

简介 libarchive是一个开源的压缩和归档库。 它支持实时访问多种压缩文件格式&#xff0c;比如7z、zip、cpio、pax、rar、cab、uuencode等&#xff0c;因此应用十分广泛。 举个例子&#xff0c;我写了一段代码&#xff0c;想要解压一个压缩包&#xff0c;那我就得 fork 一个 …

python制作简单版天天酷跑,是不是你平日里摸鱼小游戏呀

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 天天酷跑是一款轻松好玩、简单时尚的跑酷类手机游戏。 那我们能不能用python模拟出这个一个游戏呢&#xff1f; 答案当然是可以的&#xff0c;今天我就给大家带来简易版的天天酷跑小游戏 开发环境&#xff1a; 版 本&a…

如何用Python写个网页爬取程序

如何用Python写个网页爬取程序 准备开发工具安装PythonPython安装pipPip安装爬取插件准备好网页地址代码实现 准备开发工具 额&#xff0c;作者用的是vscode。具体怎么安装自行百度哈&#xff0c;这个都不会建议就不要学爬取了。 不忍心藏着也&#xff0c;给你个方法吧 vsc…

2023年第六届广西大学生程序设计竞赛(热身赛)题解

题目均来自去年的省赛原题 参考资料 知乎&#xff1a;第五届GXCPC广西大学生程序设计竞赛 部分题解&#xff08;无CDK&#xff09; A题送分题&#xff0c;跳过 B 位运算lowbit函数 题目大意&#xff1a; 对一个数&#xff08;二进制&#xff09;进行操作&#xff0c;询问使其…

C++11/C++14中constexpr的使用

常量表达式(const expression)是指值不会改变并且在编译过程中就能得到计算结果的表达式。字面值属于常量表达式&#xff0c;用常量表达式初始化的const对象也是常量表达式。 只要有可能使用constexpr&#xff0c;就使用它。 C11中constexpr的使用&#xff1a; constexpr是C11中…

MKS SERVO4257D 闭环步进电机_系列7 MODBUS-RTU通讯示例

第1部分 产品介绍 MKS SERVO 28D/35D/42D/57D 系列闭环步进电机是创客基地为满足市场需求而自主研发的一款产品。具备脉冲接口和RS485/CAN串行接口&#xff0c;支持MODBUS-RTU通讯协议&#xff0c;内置高效FOC矢量算法&#xff0c;采用高精度编码器&#xff0c;通过位置反馈&a…

论坛项目学习记录【预备篇2】

论坛项目学习记录【预备篇2】 1. 什么是依赖注入2. 怎么使用依赖注入依赖注入注意事项 3.组件扫描情况下依赖注入的实现4.Resource注解的使用与Autowired的区别5.SpringMvcSpringMvc执行流程 1. 什么是依赖注入 就是在Spring容器内容将各个对象的依赖关系建立好的操作&#xf…

持续集成和持续交付:构建高效的软件交付流水线

在现代软件开发中&#xff0c;持续集成&#xff08;Continuous Integration&#xff09;和持续交付&#xff08;Continuous Delivery&#xff09;已成为构建高效、可靠软件交付流水线的关键实践。通过自动化和频繁地集成代码、构建、测试和部署&#xff0c;团队能够更快地交付高…

Unity--使用Cinemachine Confiner设置摄像机边界

使用Cinemachine Confiner设置摄像机边界 前提提要&#xff1a;在做这个功能前需要&#xff1a; ​ main camera ​ 另外一个相机 思路&#xff1a;创建一个对象绑定Polygon Collider2D 边界。然后在另外一个相机Cinemachine Confiner上绑定他 ​ 绑定边界 记得点这个&#…

2023年京东618全品类预售数据查询

这一期主要分享今年618京东数码产品的预售数据&#xff0c;包括笔记本电脑、投影机、微单相机三大品类。 -笔记本电脑- 今年618&#xff0c;笔记本电脑在京东累计预售量达到73万件&#xff0c;预售额达到41亿元。预售期间&#xff0c;微单相机品类均价在5661元左右。期间&#…

软件测试实验:链接测试

目录 前言实验目的实验环境实验内容实验步骤实验过程总结 前言 本实验的目的是学习和掌握软件测试中的链接测试方法和技巧。链接测试是指对Web应用系统中的各种链接进行检查和验证&#xff0c;以确保它们能正确地指向预期的目标&#xff0c;不出现错误链接、空链接、死链接或孤…

简单尝试:ChatGLM-6B + Stable diffusion管道连接

核心思想是&#xff1a; 1. 抛去算法设计方面&#xff0c;仅从工程角度考虑的话&#xff0c;Stable diffusion的潜力挖掘几乎完全受输入文字影响。 2. BLIP2所代表的一类多模态模型走的路线是"扩展赋能LLM模型"&#xff0c;思路简单清晰&#xff0c;收益明显。LLM …

电池状态估计 | Matlab实现利用卡尔曼滤波器估计电池充电状态

文章目录 效果一览文章概述研究内容程序设计参考资料效果一览 文章概述 电池状态估计 | Matlab实现利用卡尔曼滤波器估计电池充电状态 研究内容 目前,常用的电池模型有:数

外包干了5年,女朋友嫌弃我,跑了。。。

先说一下自己的情况。大专生&#xff0c;17年通过校招进入湖南某软件公司&#xff0c;干了接近5年的测试&#xff0c;今年年上旬&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落&#xff01;而我已经在一个企业干了5年&#xff0c;…

一文带你了解MySQL之约束

在SQL标准中&#xff0c;一共规定了6种不同的约束&#xff0c;包括非空约束&#xff0c;唯一约束和检查约束等&#xff0c;而在MySQL中是不支持检查约束的&#xff0c;所以这篇文章先对其余5种约束做一个详解和练习。 文章目录 1. 约束的概念2. 约束的分类3. 非空约束4. 唯一约…

大数据:pyspark模块,spark core的RDD,RDD是弹性分布式数据抽象对象,RDD五大特性,wordcount案例展示RDD

大数据&#xff1a;pyspark模块 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;oracle&#xff0c;尤其sql…

English Learning - L3 作业打卡 Lesson4 Day29 2023.6.2 周五

English Learning - L3 作业打卡 Lesson4 Day29 2023.6.2 周五 引言&#x1f349;句1: I once made a big mistake at the office and felt foolish.成分划分弱读连读爆破语调 &#x1f349;句2: I had egg on my face.成分划分弱读语调 &#x1f349;句3: Over the weekend, m…

Java企业级信息系统开发学习笔记13 Spring Boot(使用maven方式构建Spring Boot项目)

文章目录 一、学习目标二、Spring Boot框架概述三、使用maven方式构建Spring Boot项目&#xff08;一&#xff09;创建Maven项目&#xff08;二&#xff09;添加依赖&#xff08;三&#xff09;创建入口类&#xff08;四&#xff09;创建控制器&#xff08;五&#xff09;运行入…

防火墙之服务器负载均衡

防火墙之服务器负载均衡 原理概述&#xff1a; 防火墙&#xff08;英语&#xff1a;Firewall&#xff09;技术是通过有机结合各类用于安全管理与筛选的软件和硬件设备&#xff0c;帮助计算机网络于其内、外网之间构建一道相对隔绝的保护屏障&#xff0c;以保护用户资料与信息安…