初探SVG

 SVG,可缩放矢量图形(Scalable Vector Graphics)。使用XML格式定义图像。SVG有以下优点:1)可被非常多的工具读取和修改;2)比JPEG和GIF尺寸更小,可压缩性更强;3)可在任何分辨率下被高质量地打印;4)图片质量不下降的情况下被放大;5)文本是可选的,同时也是可搜索的(和时候制作地图);6)可以与JS一起运行。

1 路径 <path>

命令

名称

参数

M

moveto 移动到

(x y)

Z

closepath 关闭路径

(none)

L

lineto 画线到

(x y)

H

horizontal lineto 水平线到

(x)

V

vertical lineto 垂直线到

(y)

A

elliptical arc 椭圆弧

(rx ry x-axis-rotation large-arc-flag sweep-flag x y)

x-axis-rotation:椭圆相对于坐标系的旋转角度。

large-arc-flag:标记绘制大弧(1)还是小弧(0)部分。

sweep-flag:标记向顺时针(1)还是逆时针(0)方向绘制。

C

curveto 三次贝塞尔曲线到

(x1 y1 x2 y2 x y)

S

smooth curveto 光滑三次贝塞尔曲线到

(x2 y2 x y)

Q

Bézier curveto 二次贝塞尔曲线到

(x1 y1 x y)

T

smooth Bézier curveto 光滑二次贝塞尔曲线到

(x y)

表 路径命令

如果指令字母是大写,例如H,则表示坐标位置是绝对位置。如果指令字母小写的,例如h,则表示坐标位置是相对位置。

1.1 贝塞尔曲线

贝塞尔曲线(Bézier curve),是应用于二维图形应用程序的数学曲线,用数学的方式定义一条曲线。由起点、终点、控制点组成。

控制点个数可以是0-n个,当为0个时称为一阶贝塞尔曲线(一条直线),1个控制点的时称为二阶贝塞尔曲线,依次类推。

1.1.1 二阶贝塞尔曲线

图 二阶贝塞尔曲线示意图

二阶贝塞尔曲线实现原理:起点为A,终点为C,控制点为B。连接AB,BC。

并在AB上取点D,BC上取点E,连接DE,取点F,使其满足条件 AD/AB = BE/BC = DF / DE = r。其中F点即为曲线点轨迹点。

图 二阶贝塞尔曲线实现原理

用JS实现二阶贝塞尔曲线实现原理:

图 二阶贝塞尔曲线绘制过程实现效果

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="author" content="黄名富"><title>二阶贝塞尔曲线实现原理</title>
</head>
<body>
<svg width="525" height="310" id="svg"><path d="M0,300 Q300 0 500 300" fill="#d3d2d2"/><line id="lineAB" stroke-width="2" stroke="black"/><line id="lineBC" stroke-width="2" stroke="black"/><svg id="pointA"><circle r="4" fill="red" cx="4" cy="4"/><text fill="red" x="15" y="14" font-size="20">A</text></svg><svg id="pointB"><circle r="4" fill="red" cx="4" cy="4"/><text fill="red" x="15" y="15" font-size="20">B</text></svg><svg id="pointC"><circle r="4" fill="red" cx="4" cy="5"/><text fill="red" x="15" y="14" font-size="20">C</text></svg><line stroke="green" stroke-width="2" id="lineDE"/><polyline stroke-width="2" stroke="red" id="pointF" fill="red"/></svg>
</body>
</html><script>function Point(x,y) {this.x = x;this.y = y;}const aPoint = new Point(0,300),bPoint = new Point(300,0),cPoint = new Point(500,300);let dPoint = new Point(0,0),ePoint = new Point(0,0),fPoint = new Point(0,0);function setPosition(r) {dPoint.x = r * bPoint.x;dPoint.y = aPoint.y * (1-r);ePoint.x = r * (cPoint.x - bPoint.x) + bPoint.x;ePoint.y = r * cPoint.y;fPoint.x = r * (ePoint.x - dPoint.x) + dPoint.x;fPoint.y = r * (ePoint.y - dPoint.y) + dPoint.y;}let r = 0;let timeoutId = null;(function initSvg() {let lineAB = document.querySelector("#lineAB");lineAB.setAttribute("x1",aPoint.x);lineAB.setAttribute("y1",aPoint.y);lineAB.setAttribute("x2",bPoint.x);lineAB.setAttribute("y2",bPoint.y);let lineBC = document.querySelector("#lineBC");lineBC.setAttribute("x1",bPoint.x);lineBC.setAttribute("y1",bPoint.y);lineBC.setAttribute("x2",cPoint.x);lineBC.setAttribute("y2",cPoint.y);let pointA = document.querySelector("#pointA")pointA.setAttribute("x",aPoint.x);pointA.setAttribute("y",aPoint.y - 5);let pointB = document.querySelector("#pointB")pointB.setAttribute("x",bPoint.x - 4);pointB.setAttribute("y",bPoint.y);let pointC = document.querySelector("#pointC")pointC.setAttribute("x",cPoint.x - 4);pointC.setAttribute("y",cPoint.y - 5);}());(function updateDraw() {let lineDE = document.querySelector("#lineDE");let pointF = document.querySelector("#pointF");setPosition(r);lineDE.setAttribute("x1",dPoint.x);lineDE.setAttribute("y1",dPoint.y);lineDE.setAttribute("x2",ePoint.x);lineDE.setAttribute("y2",ePoint.y);let point = document.querySelector("#svg").createSVGPoint();point.x = fPoint.x;point.y = fPoint.y;pointF.points.appendItem(point);r += 0.001;if (timeoutId) clearTimeout(timeoutId);if (r <= 1) {timeoutId = setTimeout(updateDraw,1);}}())</script>

1.2 路径实例

图 路径实例1

<svg width="500" height="240">
    <rect stroke="green" stroke-width="3" width="100%" height="100%" fill="transparent"/>
    <path stroke="blue" d="M0 20 L100 100 H250 V150 Z" fill="red" fill-rule="inherit"/>
    <text x="20" y="180">
        <tspan x="10" dy="0">绝对位置: 路径起始点为(0,20),</tspan>
        <tspan x="10" dy="18">然后直线到(100,100),再水平到</tspan>
        <tspan x="10" dy="18">(100,250),最后垂直到(100,150)</tspan>
    </text>
    <path stroke="black" fill="green" d="M260 20 l100 100 h100 v-100"/>
    <text x="260" y="180">
        <tspan x="260" dy="0">相对位置: 路径起始点为(260,20),</tspan>
        <tspan x="260" dy="18">然后直线到达(360,120),再水平到</tspan>
        <tspan x="260" dy="18">(460,120),最后垂直到(460,20)</tspan>
    </text>
</svg>

图 路径实例2

<svg width="500" height="300">
    <rect stroke="green" stroke-width="3" width="100%" height="100%" fill="transparent"/>
    <!--三次贝塞尔曲线-->
    <path d="M0,300 C200 100 300 0 500 300" fill="red"/>
    <!--二次贝塞尔曲线-->
    <path d="M0,300 Q300 0 500 300" fill="green"/>
    <!--光滑二次贝塞尔曲线-->
    <path d="M0,300 S300 0 500 300" fill="blue"/>
</svg>

1.3 路径与其他标签组合使用

图 path与text组合使用

<svg width="300" height="120">
    <rect width="100%" height="100%" stroke="green" stroke-width="3" fill="transparent"/>
    <defs>
        <path id="path1" d="M20,100 S100 0 300 100"/>
    </defs>
    <text>
        <textPath xlink:href="#path1">这是一个用路径控制文字显示的话</textPath>
    </text>
</svg>

2 滤镜

feBlend

将两个图像或SVG组合为单个图形

feImage

光栅化

feColorMatrix

基于矩阵对通道(RGBA)处理从而影响色值

feMerge

创建累计而上的图像feConvolveMatrix

feComponentTransfer

为每个像素点颜色的转换。

feMorphology

腐蚀或扩张输入图像

feComposite

使用Porter-Duff将两个输入图像合成一个图像

feOffset

相对图形的当前位置来移动图像

feConvolveMatrix

应用矩阵卷积滤波器

feSpecularLighting

镜面反色

feDiffuseLighting

漫反射

feTile

允许以填充输入图像的重复,平铺图案的目标矩阵。

feDisplacementMap

从使用来自图像的像素值in在空间上置换从图像

feTurbulence

烟雾效果

feFlood

生成一层连续的颜色,该颜色完全填充来该元素的过滤器基本区域

feDistantLight

远光源

feGaussianBlur

模糊效果

fePointLight

创建点光源效果

feSpotLight

聚光灯效果

表 SVG可用滤镜

用<filter>标签来定义SVG滤镜。其必须指定id属性。

图 feTurbulence效果

<svg width="300" height="100">
    <filter id="noise">
        <feTurbulence baseFrequency="0.5"/>
    </filter>
    <rect width="100%" height="100%" fill="none" filter="url(#noise)"/>
</svg>

图 多种滤镜组合实现阴影效果

<svg width="600" height="400">
    <filter id="f1" x="0" y="0" width="200%" height="200%">
        <feOffset result="offOut" in="SourceAlpha" dx="20"
                  dy="20" />
        <feGaussianBlur result="blurOut" in="offOut"
                        stdDeviation="10" />
        <feBlend in="SourceGraphic" in2="blurOut"
                 mode="normal" />
    </filter>
    <rect width="300" height="200" stroke="green" stroke-width="3" fill="yellow" filter="url(#f1)" />
</svg>

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++——基础

初学C的时候&#xff0c;有没有想过&#xff0c;为什么C支持重载&#xff0c;而C不支持重载呢&#xff1f;&#xff1f; 其实&#xff0c;一个程序运行起来都要经过四步骤 预处理编译汇编链接 预处理阶段会经过去注释&#xff0c;宏替换&#xff0c;头文件展开&#xff0c;条…

Java Web——HTTP协议

目录 1. HTTP协议概述 1.1. HTTP数据传输格式 1.2. HTTP协议特点 2. HTTP 1.0和HTTP 1.1 3. HTTP请求协议 3.1. GET方式请求协议 3.2. POST方式请求协议 3.3. GET请求和POST请求的区别 4. HTTP相应协议 4.1. 响应状态码 如果两个国家进行会晤需要遵守一定的礼节。所以…

使用ffmpeg调用电脑自带的摄像头和扬声器录制音视频

1、打开cmd&#xff0c;执行chcp 65001,修改cmd的编码格式为utf8&#xff0c;避免乱码 2、执行指令ffmpeg -list_devices true -f dshow -i dummy,查看当前window的音频和视频名称 3、打开windows系统的"打开声音设置"–“麦克风隐私设置”–"允许应用访问你…

arduino 简易智能花盆

编辑器&#xff1a;arduino IDE 主板&#xff1a;arduino uno 传感器&#xff1a; 0.96寸的OLED屏&#xff08;四脚&#xff09; 声音模块 土壤温湿度模块 DS18B20温度模块&#xff08;这里用到防水的&#xff09; 光敏电阻模块&#xff08;买成三脚的了只能显示高低&#x…

金字塔原理小节

目录 第1章 为什么要用金字塔结构 一、归类分组&#xff0c;将思想组织成金字塔 二、奇妙的数字“7” 三、归类分组搭建金字塔 四、找出逻辑关系&#xff0c;抽象概括 五、自上而下表达&#xff0c;结论先行 第1章 为什么要用金字塔结构 如果受众希望通过阅读你的文章、听…

自动计算零售数据分析指标?BI软件表示可行

随着BI技术的飞速发展&#xff0c;借助系统来计算分析指标也不是什么难事&#xff0c;即便是面对组合多变的零售数据分析指标&#xff0c;奥威BI软件也依旧可以又快又精准地完成指标计算。 BI软件可以自动计算零售数据分析指标&#xff0c;如销售额、库存量、订单量等。在计算…

超简单的Linux FTP服务搭建教程

目录 前言1、检查vsftp是否已安装2、安装vsftpd3、启动ftp服务4、测试ftp服务5、上传文件配置总结 前言 本文记录了在Kylin Linux Desktop V10(SP1)系统上搭建FTP服务的过程。FTP是File Transfer Protocol的缩写&#xff0c;译为文件传输协议&#xff0c;是用于在网络上进行文…

Postman的环境变量和全局变量

近期在复习Postman的基础知识&#xff0c;在小破站上跟着百里老师系统复习了一遍&#xff0c;也做了一些笔记&#xff0c;希望可以给大家一点点启发。 多种环境&#xff1a;开发环境、测试环境、预发布环境、生产环境&#xff0c;可以用环境变量来解决。 今天的分享就到这里&a…

【Azure 架构师学习笔记】-Azure Storage Account(5)- Data Lake layers

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Storage Account】系列。 接上文 【Azure 架构师学习笔记】-Azure Storage Account&#xff08;4&#xff09;- ADF 读取Queue Storage 前言 不管在云还是非云环境中&#xff0c; 存储是IT 系统的其中一个核心组件。在…

Python和BeautifulSoup库的魔力:解析TikTok视频页面

概述 短视频平台如TikTok已成为信息传播和电商推广的重要渠道。用户通过短视频分享生活、创作内容&#xff0c;吸引了数以亿计的观众&#xff0c;为企业和创作者提供了广阔的市场和宣传机会。然而&#xff0c;要深入了解TikTok上的视频内容以及用户互动情况&#xff0c;需要借…

Win11专业版安装Docker Desktop,并支持映射主机的gpu

一、Windows环境下安装 Docker 必须满足: 1. 64位Windows 11 Pro(专业版和企业版都可以) 2. Microsoft Hyper-V,Hyper-V是微软的虚拟机,在win11上是自带的,我们只需要启动就可以了 二、下载Docker Desktop安装包 方式一:进入官网下载 https://docs.docker.com/desktop…

学习c#的第四天

目录 C# 变量 C# 中的变量定义与初始化 接受来自用户的值 C# 中的 Lvalues 和 Rvalues 不同类型变量进行运算 静态变量 局部变量 C# 常量 整数常量 浮点常量 字符常量 字符串常量 定义常量 扩展知识 Convert.ToDouble 与 Double.Parse 的区别 静态常量和动态常…