Unity中button事件监听的四种方式

UGUI 可视化创建以及关联事件很方便, 动态创建可以利用创建好的 Prefab 进行实例化, 只是在关联事件上有些复杂, 本文总结了几种给按钮绑定事件的关联方式.

1. 可视化创建及事件绑定 #
Step 1 : 通过 Hierarchy 面板创建 UI > Button.

这里写图片描述

Step 2 : 创建一个脚本 TestClick.cs, 定义了一个 Click 的 public 方法.

Step 3 : 选中 Hierarchy 中的 Button, Add Component 脚本 TestClick.cs

Step 4 : 在 Button(Script) 关联 TestClick 脚本里的 Click 方法.

这里写图片描述

Step 5 : Done.

TestClick.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class TestClick : MonoBehaviour {

public void Click(){
    Debug.Log ("Button Clicked. TestClick.");
}

}
2. 通过直接绑定脚本来绑定事件 #
Step 1 : 通过 Hierarchy 面板创建 UI > Button.

Step 2 : 创建一个 ClickHandler.cs 脚本, 定义了一个私有方法 OnClick(), 并在 Start() 方法里为 Button 添加点击事件的监听,作为参数传入 OnClick 方法.
这里写图片描述
Step 3 : 将 ClickHandler 绑定在 Button 对象上.

Step 4 : Done.

ClickHandler.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class ClickHandler : MonoBehaviour {

void Start () {
    Button btn = this.GetComponent<Button> ();
    btn.onClick.AddListener (OnClick);
}

private void OnClick(){
    Debug.Log ("Button Clicked. ClickHandler.");
}

}
3. 通过 EventTrigger 实现按钮点击事件 #
UGUI 系统中 Button 默认只提供了 OnClick 的调用方法, 有时候我们还需要监听鼠标进入事件 (MouseIn) 和鼠标滑出事件 (MouseOut). 就需要借助 UI 系统中的 EventTrigger 脚本来实现.

Step 1 : 通过 Hierarchy 面板创建 UI > Button.

Step 2 : 创建一个 EventTriggerHandler.cs 脚本, 利用 UnityEngine.EventSystems.EventTrigger 添加监听事件.
这里写图片描述
Step 3 : 绑定 EventTriggerHandler.cs 脚本到 Button 上.

Step 4 : Done.

EventTriggerHandler.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;

// 需要 EventTrigger 脚本的支援
[RequireComponent(typeof(UnityEngine.EventSystems.EventTrigger))]
public class EventTriggerHandler : MonoBehaviour {

// Use this for initialization
void Start () {
    Button btn = this.GetComponent<Button> ();
    EventTrigger trigger = btn.gameObject.GetComponent<EventTrigger> ();
    EventTrigger.Entry entry = new EventTrigger.Entry ();
    // 鼠标点击事件
    entry.eventID = EventTriggerType.PointerClick;
    // 鼠标进入事件 entry.eventID = EventTriggerType.PointerEnter;
    // 鼠标滑出事件 entry.eventID = EventTriggerType.PointerExit;
    entry.callback = new EventTrigger.TriggerEvent ();
    entry.callback.AddListener (OnClick);
    // entry.callback.AddListener (OnMouseEnter);
    trigger.triggers.Add (entry);
}

private void OnClick(BaseEventData pointData){
    Debug.Log ("Button Clicked. EventTrigger..");
}

private void OnMouseEnter(BaseEventData pointData){
    Debug.Log ("Button Enter. EventTrigger..");
}

}
4. 通过 MonoBehaviour 实现事件类接口来实现事件的监听 #
Step 1 : 通过 Hierarchy 面板创建 UI > Button.

Step 2 : 创建一个 EventHandler.cs 脚本.

Step 3 : 将脚本绑定在 Button 对象上.
这里写图片描述

Step 4 : Done.

EventHandler.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;

public class EventHandler : MonoBehaviour, IPointerClickHandler, IPointerEnterHandler, IPointerExitHandler, IPointerDownHandler, IDragHandler {

public void OnPointerClick(PointerEventData eventData){
    if(eventData.pointerId == -1){
        Debug.Log ("Left Mouse Clicked.");
    } else if(eventData.pointerId == -2){
        Debug.Log ("Right Mouse Clicked.");
    }
}

public void OnPointerEnter(PointerEventData eventData){
    Debug.Log ("Pointer Enter..");
}

public void OnPointerExit(PointerEventData eventData){
    Debug.Log ("Pointer Exit..");
}

public void OnPointerDown(PointerEventData eventData){
    Debug.Log ("Pointer Down..");
}

public void OnDrag(PointerEventData eventData){
    Debug.Log ("Dragged..");
}

}
UGUI 如何判断 UI 元素被点击时是鼠标的哪个按键, 上面的代码中我们可以根据 eventData.pointerId 来监听是鼠标左键还是右键. 但是每个 UI 元素都创建一个 MonoBehaviour 来监听各个事件显然不好, 下面是通过利用 Delegate 和 Event 来做一个通用类 UIEventListener 来处理事件 (观察者模式).

UIEventListener.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;

public class UIEventListener : MonoBehaviour, IPointerClickHandler, IPointerEnterHandler, IPointerExitHandler {

// 定义事件代理
public delegate void UIEventProxy(GameObject gb);

// 鼠标点击事件
public event UIEventProxy OnClick;

// 鼠标进入事件
public event UIEventProxy OnMouseEnter;

// 鼠标滑出事件
public event UIEventProxy OnMouseExit;

public void OnPointerClick(PointerEventData eventData){
    if (OnClick != null)
        OnClick (this.gameObject);
}

public void OnPointerEnter(PointerEventData eventData){
    if (OnMouseEnter != null)
        OnMouseEnter (this.gameObject);
}

public void OnPointerExit(PointerEventData eventData){
    if (OnMouseExit != null)
        OnMouseExit (this.gameObject);
}

}
TestEvent.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class TestEvent : MonoBehaviour {

void Start () {
    Button btn = this.GetComponent<Button> ();
    UIEventListener btnListener = btn.gameObject.AddComponent<UIEventListener> ();

    btnListener.OnClick += delegate(GameObject gb) {
        Debug.Log(gb.name + " OnClick");
    };

    btnListener.OnMouseEnter += delegate(GameObject gb) {
        Debug.Log(gb.name + " OnMouseEnter");
    };

    btnListener.OnMouseExit += delegate(GameObject gb) {
        Debug.Log(gb.name + " OnMOuseExit");
    };
}

}
TestEvent 脚本绑定在 Button 上即可.

Unity,可以通过给Button组件添加监听器来为按钮添加事件。可以使用以下代码来实现: 引用\[1\]的代码是一个名为LevelButtonEvent的脚本,它可以挂载到Button的预制体上。该脚本定义了一个int类型参数的事件onLevelButtonOnClick,并在按钮被点击时触发该事件。 引用\[2\]的代码是一个生成关卡选择按钮的方法LoadSelectButton。在该方法,首先获取Button的预制体,然后通过实例化来生成多个按钮。接着,给每个按钮的LevelButtonEvent组件的id属性赋值,并监听按钮的点击事件。 引用\[3\]的代码是另一个示例,展示了如何在UnityButton添加点击事件。在Start方法,通过GameObject.Find方法找到名为"Button"的游戏对象,并获取其Button组件。然后,使用AddListener方法为按钮的点击事件添加两个方法M和F。 综上所述,Unity可以通过给Button组件添加监听器的方式为按钮添加事件。可以根据需要选择使用引用\[1\]的LevelButtonEvent脚本或引用\[3\]的示例代码来实现。 #### 引用[.reference_title] - *1* *2* [unity给多个Button添加点击事件](https://blog.csdn.net/hyp19980829/article/details/85237054)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Unity UGUI按钮添加点击事件](https://blog.csdn.net/weixin_40311211/article/details/82984982)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值