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. Selenium - 元素操作(5) - iframe切换

    Selenium - 元素操作 iframe切换 很多时候定位元素时候总是提示元素定位不到的问题,明明元素就在那里,这个时候就要关注你所 定位的元素是否在frame和iframe里面: frame标签 ...

  2. python如何利用算法解决业务上的【分单问题】

    分单是很多企业日常工作中非常典型的一项内容,它非常复杂,但同时又极为重要,如何合理的分单是企业管理中一个很重要的课题. 之所以说分单很复杂,是因为影响单据该分给谁,分多少量这个事儿本身就有太多的影响因 ...

  3. Kotlin难点

    目录 高阶函数 双冒号 函数引用 类引用 属性引用 匿名函数 Lambda 表达式 例子 作用域函数 高阶函数 高阶函数是将函数用作参数或返回值的函数,还可以把函数赋值给一个变量. 所有函数类型都有一 ...

  4. OSPF 多区域配置实验

    实验拓扑 实验需求 按照图示配置 IP 地址和loopback 接口 按照图示分区域配置 OSPF ,实现全网互通 为了路由结构稳定,要求路由器使用环回口作为 Router-id 在AR3上配置静默接 ...

  5. RedHat7.4配置yum源(原创!详细易懂)

    redhat7 .4配置centOS yum源(自带yum文件) 1.定位到yum的配置文件 root@192.168.6.129:/etc# cd yum.repos.d 2.检查yum是否安装,以 ...

  6. 深入探索C++对象模型(Inside the C++ object model) -- 摘阅笔记(关于对象 - esp 1)

    Object Lessons 关于对象 在C语言中,"数据"和"处理数据的操作(函数)"是分开声明的,也就是说 ,语言本身并没有支持"数据和函数&qu ...

  7. C++ 惯用法之 Copy-Swap 拷贝交换

    C++ 惯用法之 Copy-Swap 拷贝交换 这是"C++ 惯用法"合集的第 3 篇,前面 2 篇分别介绍了 RAII 和 PIMPL 两种惯用法: RAII: Resouce ...

  8. 我和ChatGPT聊数字人

    ​ 近期,聊天机器人ChatGPT火了,写诗写文写代码,才艺狠狠拉满. 面对如此"会聊"的ChatGPT,很多人好奇相同的问题提问ChatGPT和真人,会有什么样的结果? 于是我们 ...

  9. 与 AI 同行,利用 ChatGLM 构建知识图谱

    大家好,我是东方财富的一名算法工程师,这里分享一些利用大模型赋能知识图谱建设的一些实践. 为什么知识图谱需要大模型 在金融场景中,天然会有大量结构化的数据需要投入大量的人力去生产和维护,而这样的数据又 ...

  10. Lens Shading成因及相关

    一个监控摄像头光学处理包含以下几个部分:镜头(Lens)(定变焦镜头).红外截止滤波片(IR-cut filter)(红外截止滤光片和蓝玻璃滤光片为主).图像传感器(Image Sensor)和印制电 ...