svg.js教程及使用手册详解(二)

上篇简要介绍了svg.js的基本信息和基本用法,这篇开始详细讲解svg.js的用法。

SVG元素

SVG元素主要包括各种形状、线条、文本、路径。

矩形——Rect

Rects有两个参数,即矩形的宽度和高度:

var rect = draw.rect(100, 100)

椭圆——Ellipse

Ellipses就像矩形一样,有两个参数,横向和纵向的直径:

var ellipse = draw.ellipse(200, 100)

圆——Circle

Circles有一个参数,即圆的直径:

var circle = draw.circle(100)

倘若画椭圆的时候,设置其两个参数相同,那么实际上画出的图形和相同直径的圆是一样的。

直线——Line

四个参数,分别是直线起点和终点的x、y坐标:

var line = draw.line(0, 0, 100, 150).stroke({ width: 1 })

折线——Polyline

由三个或三个以上的点组成折线,也可以认为是不闭合的多边形。所以其参数就是折线顶点的坐标:

var polyline = draw.polyline(‘0,0 100,50 50,100‘).fill(‘none‘).stroke({ width: 1 })

其中用空格分开的每一对坐标x1,y1表示一个顶点的坐标,所以使用以下的这种集合的方式来表示点的坐标也是可以的:

var polyline = draw.polyline([[0,0], [100,50], [50,100]]).fill(‘none‘).stroke({ width: 1 })

多边形——Polygon

polyline画出的是折线,是不闭合的多边形,Polygon则相对的画出的是闭合的多边形。其参数是闭合多边形的顶点的坐标:

var polygon = draw.polygon(‘0,0 100,50 50,100‘).fill(‘none‘).stroke({ width: 1 })

二者的区别仅仅在于,起点和终点是否连接。

路径——Path

var path = draw.path(‘M10,20L30,40‘)

实际上svg.js中Path的使用方法跟SVG的Path的使用方法是一样的。具体如下:

M = moveto(M X,Y) :将画笔移动到指定的坐标位置
L = lineto(L X,Y) :画直线到指定的坐标位置
H = horizontal lineto(H X):画水平线到指定的X坐标位置
V = vertical lineto(V Y):画垂直线到指定的Y坐标位置
C = curveto(C X1,Y1,X2,Y2,ENDX,ENDY):三次贝赛曲线
S = smooth curveto(S X2,Y2,ENDX,ENDY)
Q = quadratic Belzier curve(Q X,Y,ENDX,ENDY):二次贝赛曲线
T = smooth quadratic Belzier curveto(T ENDX,ENDY):映射
A = elliptical Arc(A RX,RY,XROTATION,FLAG1,FLAG2,X,Y):弧线
Z = closepath():关闭路径

图片——Image

当需要在SVG画布上放置图片时,可以使用以下函数:

var image = draw.image(‘/path/to/image.jpg‘, 200, 200).move(100, 100)

其中第一个参数是图片路径,后两个参数分别表示图片的宽度和高度。

文本——Text

第一种是最简单的创建文本的方式:

var text = draw.text("Lorem ipsum dolor sit amet consectetur.\nCras sodales imperdiet auctor.")

以上代码会自动创建一个文本块,并在必要时插入换行。

第二种方式相对复杂,也增加了更多控制:

var text = draw.text(function(add) {
  add.tspan(‘Lorem ipsum dolor sit amet ‘).newLine()
  add.tspan(‘consectetur‘).fill(‘#f06‘)
  add.tspan(‘.‘)
  add.tspan(‘Cras sodales imperdiet auctor.‘).newLine().dx(20)
  add.tspan(‘Nunc ultrices lectus at erat‘).newLine()
  add.tspan(‘dictum pharetra elementum ante‘).newLine()
})

要获取text文本的内容:

text.content

要修改text文本的内容:

text.text(‘Brilliant!‘)

还有如下这种使用起来更自然的方式:

text.font({
  family:   ‘Helvetica‘
, size:     144
, anchor:   ‘middle‘
, leading:  ‘1.5em‘
})

文本路径——TextPath

var text = draw.text(function(add) {
  add.tspan(‘We go ‘)
  add.tspan(‘up‘).fill(‘#f09‘).dy(-40)
  add.tspan(‘, then we go down, then up again‘).dy(40)
})
text.path(‘M 100 200 C 200 100 300 0 400 100 C 500 200 600 300 700 200 C 800 100 900 100 900 100‘).font({ size: 42.5, family: ‘Verdana‘ })

以上代码在执行时,将沿着给定的路径绘制文本。

继承——Use

var rect = draw.rect(100, 100).fill(‘#f09‘)
var use  = draw.use(rect).move(200, 200)

如上代码所示,在SVG画布上将会出现两个rect,原始的rect和use的实例,任何在原始rect上所做的修改都将会在use的实例上显现。

如果我不想让原始的rect出现怎么办呢?

var rect = draw.defs().rect(100, 100).fill(‘#f09‘)
var use  = draw.use(rect).move(200, 200)

如上,可以使用defs()方法,由此也拓展出一个更易于重用的SVG组件。可以将原始的rect当作一个库元素,可以通过use方法来进行重用而不会修改原始元素。

下一篇将持续更新svg.js中引用元素的方法,也即控制画布上的元素进行动画操作的方法,敬请期待!

时间: 2024-10-03 23:08:48

svg.js教程及使用手册详解(二)的相关文章

svg.js教程及使用手册详解(一)

做毕设的时候,因为要使用到画图和自定义动画,所以接触到了SVG.网上关于SVG和Canvas的对比很多,具体的辨析这里就不赘言.网上关于SVG的所谓教程基本上都是SVG本身,但是却没有一个针对svg.js这样的集成的SVG库进行具体讲解的教程,做这件事的,本文应该是第一篇,也是给那些需要动态的使用SVG的兄弟们一点帮助. 简介: SVG.js是一个轻量级的JavaScript库,允许你轻松操作SVG和定义动画.  SVG(Scalable Vector Graphics,可缩放矢量图形)是基于X

js的offsetParent属性用法详解

js的offsetParent属性用法详解:此属性是javascript中较为常用的属性,对于它的良好掌握也是非常有必要的,下面就通过代码实例介绍一下它的用法,希望能够给需要的朋友带来一定的帮助.一.基本介绍:此属性可以返回距离指定元素最近的采用定位(position属性值为fixed.relative或者absolute)父级元素,如果父级元素中没有采用定位的元素,则返回body对象的引用.语法结构: obj.offsetParent 二.代码实例: <!DOCTYPE html> <

Nmap扫描教程之基础扫描详解

Nmap扫描教程之基础扫描详解 Nmap扫描基础扫描 当用户对Nmap工具了解后,即可使用该工具实施扫描.通过上一章的介绍,用户可知Nmap工具可以分别对主机.端口.版本.操作系统等实施扫描.但是,在实施这些扫描工作之前,需要先简单了解下Nmap工具的使用,以方便后面实施扫描.所以,本章将通过使用Nmap工具实施基础的扫描,来帮助用户了解该工具. Nmap扫描扫描概述 在实施基本的扫描之前,需要先了解一些Nmap网络扫描的基本知识,及需要考虑的一些法律边界问题.本节将对网络基本扫描进行一个简单介

js对象浅拷贝和深拷贝详解

js对象浅拷贝和深拷贝详解 作者:i10630226 字体:[增加 减小] 类型:转载 时间:2016-09-05我要评论 这篇文章主要为大家详细介绍了JavaScript对象的浅拷贝和深拷贝代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文为大家分享了JavaScript对象的浅拷贝和深拷贝代码,供大家参考,具体内容如下 1.浅拷贝 拷贝就是把父对像的属性,全部拷贝给子对象. 下面这个函数,就是在做拷贝: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 var

js 中中括号,大括号使用详解

一.{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数.如:var LangShen = {"Name":"Langshen","AGE":"28"};上面声明了一个名为"LangShen"的对象,多个属性或函数用,(逗号)隔开,因为是对象的属性,所以访问时,应该用.(点)来层层访问:LangShen.Name.LangShen.AGE,当然我们也可以用数组的方式来访问,如:Lang

[CSS3教程]相对单位rem详解

作者:zhanhailiang 日期:2015-01-28 定义 CSS3新增了一个相对单位rem,其官方定义如下: font size of the root element rem,em,px单位的区别 rem单位和em单位都是相对大小,px是绝对大小.其区别在 em基于当前元素的(如果没设置就是继承其父元素的)font-size,这样会出现一些组合问题: rem则是只相对于根元素的font-size,即只需要设置根元素的font-size,其它元素使用rem单位设置成相应的百分比即可: 兼

JConsole使用手册详解

一篇Sun项目主页上介绍JConsole使用的文章,前段时间性能测试的时候大概翻译了一下以便学习,今天整理一下发上来,有些地方也不知道怎么翻,就保留了原文,可能还好理解点,呵呵,水平有限,翻的不好,大家多多包涵. JConsole毕竟是JDK自带的东西,功能虽然没有一些商业软件那么强大,但是稳定性好,在大压力情况下也不会发生什么问题.而且,提供了相对全面的系统监控功能,还是值得一用的. JConsole JConsole是一个基于JMX的GUI工具,用于连接正在运行的JVM,不过此JVM需要使用

.NET源码保护控件VMProtect免费下载及使用教程脱壳等功能详解

原文来自VMProtect龙博方案网www.fanganwang.com VMProtect是一款全新的软件保护工具.与其它大部分的保护程序不同,VMProtect可修改程序的源代码.VMProtect可将被保护文件中的部分代码转化到在虚拟机(以下称作VM)上运行的程序(以下称作bytecode)中.您同样可把VM想象为具备命令系统的虚拟处理器,该命令系统与Intel 8086处理器所使用的完全不同.例如,VM没有负责比较2个操作数的命令,也没有有条件与无条件的移转等.就象您现在看到的,黑客必须

JS中的event 对象详解

JS中的event 对象详解 JS的event对象 Event属性和方法: 1. type:事件的类型,如onlick中的click: 2. srcElement/target:事件源,就是发生事件的元素: 3. button:声明被按下的鼠标键,整数,1代表左键,2代表右键,4代表中键,如果按下多个键,酒把这些值加起来,所以3就代表左右键同时按下:(firefox中 0代表左键,1代表中间键,2代表右键) 4. clientX/clientY:事件发生的时候,鼠标相对于浏览器窗口可视文档区域的