亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

甘孜| 随州市| 突泉县| 诸城市| 泰宁县| 九江县| 额济纳旗| 三河市| 榆林市| 武城县| 朔州市| 鹿邑县| 额敏县| 黑龙江省| 长沙县| 大荔县| 明星| 青州市| 海阳市| 英德市| 东安县| 江门市| 吴江市| 仙居县| 永城市| 青岛市| 灌南县| 铁岭县| 阿勒泰市| 蒙自县| 大足县| 嘉定区| 东城区| 民乐县| 什邡市| 杭州市| 柯坪县| 齐河县| 资阳市| 富锦市| 平阴县|