HTML5画布更广泛的KineticJS函数

本教程演示了所有的广泛的KineticJS提供的函数集,包括直线、缓和、背部、弹性、弹,和强大的。

说明:按“播放”转换所有的文本节点。

文字的东西,就不多说了,直接上图和上代码。


<!DOCTYPE HTML>
<html>
  <head>
    <style>
      body {
        margin: 0px;
        padding: 0px;
      }
      #buttons {
        position: absolute;
        top: 10px;
        left: 10px;
      }
      #buttons > input {
        padding: 10px;
      }
    </style>
  </head>
  <body>
    <div id="container"></div>
    <div id="buttons">
      <input type="button" id="play" value="Play">
      <input type="button" id="pause" value="Pause">
      <input type="button" id="reverse" value="Reverse">
    </div>
    <script src="http://d3lp1msu2r81bx.cloudfront.net/kjs/js/lib/kinetic-v4.7.2.min.js"></script>
    <script defer="defer">
      var stage = new Kinetic.Stage({
        container: 'container',
        width: 578,
        height: 480
      });
      var layer = new Kinetic.Layer();

      var easings = [
        {name: 'Linear', color:'blue'},
        {name: 'EaseIn', color:'green'},
        {name: 'EaseOut', color:'green'},
        {name: 'EaseInOut', color:'green'},
        {name: 'BackEaseIn', color:'blue'},
        {name: 'BackEaseOut', color:'blue'},
        {name: 'BackEaseInOut', color:'blue'},
        {name: 'ElasticEaseIn', color:'green'},
        {name: 'ElasticEaseOut', color:'green'},
        {name: 'ElasticEaseInOut', color:'green'},
        {name: 'BounceEaseIn', color:'blue'},
        {name: 'BounceEaseOut', color:'blue'},
        {name: 'BounceEaseInOut', color:'blue'},
        {name: 'StrongEaseIn', color:'green'},
        {name: 'StrongEaseOut', color:'green'},
        {name: 'StrongEaseInOut', color:'green'}
      ]; 
      
      var tweens = [];

      for(var n = 0; n < easings.length; n++) {
        var num = n + 1;
        var ease = easings[n];
        var text = new Kinetic.Text({
          x: 10,
          y: 60 + (n * 400 / easings.length),
          padding: 4,
          text: num + ') ' + ease.name,
          fontSize: 18,
          fontFamily: 'Calibri',
          fill: ease.color
        });

        layer.add(text);
        
        var tween = new Kinetic.Tween({
          node: text, 
          x: 420,
          easing: Kinetic.Easings[ease.name],
          duration: 2
        });
        
        // add tween to tweens array
        tweens.push(tween);
      }

      stage.add(layer);

      // play
      document.getElementById('play').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
          tweens[n].play(); 
        }
      }, false);
      
      // pause
      document.getElementById('pause').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
          tweens[n].pause(); 
        }
      }, false);
      
      // reverse
      document.getElementById('reverse').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
          tweens[n].reverse(); 
        }
      }, false); 

    </script>
  </body>
</html>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值