今天给大家展示一下点击按钮然后切换场景这个代码

本文介绍了一个使用Cocos2d-x框架的游戏开发案例,重点讲解了游戏UI搭建、按钮事件处理及场景切换等核心功能实现。通过具体代码展示了如何初始化游戏层、设置标签文本、响应用户触屏操作并实现不同场景间的转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先创建helloworld的主要框架,然后具体的我再在代码中分析一下
var HelloWorldLayer = cc.Layer.extend({
    _mainUI:null,
    _a:null,
    //
    MAX:6,
    MIN:1,
    _c:null,
    ctor:function () {
        //////////////////////////////
        // 1. super init first
        this._super();
        this._init();
    },
    _init:function() {
        this._a = 4 ;
        this._mainUI = ccs.load(res.Ui_Json).node;
        this.addChild(this._mainUI);
        this._c=this._getWidgetByName(this._mainUI,"Label_5");
        this._setLabString(this._a);
        this._getWidgetByName(this._mainUI,"Button_2").addTouchEventListener(this._leftBtn.bind(this),this._mainUI);
        this._getWidgetByName(this._mainUI,"Button_1").addTouchEventListener(this._rightBtn.bind(this),this._mainUI);
        this._getWidgetByName(this._mainUI,"Button_3").addTouchEventListener(this._startGame.bind(this),this._mainUI);
    },
这里是开始切换场景的一个方法
    _startGame:function(){
        cc.director.runScene(new GameScene());
        //this._a =this._getWidgetByName(this._mainUI,"Button_3");
        //this._a.addTouchEventListener(this._inputHandler.bind(this),this._mainUI);
        //var btn;
        //for(var i = 0;i<this.TOTAL;i++){
        //    btn=this._getWidgetByName(this._mainUI,"Button_"+i);
        //    btn.addTouchEventListener(this._inputHandler.bind(this),this._mainUI)
        //}
    },
这是回调方法
    _inputHandler: function (sender,type) {
        if(type==ccui.Widget.TOUCH_ENDED){
            //var str=sender.name.split("Button_")[1];
            if(sender.name == "Button_3") this._changeScene();
            else if(sender.name == "Button_2") this._leftBtn();
            else if(sender.name == "Button_1") this._rightBtn();
        }
    },
其实这是一个拼图游戏裁出来的一部分,这里是左按钮,不做分析
    _leftBtn:function(sender,type){
        if(type==ccui.Widget.TOUCH_ENDED) {
            this._a--;
            if (this._a < this.MIN)  this._a = this.MAX;
            this._setLabString(this._a);
        }
    },
同样的,这里是右按钮
    _rightBtn:function(sender,type){
        if(type==ccui.Widget.TOUCH_ENDED) {
            this._a++;
            if (this._a > this.MAX)  this._a = this.MIN;
            this._setLabString(this._a);
        }
    },
切换场景
    _changeScene:function(){
        var scene =new GameScene();
        cc.director.runScene(scene);
    },
封装的API
    _getWidgetByName:function(par,name){
        return ccui.helper.seekWidgetByName(par,name);
    },
    _setLabString:function(str){
        this._c.setString(str);
    },
    _getLabString:function(){
        return this._c.getString();
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值