如何设计动效图——前端SVG JavaScript库Raphaël介绍

一、Raphaël趣味介绍

1.1 Raphaël名字的缘由

Raphaël读音为 ['ræfeɪəl],译音为拉斐尔,为什么一个前端图库取名为此,查了资料拉斐尔被称为文艺复兴三杰之一,和达.芬奇、米开朗基罗齐名,他的画让神从天堂走进了人间,给当时战乱的欧洲带来了光明。因此用此人名取名实在是巧妙啊。
圣母的婚礼

1.2 Raphaël的功能

Raphaël官网传送门

该库以W3C推荐的SVG1标准和VML2语言为基础绘图,意味着每一个图形都是一个DOM对象,即<svg>元素,因此可以对其绑定js事件以及修改该元素。该库的目标是提供一个绘制矢量图的适配器,能够更好且适宜地兼容各种浏览器。

目前兼容的浏览器有:

浏览器及版本
Firefox 3.0+
Safari 3.0+
Chrome 5.0+
Opera 9.5+
Internet Explorer 6.0
1.3 霸气的Demo

下图是利用该库绘制的虎头,官网Demo链接在此,可以对此任意放大而不失真。
虎头
此外在其首页展示了28个示例,足以见识其强大。
Raphaël示例

二、Raphaël的API

我研读了Raphaël所有的接口,很直观且简单,使用人员能够快速上手。接口共计分为7个模块。各模块的功能及接口数、属性数如下。

模块功能接口数属性数
Animation创建并开始动画20
ElementSVG元素实践及操作方法546
Matrix矩阵操作,工具类100
Paper画布204
Raphael主类,根据元素创建画布并进行绘制327
Set元素集合类,增删改查60
eve事件类,事件监听、启动以及停止61

三、Raphaël的使用

3.1 SVG基本语法

图形基础的形状无非是线面体,再复杂的图形都是由这几种基本图形构成。

标签名称属性
svg图形width、height、viewbox
line直线x1、y1、x2、y2
polyline曲线points
rect矩形x、y、rx、ry
circle圆形cx、cy、r
ellipse椭圆形cx、cy、rx、ry
pology多边形points
path路径d

path标签最为强大,借助它可以绘制任意图形。

其中样式可以是stroke、stroke-width、fill、fill-rule,用style作为key,每一个也可以单独作为属性。

3.2 指南针的实现

基于Vue框架实现,传入角度即可完成展示,效果如图所示。需要源码请私信
指南针


  1. SVG:Scalable Vector Graphic,可伸缩矢量图形 ↩︎

  2. VML:The Vector Markup Language,矢量标记语言 ↩︎

Kity 是一个基于 SVG 的矢量,帮助你快速在页面上创建和使用矢量元素。 面向对象的接口风格在 Kity 里,所有形,以及交换的数据,都是以强类型的对象出现的,可以非常方便地使用和拓展它们。 丰富的形Kity 内置了的形,包括矩形、圆形、椭圆、多边形、自曲线、直线、正多边形、星形、饼、环、旋转形等等,还有最强大的 Path 工具,可以绘制任意矢量形 强大的填充能力Kity 对颜色加强了支持,不仅能随意使用 RGB 或 HSL 进行颜色的配置,还支持调色板的定义和使用。Kity 同时支持渐变和纹理的使用,可以让矢量元素更加生丰富。 完善的坐标变换能力在 Kity 中,对形进行平移、旋转、缩放等变换是非常简单的。而且,这些变换的综合结果还可以获取,用于形学的一些计算。 灵活的画支持Kity 内置了一个灵活的画引擎,你可以使用该引擎方便灵活地创建和使用画。画创建的时间线还可以进一步控制:暂停、停止、循环等。同时提供最底层的画接口,让你有完全的画能力。 必不可少的事件处理对于需要创建交互的应用来说,事件是必不可少的。Kity 允许你在形上绑定各种各样的事件,并且可以帮你精确的计算事件发生的坐标(你还可以指定坐标系)。这个是非常重要的,不是吗? 文本支持Kity 在文本的支持上下了苦工,你可以方便地定位文本和设置文本的样式。你还可以使用路径文本,让一个文本沿着指定的路径排列。 滤镜支持Kity 支持最常用的 SVG 滤镜,而且为您预留了接口,可以快速拓展。 强大的形学支持这个在形应用当中也是非常重要的。在 Kity 中,你可以轻松获取形在指定坐标系下的区域,支持区域的合并、变换操作。Kity 同时对贝塞尔曲线和路径提供了很多有用的工具,比如切割、求字段、求补间等。 开始使用 要开始使用 kity,你需要先在页面中引用 kity.min.js: // 引用本地的 kity  [removed][removed] // 使用 git 的 CDN 服务引用 [removed] [removed] 然后,你就可以在任何的元素上创建 kity 的画布: [removed]     var paper = new kity.Paper('kity_paper');     var rect = paper.put(new kity.Rect());     var text = paper.put(new kity.Text());     text.setContent('hello kity!');     text.fill('white');     text.setX(100);     text.setY(200);     rect.setBox(text.getBoundaryBox().expand(-15, -10, 15, 10));     rect.setRadius(5);     rect.fill('blue');[removed] 更详细的使用方法请参考 wiki。 标签:Kity
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追寻上飞

鼓励一下这只勤劳的小蜜蜂吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值