Cocos2d-x《雷电大战》(2)-精灵随手指移动,你点哪我走哪!

请参见原作者实现

Cocos2d-x《雷电大战》(2)-精灵随手指移动,你点哪我走哪!

作者想实现的功能是有个飞机,可以接受触控事件,让飞机跟着手指走

1.资源

var res = {
//...
  AIRPLAN:'res/air1.png',
//...
  };

2.添加新的层至HelloScene
var HelloWorldScene = cc.Scene.extend({
  onEnter:function () {

//....


    //可以飞了
    var airLayer=new Airplane();
    this.addChild(airLayer,300);
//....

  }
});
3 project.json中添加新的脚本引用
   
 "jsList" : [
        "src/resource.js",
        "src/airplane.js", //我们新的文件
        "src/app.js"
    ]


4现在我们可以在src/airplane.js中实现Airplane了

var Airplane = cc.Sprite.extend({
    ctor:function (){
      var me=this;
      var size=cc.winSize;
      me._super(res.AIRPLAN)
      me.setPosition(size.width/2,size.height/2);

      cc.eventManager.addListener(cc.EventListener.create({
        event: cc.EventListener.TOUCH_ONE_BY_ONE,
        swallowTouches: true,
        onTouchBegan: me.onTouchBegan.bind(me),
        onTouchMoved: me.onTouchMoved.bind(me),
        onTouchEnded: me.onTouchEnded.bind(me),
      }), me);

      return true;
    },
    onTouchBegan:function(touch,e){
      var me=this;
      var size=me.getContentSize();
      var rect = cc.rect(0, 0, size.width, size.height);

      var point = me.convertToNodeSpace(touch.getLocation());
      if(cc.rectContainsPoint(rect,point)){
        me.started=true;
        return true;
      }
      return false;
    },
    onTouchMoved:function(touch,e){
      var me=this;
      var size=me.getContentSize();

      if(!!me.started){
        var delta = touch.getDelta();
        var x=me.x + delta.x;
        var y=me.y + delta.y;
        if(x <= size.width / 2  ){
          x = size.width / 2;
        }else if(x > cc.winSize.width - size.width /2 ){
          x = cc.winSize.width - size.width /2;
        }
        if(y < size.height / 2){
          y = size.height/2;
        }else if(y > cc.winSize.height - size.height / 2){
          y = cc.winSize.height - size.height / 2
        }
        me.x=x;
        me.y=y;
      }
    },
    onTouchEnded:function(t,e){
      this.started=false;
    }
});


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值