文章案例 => 传送门

clipPath-裁剪

能限制哪些地方可见,哪些地方不可见。标记指定的区域之外的所有内容都不会被显示(图像不会被绘制出来)。剪切路径是用clipPath元素定义的,属性clip-path可用来引用剪切路径。默认情况下,一个形状,其被剪切掉的区域(不可见的区域)是不响应鼠标事件的。

// 超出矩形区域将不会被绘制
<svg width="120" height="120"viewPort="0 0 120 120" version="1.1"xmlns="http://www.w3.org/2000/svg"><defs><clipPath id="myClip"><circle cx="30" cy="30" r="20"/><circle cx="100" cy="70" r="30"/></clipPath></defs><rect x="10" y="10" width="100" height="100"clip-path="url(#myClip)" fill='red' /></svg>

g-分组

g 标记就是’group’的简写,是用来分组用的,它能把多个元素放在一组里,对 g 标记实施的样式和渲染会作用到这个分组内的所有元素上。组内的所有元素都会继承 g 标记上的所有属性。用定义的分组还可以使用 use 进行复制使用。

<svg width="200" height="100" viewBox="0 0 200 100"><g fill="blue" id="myClip"><circle cx="30" cy="30" r="20"/><circle cx="100" cy="70" r="30"/></g>
</svg>

use-深度复用

use 标记的作用是能从 SVG 文档内部取出一个节点,克隆它,并把它输出到别处。跟’引用’很相似,但它是深度克隆。

<svg width="200" height="200" viewBox='0 0 60 60'><style>.classA { fill:red }</style><defs><g id="Port"><circle style="fill:inherit" r="5"/></g></defs><use x="20" y="10" xlink:href="#Port" /><use x="20" y="30" xlink:href="#Port" class="classA"/><use x="20" y="50" xlink:href="#Port" style="fill:blue"/>
</svg>

defs-模板

defs 元素用于预定义一个元素使其能够在 SVG 图像中重复使用,和 g 结合使用。

<svg width="300" height="300" viewport="0 0 300 300"><defs><g id="shape"><rect x="25" y="50" width="50" height="50" /><circle cx="25" cy="50" r="50" /><circle fill="orange" cx="25" cy="50" r="5" /></g></defs><use xlink:href="#shape" x="50" y="25" /><use xlink:href="#shape" x="200" y="25" /><use xlink:href="#shape" x="50" y="150" />
</svg>

symbol-模板

symbol 标记的作用是定义一个图像模板,它的作用相当于 g 和 defs 的结合,你可以使用 use 标记实例化它,然后在 SVG 文档中反复使用,这种用法非常的高效。symbol 本身不会输出任何图像,只有使用 use 实例化后才会显示。。

<svg viewBox="0 0 150 150" height='300'><symbol id="sym01" viewBox="0 0 150 110"><circle cx="50" cy="50" r="40" stroke-width="8" stroke="red" fill="red"/><circle cx="90" cy="60" r="40" stroke-width="8" stroke="green" fill="white"/></symbol><use xlink:href="#sym01"x="0" y="0" width="100" height="50"/><use xlink:href="#sym01"x="0" y="50" width="75" height="38"/><use xlink:href="#sym01"x="0" y="100" width="50" height="25"/>
</svg>

文本

text 元素用于定义文本

<svg width="200" height="400"><!-- y 设置为 0 是看不到的 --><text x="10" y="1" fill="red">hello world !</text><text x="10" y="25" fill="blue">hello world !</text><!-- 旋转文本 --><text x="0" y="45" fill="red"
transform="rotate(30 20,40)">hello world !</text><!-- 文本组 --><text x="10" y="105" style="fill:red;">这里有几行文字:<tspan x="10" y="125">这是第一行文字。</tspan><tspan x="10" y="145">第二行文字在这里。</tspan></text><!-- 加超链接 --><a xlink:href="http://lwpersonal.cn/other/draw/Canvas/SVG.html"
target="_blank"><text x="10" y="170" fill="orange">超链接 !</text></a><!-- 按路径渲染文本 --><defs><path id="path1" d="M10,190 a1,1 0 0,0 100,0" /></defs><text x="10" y="190" style="fill:red;"><textPath xlink:href="#path1">I love SVG I love SVG</textPath></text><!-- x 的值定义距离上一个文本的 x 的绝对距离,dx 定义相对距离 --><text x="10 30 50" dx="-10 0 20" y="280 300 280" fill="red">hello world !</text><!-- 定义每一个文本的距离 --><text x="10" y="330" letter-spacing="10" fill="red">hello world !</text><!-- 定义文本相对于 x 坐标的处理方法 --><text x="100" y="360" text-anchor="middle" fill="red">hello world !</text><text x="100" y="390" text-anchor="end" fill="red">hello world !</text>
</svg>

上一篇:SVG 详解(三)基础语法
下一篇:

SVG 详解(四)其他常用标签相关推荐

  1. 详解DNS的常用记录(上):DNS系列之二

    详解DNS的常用记录(上) 在上篇博文中,我们介绍了DNS服务器的体系结构,从中我们了解到如果我们希望注册一个域名,那么必须经过顶级域名服务器或其下级的域名服务器为我们申请的域名进行委派,把解析权委派 ...

  2. Android Studio 插件开发详解四:填坑

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/78265540 本文出自[赵彦军的博客] 系列目录 Android Gradle使用 ...

  3. mybatis 鉴别其_MyBatis之Mapper XML 文件详解(四)-JDBC 类型和嵌套查询

    MyBatis之Mapper XML 文件详解(四)-JDBC 类型和嵌套查询 白玉 IT哈哈 支持的 JDBC 类型 为了未来的参考,MyBatis 通过包含的 jdbcType 枚举型,支持下面的 ...

  4. App Widgets 详解四 RemoteViews、RemoteViewsService和RemoteViewsFactory

    导读 本篇文章将介绍"集合视图",App Widget 复杂布局的实现 App Widget 小部件系列其他文章链接 App Widgets 详解一 简单使用 App Widget ...

  5. 计算机中常用软件列表,详解win10中常用软件列表不要在任务栏显示的方法

    我们在win10系统的使用中,在win10的界面中我们经常使用软件在电脑任务栏中会在电脑中显示,那很多的小伙伴在电脑中是不想要显示的遇到这个问题我们怎么取消这个常用的软件在任务栏一直显示的情况呢,今天 ...

  6. linux 进程间通信 dbus-glib【实例】详解四(上) C库 dbus-glib 使用(附代码)(编写接口描述文件.xml,dbus-binding-tool工具生成绑定文件)(列集散集函数)

    linux 进程间通信 dbus-glib[实例]详解一(附代码)(d-feet工具使用) linux 进程间通信 dbus-glib[实例]详解二(上) 消息和消息总线(附代码) linux 进程间 ...

  7. springboot 详解 (四)redis filter

    ---------------------------------------------------------------------------------------------------- ...

  8. 数据结构--图(Graph)详解(四)

    数据结构–图(Graph)详解(四) 文章目录 数据结构--图(Graph)详解(四) 一.图中几个NB的算法 1.普里姆算法(Prim算法)求最小生成树 2.克鲁斯卡尔算法(Kruskal算法)求最 ...

  9. HTML中的camera标签,详解HTML5 使用video标签实现选择摄像头功能

    详解HTML5 使用video标签实现选择摄像头功能 1. html // jquery reference // // Open WebCam Snap Photo 2. javascript El ...

最新文章

  1. Java基础IO流(五)RandomAccessFile
  2. AWS负载均衡器的健康检查机制
  3. C#刷遍Leetcode面试题系列连载(3): No.728 - 自除数
  4. [Spring5]IOC容器_Bean管理_工厂Bean
  5. SuperMap iDesktop 9D中实现地图配准
  6. 论文学习20-End-to-end Sequence Labeling via Bi-directional LSTM-CNNs-CRF(序列标注,2016ACL
  7. 辅助排序和Mapreduce整体流程
  8. 【机器学习】机器学习用到的常用术语
  9. 罗永浩直播带货被吐槽不是全网最低价 本人亲自回应了
  10. 位于 mscorlib.dll 中_带电粒子在匀强磁场中运动问题的四种类型
  11. 路由器距离向量算法计算举例_文本去重算法:Minhash/Simhash/Klongsent
  12. socket编程(一)
  13. matlab数字图像处理实验一:图像的读取显示存储、平移镜像放大缩小及旋转
  14. 圆通问题频发背后的“罪与罚”
  15. 牛客网数据库SQL实战45—— 将titles_test表名修改为titles_2017
  16. 【摘】UI设计中对比色颜色的选取
  17. 大型仪器一般都是用计算机,问题:大型仪器一般都使用计算机进行控制,对该计算机除了在性能上能满足要求,在使用方面原则上有何要求。...
  18. python类中最大的_python类的学习笔记(一)
  19. 网络流24题之太空飞行计划问题
  20. 多线程实例之售卖车票

热门文章

  1. ADC-JESD204B接口调试记录
  2. java 核心技术Ⅱ--章五:JDBC数据库编程
  3. JVM类加载与运行时优化
  4. python 复数归一化处理
  5. photon服务器具体实例
  6. 南方数码iData数据工厂二次开发图层选择
  7. 为什么多数程序员对黑色的界面情有独钟?网友调侃:黑科技般的黑
  8. 主成分分析原理的数学证明
  9. padStart()与padEnd()
  10. 景区票务分销系统功能推荐,景区票务系统解决方案