欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

简述tweenjs的使用

程序员文章站 2022-06-11 11:01:56
安装 执行 cnpm i -s @tweenjs/tween.js 简单demo const tween = require('@tweenjs/tween.js') cl...

安装

执行 cnpm i -s @tweenjs/tween.js

简单demo

const tween = require('@tweenjs/tween.js')

class demo {
    animate () {
        this.animate = this.animate.bind(this)
        requestanimationframe(this.animate)
        tween.update()
    }

    init () {
        const tween = new tween.tween({ number: 0 }).to({ number: 1000 }, 1000).easing(tween.easing.linear.none).start()
        tween.onupdate((data: any) => {
            console.log(data.number)
        })
        this.animate()
    }
}

注意事项

关于 tween.update() 的参数

tween.update() 可传入 time 参数,在自定义 time 参数时,需在调用 tween.start() 函数时,传入初始 time 值,否则,tween 在执行时,默认 starttime 的值是 start 函数执行时 tween.now() 的返回值,从而导致当前 tween 的补间动画延迟执行,延迟执行的时间取决于当前 tween 对应的 starttime 的值和 tween.update(time) 函数中 time 的增量值的幅度。示例代码如下:

class demo {
  time = 0

  animate () {
      this.animate = this.animate.bind(this)
      requestanimationframe(this.animate)
      tween.update(this.time)
      this.time += 100
  }

  init () {
      const tween = new tween.tween({ number: 0 }).to({ number: 1000 }, 1000).easing(tween.easing.linear.none).start(this.time)
      tween.onupdate((data: any) => {
          console.log(data.number)
      })
      this.animate()
  }
}