UGUI的Button(按钮)组件的介绍及使用

1. 什么是UGUI的Button组件?

UGUI(Unity GUI)是Unity引擎中的一套用户界面系统,Button(按钮)是其中的一个常用组件。Button组件可以用于创建可交互的按钮,用户点击按钮时可以触发相应的事件。

2. Button组件工的作原理

Button组件通过检测用户的点击事件来触发相应的操作。当用户点击按钮时,Button组件会检测到点击事件,并执行相应的操作,如比调用指定的函数或改变按钮的状态。

3. Button组件的常用属性

  • Interactable(可交互):设置按钮是否可交互。如果设置为false,按钮将无法被点击。
  • Transition(过渡效果):设置按钮的过渡效果,包括颜色、缩放、透明度等。
  • Normal Color(正常状态颜色):设置按钮在正常状态下的颜色。
  • Highlighted Color高(亮状态颜色):设置按钮在高亮状态下的颜色。
  • Pressed Color(按下状态颜色):设置按钮在按下状态下的颜色。
  • Disabled Color(禁用状态颜色):设置按钮在禁用状态下的颜色。

4. Button组件的常用函数

  • onClick.AddListener():为按钮添加点击事件的监听器。
  • onClick.Remove()Listener:移除按钮的点击事件监听器。
  • onClick.Invoke():手动触发按钮的点击事件。

5. 示例代码

示例1:创建一个简单的按钮

using UnityEngine;
using UnityEngine.UI; public class ButtonExample : MonoBehaviour
{
public Button button; void Start()
{
button.onClick.AddListener(OnClick);
} void OnClick()
{
Debug.Log("Button clicked!");
}
}

操作步骤:

  1. 创建一个空物体,并将脚本ButtonExample挂载到该物体上。
  2. 在场景中创建一个按钮,并将该按钮的引用赋值给button变量。
  3. 运行游戏,点击按钮,控制台将输出"Button clicked!"。

注意事项:

  • 确保按钮的OnClick事件已经绑定到ButtonExample脚本的OnClick函数。

示例2:改变按钮的颜色

using UnityEngine;
using UnityEngine.UI; public class ButtonExample : MonoBehaviour
{
public Button button; void Start()
{
button.onClick.AddListener(OnClick);
} void OnClick()
{
button.image.color = Color.red;
}
}

操作步骤:

  1. 创建一个空物体,并将脚本ButtonExample挂载到该体物上。
  2. 在场景中创建一个按钮,并将该按钮的引用赋值给button变量。
  3. 运行游戏,点击按钮,按钮的颜色将变为红色。

注意事项:

  • 确保按钮的OnClick事件已经绑定到ButtonExample脚本的OnClick函数。

示例3:禁用按钮

using UnityEngine;
using UnityEngine.UI; public class ButtonExample : MonoBehaviour
{
public Button button; void Start()
{
button.onClick.AddListener(OnClick);
} void OnClick()
{
button.interactable = false;
}
}

操作步骤:

  1. 创建一个空物体,并将脚本ButtonExample挂载到该物体上。
  2. 在场景中创建一个按钮,并将该按钮的引用赋值给button变量。
  3. 运行游戏,点击按钮,按钮将变为不可交互状态。

注意事项:

  • 确保按钮的OnClick事件已经绑定到ButtonExample脚本的OnClick函数。

示例4:移除按钮的点击事件监听器

using UnityEngine;
using UnityEngine.UI; public class ButtonExample : MonoBehaviour
{
public Button button; void Start()
{
button.onClick.AddListener(OnClick);
} void OnClick()
{
button.onClick.RemoveListener(OnClick);
}
}

操作步骤:

1.空一个 创建物体,并将脚本ButtonExample挂载到该物体上。

2. 在场景中创建一个按钮,并将该按钮的引用赋值给button变量。

3. 运行游戏,点击按钮,按钮的点击事件监听器将被移除。

注意事项:

  • 确保按钮的OnClick事件已经绑定到ButtonExample脚本的OnClick函数。

示例5:手动触发按钮的点击事件

using UnityEngine;
using UnityEngine.UI; public class ButtonExample : MonoBehaviour
{
public Button button; void Start()
{
button.onClick.AddListener(OnClick);
} void Update()
{
if (Input.GetKeyDown(KeyCode.Space))
{
button.onClick.Invoke();
}
} void OnClick()
{
Debug.Log("Button clicked!");
}
}

操作步骤:

  1. 创建一个空物体,并将脚本ButtonExample挂载到该物体上。
  2. 在场景中创建一个按钮,并将该按钮的引用赋值给button变量。
  3. 运行游戏,按空下格键,控制台将输出"Button clicked!"。

注意事项:

  • 确保按钮的OnClick事件已经绑定到ButtonExample脚本的OnClick函数。

参考资料

Unity UGUI的Button组件的介绍及使用的更多相关文章

  1. Unity UGUI之Button

    创建Button后,会出现一个Image组件和一个Button组件,以及Button子节点Text(可以删除不影响功能) 其中Image的Image Type中有四个选项--Simple.Sliced ...

  2. Unity UGUI实现Button按钮长按状态的判断

    代码: using UnityEngine.EventSystems; using System.Collections; /// <summary> /// 脚本位置:UGUI按钮组件身 ...

  3. Unity UGUI——Rect Transform组件(基础属性)

    基础属性:Width.Height.Pivot图示 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTXJfQUhhbw==/font/5a6L5L2T/fo ...

  4. Unity UGUI Layout自动排版组件用法介绍

    Unity UGUI布局组件 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...

  5. Unity UGUI基础之Button

    UGUI Button,可以说是真正的使用最广泛.功能最全面.几乎涵盖任何模块无所不用无所不能的组件,掌握了它的灵巧使用,你就几乎掌握了大半个UGUI! 一.Button组件: Interactabl ...

  6. 关于Unity中UI中的Button节点以及它的Button组件

    Button是最常用的UI节点,包含的组件有 1.Image组件 显示Button的纹理,把Image贴图拖进Image组件中后,记得点击Set Native Size,显示贴图原始大小 2.Butt ...

  7. Unity UGUI —— 无限循环List

    还记得大学毕业刚工作的时候是做flash的开发,那时候看到别人写的各种各样的UI组件就非常佩服,后来自己也慢慢尝试着写,发现其实也就那么回事.UI的开发其实技术的成分相对来说不算多,但是一个好的UI是 ...

  8. Unity UGUI

    超详细的基础教程传送门:(持续更新中) Unity UGUI之Canvas&EventSystem:http://blog.csdn.net/qq992817263/article/detai ...

  9. Unity UGUI 小知识

    1.有个控件叫Selectable 这个控件在button,slider等身上有,也可以自行添加,可通过API搜索所有带这个控件的物体统一控制. 2.实现ScrollView只使用Scrollbar操 ...

  10. Unity UGUI鼠标穿透UI问题(Unity官方的解决方法)

    简述 最近在用UGUI的时候遇到了鼠标穿透的问题,就是说在UGUI和3D场景混合的情况下,点击UI区域同时也会 触发3D中物体的鼠标事件.比如下图中 这里给Cube加了一个鼠标点击改变颜色的代码,如下 ...

随机推荐

  1. 【工作随手记】并发之synchronized

    synchronized对于java同学肯定都是耳熟能详的必修课了.但是不管对于新手还是老手都有一些容易搞错的点.这里权做一点记录. 锁的是代码还是对象? 同步块一般有两种写法. 1是直接加以方法体上 ...

  2. [MAUI]在.NET MAUI中复刻苹果Cover Flow

    @ 目录 原理 3D旋转 平行变换 创建3D变换控件 绘制封面图片 应用3D旋转 应用平行变换 绘制倒影 创建绑定属性 创建绑定数据 创建布局 计算位置 计算3D旋转 创建动效 项目地址 Cover ...

  3. 2023 5.14 虚拟环境安装Linux

    1.安装配置VM虚拟机 vmare workstation 虚拟机是一款桌面计算机虚拟软件 让用户能够在单一主机上同事运行多个操作系统 1.每个虚拟操作系统的硬盘与数据都是独立 2.多台虚拟机可以构建 ...

  4. 2023-05-26:golang关于垃圾回收和析构函数的选择题,多数人会选错。

    2023-05-26:golang关于垃圾回收和析构的选择题,代码如下: package main import ( "fmt" "runtime" " ...

  5. Outlook无法启动一直显示“正在启动”的解决方法

    缘起 今天早上打开电脑以后,就打开Outlook2016了,一直显示这个界面: 我没在意就干别的事了, 可以半个小时过去了,还是这个界面,我慌了. 解决方法 安全模式打开Outlook 按WIN + ...

  6. Java(数组使用、Arrays、稀疏数组)

    1.数组的使用 For-Each循环 int[] arrays = {1,2,3,4,5}; //打印全部的数组元素 JDK1.5 没有下标 for (int array : arrays) { Sy ...

  7. CF1477E&大户爱的送分题题解

    CF1477E&大户爱的送分题题解 (CF1477E为我出的校内模拟赛的一道题--<大户爱的送分题>的待修版本) 大户爱的送分题 文件名OhtoAiFirst.cpp/.in/.o ...

  8. NSDI-2023 微软论文:解构有状态网络功能

    本文通过chatgpt代理站(支持gpt4):gptschools.cn翻译整理 微软Azure对每个虚拟机进行了为期三个月的网络监控,获得了新建.并发.PPS等指标情况,发现: 1) 网络功能负载不 ...

  9. 报错 no currentsessioncontext configured!

    no currentsessioncontext configured! 使用hibernate框架报错 配置了session工厂类,使用getCurrentSession();时候引起的,原因是cu ...

  10. 河南省第十四届icpc大学生程序设计竞赛-clk

    这次比赛赛程比较长,520出发,521,回学校,出发的那一天有点热,感觉不是很好,而且那一天感觉有点生病,应该只是普通感冒,热身赛的时候被oier吊打,省实验真厉害,晚上回酒店后,我喊队友,补了前年的 ...