中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

COCOS CREATOR(TS)之按鈕事件

發布時間:2020-07-23 21:57:26 來源:網絡 閱讀:2158 作者:Aonaufly 欄目:開發技術

一 : 前景介紹

為cc.Button添加事件的方法有很多種 , 本篇只講解使用cc.Component.EventHandler的方法.因為此方案有一個最大的有點 : 可以獲得cc.Event.EventTouch.但是此方案,相比如控件拖動方案要復雜一些,所以給出此Blog予以詳解

二 : 詳解

Ⅰ: 構建cc.Component.EventHandler對象

export class ClickEvent2CreatTool{
    private static _instance : ClickEvent2CreatTool = null;
    public static get Instance() : ClickEvent2CreatTool{
        if( !ClickEvent2CreatTool._instance ){
            ClickEvent2CreatTool._instance = new ClickEvent2CreatTool();
        }
        return ClickEvent2CreatTool._instance;
    }

    public create( $node : cc.Node , $component : string , $handler : string , $param : any ) : cc.Component.EventHandler{
        let $event : cc.Component.EventHandler = new cc.Component.EventHandler();
        $event.target = $node;
        $event.component = $component;
        $event.handler = $handler;
        if( $param )
            $event.customEventData = $param;
        return $event;
    }
}

PS create參數 :
①-> $node : 放置腳本的cc.Node
②-> $component : 腳本的名稱
③-> $handler : 腳本中為事件處理的函數
④-> $param : 處理函數的用戶自定義的參數

Ⅱ : 設計界面
①,結構圖如下
COCOS CREATOR(TS)之按鈕事件
②,UI效果圖如下
COCOS CREATOR(TS)之按鈕事件
③,BTN不用設置Click Events(我們不用拖控件的方案)
COCOS CREATOR(TS)之按鈕事件
Ⅲ:腳本編寫

import {ClickEvent2CreatTool} from "../tool/ClickEvent2CreatTool";

const {ccclass, property} = cc._decorator;

@ccclass
export default class MainMenu extends cc.Component {

    @property(cc.Button)
    btn_map: cc.Button = null;

    @property(cc.Button)
    btn_building : cc.Button = null;

    @property(cc.Button)
    btn_menu : cc.Button = null;

    private listener2Btn( $isAdd : boolean ) : void{
        if( $isAdd ){
            this.btn_map.clickEvents.push(ClickEvent2CreatTool.Instance.create( this.node , "MainMenu" , "clickHandler" , this.btn_map ));
            this.btn_building.clickEvents.push(ClickEvent2CreatTool.Instance.create( this.node , "MainMenu" , "clickHandler" , this.btn_building ));
            this.btn_menu.clickEvents.push(ClickEvent2CreatTool.Instance.create( this.node , "MainMenu" , "clickHandler" , this.btn_menu ));
        }else{
            this.btn_map.clickEvents.shift();
            this.btn_building.clickEvents.shift();
            this.btn_menu.clickEvents.shift();
        }
    }
    clickHandler( $event : cc.Event.EventTouch, $customEventData : any ) : void{
        switch( $customEventData ){
            case this.btn_map:
                console.log("map click");
                break;
            case this.btn_building:
                console.log("building click");
                break;
            case this.btn_menu:
                console.log("menu click");
                break;
        }
    }

    start () : void {
        this.listener2Btn( true );
    }

    onDestroy() : void{
        this.listener2Btn( false );
    }
}

PS create參數:
①-> this.node 既是UI中的MainMenu節點 , 這個節點會綁定此腳本
②-> MainMenu 腳本的文件名稱
③-> clickHandler 腳本中clickHandler方法為Event處理方法
④-> this.btnmap 自定義的參數

Ⅳ : 在UI中使MainMenu節點綁定腳本MainMenu
COCOS CREATOR(TS)之按鈕事件
Ⅴ : 結果
COCOS CREATOR(TS)之按鈕事件

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

萍乡市| 屏东市| 自贡市| 仁怀市| 永安市| 祥云县| 鞍山市| 金川县| 香港| 抚宁县| 杨浦区| 当阳市| 保靖县| 雅安市| 武夷山市| 蚌埠市| 河东区| 噶尔县| 保靖县| 定远县| 赤城县| 色达县| 建宁县| 南江县| 南康市| 格尔木市| 泌阳县| 东丽区| 灵山县| 阿克陶县| 丹阳市| 巫溪县| 永康市| 全椒县| 临夏县| 东乌珠穆沁旗| 沛县| 宁武县| 长汀县| 潞城市| 宁陕县|