two.js之实现动画效果示例


Posted in Javascript onNovember 06, 2017

一、什么是two.js?

Two.js 是面向现代 Web 浏览器的一个二维绘图 API。Two.js 可以用于多个场合:SVG,Canvas 和 WebGL,旨在使平面形状和动画的创建更方便,更简洁。

Two.js 有一个内置的动画循环,可搭配其他动画库。Two.js 包含可伸缩矢量图形解释器,这意味着开发人员和设计人员都可以在商业应用中,如 Adobe Illustrator 中创建 SVG 元素,并把它引入 Two.js 使用场景中。

二、导入two.js

two.js之实现动画效果示例

三、用two.js实现动画

1)一个简单的小dome

<script type="text/javascript">
 //在整个body中绘制绘图区
 var two = new Two({
  fullscreen:true,//设置是否全屏
  autostart:true,//是否自动启动动画 
 }).appendTo(document.body);
   
 var star = two.makeStar(two.width/2,two.height/2,50,125);
 //two.update();//映射到页面上
 two.bind('update',function(frameCount){
  star.rotation +=0.03;
 })
   
</script>

two.js之实现动画效果示例

2)实现一个比较复杂一些的

<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title></title>
  <style type="text/css">
   svg{
    background-color: black;
   }
  </style>
  <script src="js/two.JS.js" type="text/javascript" charset="utf-8"></script>
 </head>
 <body>
  <!--创建div绘图区-->
  <div id="draw-shapes">
   
  </div>
  <script type="text/javascript">
   var elem = document.getElementById("draw-shapes");
   var params = {width:400,height:400};
   var two = new Two(params).appendTo(elem);
   var circle = two.makeCircle(-72,0,50);//前两个是x轴y轴,然后是圆的半径
   var star = two.makeStar(75,0,75,35,5);
//   var ss = two.makeCurve(250,30,46,50,465,48,79,36,94);
   
   circle.fill = "#ccd0d5";//填充颜色
   circle.lineWidth = 15;//边线的宽度
   circle.stroke = "#FED519";//边线的颜色
   
   star.fill = "yellow";
   star.opacity = 0.5;//设置透明度
   circle.noStroke();//去掉边线
   
   var group = two.makeGroup(circle,star);//将两个图形合并到一个组中
//   group.fill = "#ffffff";
   
   group.translation.set(two.width/2,two.height/2);
   group.rotation = Math.PI;
   group.scale = 0.1;
   
   two.update();
   
   two.bind('update',function(frameCount){
    if(group.scale>0.99999){
     //将缩放与旋转的度数变成0
     group.scale = group.rotation = 0;
    }
    var t = (1- group.scale) * 0.3;
    group.scale +=t;
    group.rotation +=t *3*Math.PI;
   }).play();
  </script>
 </body>
</html>

two.js之实现动画效果示例

其中的背景是这个函数makeCurve会改变为什么样的背景取决于所给的数是多大以及多少个

 四、two.js官网链接

https://two.js.org/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript parseInt 大改造
Sep 27 Javascript
一个JS小玩意 几个属性相加不能超过一个特定值.
Sep 29 Javascript
JavaScript/jQuery 表单美化插件小结
Feb 14 Javascript
如何创建一个JavaScript弹出DIV窗口层的效果
Sep 25 Javascript
JS(JQuery)操作Array的相关方法介绍
Feb 11 Javascript
通过点击jqgrid表格弹出需要的表格数据
Dec 02 Javascript
JQuery日历插件My97DatePicker日期范围限制
Jan 20 Javascript
【JS+CSS3】实现带预览图幻灯片效果的示例代码
Mar 17 Javascript
javascript鼠标跟随运动3种效果(眼球效果,苹果菜单,方向跟随)
Oct 27 Javascript
jQuery动态生成表格及右键菜单功能示例
Jan 13 Javascript
微信小程序实现自定义picker选择器弹窗内容
May 26 Javascript
js之ajax文件上传
May 13 Javascript
JS实现图片放大镜插件详解
Nov 06 #Javascript
js定时器实现倒计时效果
Nov 05 #Javascript
Vuejs实现购物车功能
Nov 05 #Javascript
JavaScript实现音乐自动切换和轮播
Nov 05 #Javascript
vue+node+webpack环境搭建教程
Nov 05 #Javascript
JavaScript实现三级级联特效
Nov 05 #Javascript
angular中不同的组件间传值与通信的方法
Nov 04 #Javascript
You might like
destoon网站转移服务器后搜索汉字出现乱码的解决方法
2014/06/21 PHP
PHP中OpenSSL加密问题整理
2017/12/14 PHP
php与阿里云短信接口接入操作案例分析
2020/05/27 PHP
jQuery解决iframe高度自适应代码
2009/12/20 Javascript
浅析js中2个等号与3个等号的区别
2013/08/06 Javascript
Node.js中的事件驱动编程详解
2014/08/16 Javascript
JavaScript中5种调用函数的方法
2015/03/12 Javascript
js实现汉字排序的方法
2015/07/23 Javascript
轻松实现javascript图片轮播特效
2016/01/13 Javascript
JavaScript如何获取到导航条中HTTP信息
2017/10/10 Javascript
百度地图去掉marker覆盖物或者去掉maker的label文字方法
2018/01/26 Javascript
JS实现字符串去重及数组去重的方法示例
2018/04/21 Javascript
简单易扩展可控性强的Jquery转盘抽奖程序
2019/03/16 jQuery
JS实现动态倒计时功能(天数、时、分、秒)
2019/12/12 Javascript
jquery实现上传文件进度条
2020/03/26 jQuery
从表单校验看JavaScript策略模式的使用详解
2020/10/17 Javascript
[54:53]完美世界DOTA2联赛PWL S2 GXR vs PXG 第二场 11.18
2020/11/18 DOTA
python中的字典详细介绍
2014/09/18 Python
python微信跳一跳系列之自动计算跳一跳距离
2018/02/26 Python
使用Python实现企业微信的自动打卡功能
2019/04/30 Python
python带参数打包exe及调用方式
2019/12/21 Python
pandas读取csv文件提示不存在的解决方法及原因分析
2020/04/21 Python
HTML5表格_动力节点Java学院整理
2017/07/11 HTML / CSS
Dr. Martens马汀博士澳大利亚官网:马丁靴鼻祖
2019/07/02 全球购物
中文教师求职信
2014/02/22 职场文书
对孩子的寄语
2014/04/09 职场文书
内蒙古鄂尔多斯市市长寄语
2014/04/10 职场文书
小学生作文评语
2014/04/18 职场文书
老兵退伍感言
2015/08/03 职场文书
初一年级组工作总结
2015/08/12 职场文书
高中体育课教学反思
2016/02/16 职场文书
导游词之西安大清真寺
2019/12/17 职场文书
详解TypeScript中的类型保护
2021/04/29 Javascript
javascript代码简写的几种常用方式汇总
2021/08/23 Javascript
纯 CSS 自定义多行省略的问题(从原理到实现)
2021/11/11 HTML / CSS
python如何利用cv2.rectangle()绘制矩形框
2022/12/24 Python