首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在easeljs/tweenjs中手动旋转

在easeljs/tweenjs中手动旋转
EN

Stack Overflow用户
提问于 2018-05-17 12:23:46
回答 1查看 330关注 0票数 0

我在手动旋转物体的过程中遇到了问题。我想要的是,当一个人双击这个对象时,它会旋转20次(任何一边,我并不挑剔)一次。如果他们再次点击,它再次旋转20。然而,它不会在任何时候旋转(双击,或不)。我在这里做错什么了?

代码语言:javascript
复制
var tri2 = new createjs.Shape();
tri2.graphics.beginStroke("#000").beginFill('#000').drawPolyStar(0, 0, 50, 3, 0, 270);

var draggerTri2 = new         createjs.Container();

draggerTri2.x = Math.random()*100;
draggerTri2.y = Math.random()*100;
draggerTri2.addChild(tri2);  

stage.addChild(draggerTri2);

draggerTri2.on("pressmove",function move(evt) {

evt.currentTarget.x = evt.stageX;
evt.currentTarget.y = evt.stageY;

stage.update();   

});

draggerTri2.on("dblclick", function rotate(evt) {

var tween2 = new TWEEN.Tween(draggerTri2,dataset)
          .to({left: "-20"}, 2000)
      .repeat(0)
      .onUpdate(function(draggerTri2){
        draggerTri2.left = Math.round(draggerTri2.left);
      })
     .start()

stage.update();   

 });

  stage.update();

代码链接:https://codepen.io/AoifeMcNeill/pen/XqyWej?editors=0010

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-18 15:16:28

你的吐温代码不是TweenJS代码。如果双击,您将得到一个未定义TWEEN的控制台错误。

TweenJS代码如下所示:

代码语言:javascript
复制
draggerTri2.on("dblclick", function rotate(evt) {
  var tween2 = createjs.Tween.get(draggerTri2, {override:true})
  .to({rotation:draggerTri2.rotation+20}, 2000)
  .on("change", function(event){
    var tween = event.target,
        draggerTri2 = tween.target;
    draggerTri2.rotation = Math.round(draggerTri2.rotation);
    stage.update();  // Only do this if nothing else is updating your stage
  });
});

您还可以使用RelativePlugin相对于当前的旋转进行旋转,而不是使用绝对值:

代码语言:javascript
复制
RelativePlugin.install();
var tween2 = createjs.Tween.get(draggerTri2, {override:true})
    .to({rotation:"+20"}, 2000);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50391414

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档