Search code examples
javascriptcocos2d-jscocos2d-html5

Cocos2d-js sprite array touch event


var GameLayer = cc.Layer.extend({
    ball:[],
    number:[],
    label:[],
    numberofballs:8,
    _order:0,
    ctor:function () {
        this._super();
        this.init();
    },
    init:function(){
        this._order=0;
        cc.log(this._order);
        this.setBall();
    },
    setCoordX:function(){
        var coordX=Math.random()*1000%330+50;
        cc.log(coordX);
        return coordX;
    },
    setCoordY:function(){
        var coordY = Math.random()*700%700+50;
        cc.log(coordY);
        return coordY;
    },
    onTouchBegan:function(touch, event){
        var target = event.getCurrentTarget();
        var PosInScreen = target.convertToNodeSpace(touch.getLocation());
        var Size = target.getContentSize();
        var rect = cc.rect(0, 0, Size.width, Size.height);

        if(cc.rectContainsPoint(rect, PosInScreen)){

            if(target.getTag()==this._order) {
                target.removeFromParent();
                this._order++;
            }

        }
        return false;
    },
    setBall:function(){
        for(var i=0;i<this.numberofballs;i++){
            this.number.push(Math.round(Math.random()*100));
        }
        this.number.sort(function(left,right){
            return left-right;
        });
        for(var i=0;i<this.numberofballs;i++){
            var eventListener = cc.EventListener.create({
                event: cc.EventListener.TOUCH_ONE_BY_ONE,
                swallowTouches: true,
                onTouchBegan: this.onTouchBegan});


            this.ball[i]=cc.Sprite.create(res.ball_png);
            this.ball[i].x=this.setCoordX();
            this.ball[i].y=this.setCoordY();
            this.ball[i].setTag(i);
            this.addChild(this.ball[i]);

            var label=new cc.LabelTTF(this.number[i],"Ariel",25);
            label.x=50;
            label.y=55;
            this.ball[i].addChild(label);
            cc.eventManager.addListener(eventListener, this.ball[i]);

        }

    }
});

var GameScene = cc.Scene.extend({
    onEnter:function () {
        this._super();
        var layer = new GameLayer();
        this.addChild(layer);
    }
});

This is my whole code.

First, in setBall function, I added

 cc.eventManager.addListener(eventListener, this.ball[i]);

I want to make touch event with this.ball array directly.

Second,in onTouchBegan function, this._order is null. I don't know why.

How can I fix it?


Solution

  • this._order is undefined because in onTouchBegan function this is instance of cc.EventListener class.

    If You want to make this to be instance of GameLayer, You can bind it:

    var eventListener = cc.EventListener.create({
        event: cc.EventListener.TOUCH_ONE_BY_ONE,
        swallowTouches: true,
        onTouchBegan: this.onTouchBegan.bind(this)});