Unity 基础 之 代码动态监听UI交互组件汇总

简介: 通过介绍组件面板和代码示例,演示代码监听UI交互组件。

一,Button组件

按钮组件:可响应用户的点击并用于启动或确认操作。

1.1 组件介绍

属性:

  • Interactible:此属性确定该组件是否接受输入。此属性设置为 false 时,交互被禁用,过渡状态也将设置为禁用状态。
  • Transition:在可选组件中,有几个过渡选项,具体取决于可选组件的当前状态。不同的状态包括:正常、突出显示、按下和禁用。
  • Navigation:还有许多导航选项可用于控制如何实现控件的键盘导航。

过度模式:(颜色为例其他同理)

  • Target Graphic:用于交互组件的图形。
  • Normal Color:控件的正常颜色
  • Highlighted Color:控件突出显示时的颜色
  • Pressed Color:控件按下时的颜色
  • Disabled Color:控件禁用时的颜色
  • Color Multiplier:这会将每个过渡的着色颜色乘以其值。由此可以创建大于 1 的颜色,从而使基色小于白色(或小于完整 Alpha)的图形元素上的颜色(或 Alpha 通道)变亮。
  • Fade Duration:从一个状态淡入淡出到另一个状态所需的时间(以秒为单位)

1.2 代码监听

  • 监听无参数形式
public Button m_Btn;
void Start()
{
      //监听无参数函数
    m_Btn.onClick.AddListener(OnClickBtn);
}

public void OnClickBtn(int i)
{
    Debug.Log("带参函数响应,参数是:" + i);
}
  • 委托形式监听
public Button m_Btn;
void Start()
{
      //委托监听
    m_Btn.onClick.AddListener(delegate () {
            OnClickBtn(111);
        });
}

public void OnClickBtn(int index)
{
    Debug.Log("委托监听, 参数是:" + index);
}
  • Lambda形式简化
public Button m_Btn;
void Start()
{
      //Lambda监听
    m_Btn.onClick.AddListener(() => {
            OnClickBtn(111);
        });
}

public void OnClickBtn(int index)
{
    Debug.Log("委托监听, 参数是:" + index);
}

二,Toggle组件

开关组件:是让用户打开或关闭某个选项的复选框。

2.1 组件介绍

属性

  • Interactable:是否接收点击
  • Transition:确定控件以何种方式对用户操作进行可视化响应的属性。1
  • Navigation:确定控件顺序的属性。1
  • Is On:开关在开始时是否为打开状态
  • Toggle Transition:开关在其值发生变化时以图形方式作出的反应。提供的选项为 None_(即复选标记直接出现或消失)和 Fade_(即复选标记淡入或淡出)。
  • Graphic:用于复选标记的图像(那个对号√)。
  • Group:此开关所属的开关组。

2.2 代码监听

Toggle 的监听是默认传递当前是否勾选的bool值,这样可以方便用户直接使用。若需要加其他的参数也可以仿照1例中Button的委托或者Lambda形式去写就可以了。

public Toggle m_Toggle;

void Start()
{
    m_Toggle.onValueChanged.AddListener(OnClickToggle);
}

void OnClickToggle(bool isOn)
{
    if (m_Toggle.isOn)
    {
        Debug.Log("此Toggle已勾选");
    }
    else
    {
        Debug.Log("此Toggle已取消勾选");
    }
}

三,Slider组件

滑动条组件:允许用户通过拖动鼠标从预定范围中选择数值。

3.1 组件介绍

属性

  • Interactable:此组件是否接受输入。
  • Transition:确定控件以何种方式对用户操作进行可视化响应的属性。1
  • Navigation:确定控件顺序的属性。1
  • Fill Rec:用于控件填充区域的图形。
  • Handle Rect:用于控件滑动“控制柄”部分的图形
  • Direction:拖动控制柄时滑动条值增加的方向。选项包括 Left To Right、Right To Left、Bottom To Top 和 Top To Bottom。
  • Min Value:控制柄处于极下端(由 Direction 属性确定)时的滑动条值。
  • Max Value:控制柄处于极上端(由 Direction 属性确定)时的滑动条值。
  • Whole Numbers:是否应该将滑动条约束为整数值?
  • Value:滑动条的当前数值。如果在 Inspector 中设置了该值,则该值将用作初始值,但是当值变化时,运行时的值也将变化。

3.2 代码监听


public Slider m_Slider;

void Start()
{
    // 监听 --> 会自动将value作为参数传递
    m_Slider.onValueChanged.AddListener(OnValueChanged_Slider);
}

void OnValueChanged_Slider(float value)
{
    Debug.Log("滑动条值改变响应方法, 当前Slider的值:" + value);
}

四,Scrollbar组件

滚动条组件:允许用户滚动由于太大而无法完全看到的图像或其他视图。

4.1 组件介绍

属性

  • Interactable:此组件是否接受输入
  • Transition:确定控件以何种方式对用户操作进行可视化响应的属性。1
  • Navigation:确定控件顺序的属性。1
  • Fill Rect:用于控件背景区域的图形。
  • Handle Rect:用于控件滑动“控制柄”部分的图形
  • Direction:拖动控制柄时滚动条值增加的方向。选项包括 Left To Right、Right To Left、Bottom To Top 和 Top To Bottom。
  • Value:滚动条的初始位置值,范围为 0.0 到 1.0。
  • Size:控制柄在滚动条内的比例大小,范围为 0.0 到 1.0。
  • Number Of Steps:滚动条允许的不同滚动位置的数量。(当前值小于1时, 滑块可以滑动到任意位置; 当大于1时则是已占比形式, 比如:numberOfSteps = 3, 则滑块每次移动1/3;)

4.2 代码监听

默认监听方式:会自动传递Scrollbar的Value作为属性。

拓展监听方式:使用Lambda表达式的方式进多参数传递

public Scrollbar m_Scrollbar;

void Start()
{
    // 监听 --> 会自动将value作为参数传递
    m_Scrollbar.onValueChanged.AddListener(OnValueChanged_Scrollbar);
    
    // 或者 --> 还有其他参数可以这样写
    m_Scrollbar.onValueChanged.AddListener((float v) => { OnValueChanged_Scrollbar(v, m_Scrollbar.gameObject); });
}

void OnValueChanged_Scrollbar(float value)
{
    Debug.Log("滚动条值改变响应方法, 当前Slider的值:" + value);
}
void OnValueChanged_Scrollbar(float value, GameObject go)
{
    Debug.Log("滚动条值改变响应方法, 当前Slider名称和值分别:" + go.name + value);
}

看过上篇的童鞋理解起来应该会很方便,因为它的默认监听方式和Slider组件是完全一样的,而拓展的监听方式又在Button组件讲解时介绍过。


五,DropDown组件

下拉选单组件:可用于让用户从选项列表中选择单个选项。

5.1 组件介绍

属性

  • Interactable:此组件是否接受输入
  • Transition:确定控件以何种方式对用户操作进行可视化响应的属性。
  • Navigation:确定控件顺序的属性。。
  • Template:下拉列表的模板的矩形变换。
  • Caption Text:用于保存当前所选选项的文本的文本 (Text) 组件。
  • Caption Image:用于保存当前所选选项的图像的图像 (Image) 组件。
  • Item Text:用于保存列表项的文本的文本组件。
  • Item Image:用于保存列表项的图像的图像组件。
  • Value:当前所选选项的索引。0 代表第一个选项,1 代表第二个,依此类推。
  • Options:可能选项的列表。可为每个选项指定一个文本字符串和一个图像。

5.2 代码监听

监听方式和上面基本一致,只是参数意义不同一个是Value进度值,一个是下拉选单的索引值


public Dropdown m_DropDown;

void Start()
{
    m_DropDown.onValueChanged.AddListener(OnDropValueChange);
}

void OnDropValueChange(int v)
{
    //切换选项 时处理其他的逻辑...
    Debug.Log("点击下拉控件的索引是..." + v);
}

六,Input Field组件

输入组件:是一种使文本 (Text) 控件的文本可编辑的方法。

6.1 组件介绍

属性

  • Interactable:此组件是否接受输入
  • Transition:确定控件以何种方式对用户操作进行可视化响应的属性。
  • Navigation:确定控件顺序的属性。
  • TextComponent:对用作输入字段内容的文本元素的引用
  • Text:起始值。开始编辑前置于字段中的初始文本。
  • Character Limit:可在输入字段中输入的最大字符数的值。
  • Content Type:内容类型,定义输入字段接受的字符类型。
  • Line Type:换行类型
  • Placeholder:占位符,默认显示值,初始值:“Enter text…”
  • Caret Blink Rate:光标闪烁速率,定义该行上的标记的闪烁速率。
  • Caret Width:光标宽度,定义该行上的标记的宽度。
  • Custom Caret Color:是否开始光标颜色设置
  • Caret Color:光标颜色
  • Selection Color:所选文本部分的背景颜色。
  • Hide Mobile Input:隐藏附加到移动设备屏幕键盘上的本机输入字段。(仅支持IOS)

6.2 代码监听

输入组件:有两个可监听的操作,一个是当内容被改变时,一个是结束编辑时,监听方式和上面差不多,不一样的是此时的参数是组件中用户输入的内容作为字符串被返回来了

public InputField m_InputField;

void Start()
{
    // 当内容被改变时回调
    m_InputField.onValueChanged.AddListener(OnInputValueChanged);
    // 内容编辑结束时回调
    m_InputField.onEndEdit.AddListener(OnInputEndEdit);
}

void OnInputValueChanged(string context)
{
    Debug.Log("输入框内容改变为:" + context);
}

void OnInputEndEdit(string context)
{
    Debug.Log("输入框内容编辑结束, 最终内容为:" + context);
}
相关文章
|
3月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
167 3
|
4月前
|
开发者 图形学 Java
揭秘Unity物理引擎核心技术:从刚体动力学到关节连接,全方位教你如何在虚拟世界中重现真实物理现象——含实战代码示例与详细解析
【8月更文挑战第31天】Unity物理引擎对于游戏开发至关重要,它能够模拟真实的物理效果,如刚体运动、碰撞检测及关节连接等。通过Rigidbody和Collider组件,开发者可以轻松实现物体间的互动与碰撞。本文通过具体代码示例介绍了如何使用Unity物理引擎实现物体运动、施加力、使用关节连接以及模拟弹簧效果等功能,帮助开发者提升游戏的真实感与沉浸感。
113 1
|
3月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
193 0
|
3月前
|
图形学 开发者 UED
Unity游戏开发必备技巧:深度解析事件系统运用之道,从生命周期回调到自定义事件,打造高效逻辑与流畅交互的全方位指南
【8月更文挑战第31天】在游戏开发中,事件系统是连接游戏逻辑与用户交互的关键。Unity提供了多种机制处理事件,如MonoBehaviour生命周期回调、事件系统组件及自定义事件。本文介绍如何有效利用这些机制,包括创建自定义事件和使用Unity内置事件系统提升游戏体验。通过合理安排代码执行时机,如在Awake、Start等方法中初始化组件,以及使用委托和事件处理复杂逻辑,可以使游戏更加高效且逻辑清晰。掌握这些技巧有助于开发者更好地应对游戏开发挑战。
160 0
|
4月前
|
开发者 图形学 API
从零起步,深度揭秘:运用Unity引擎及网络编程技术,一步步搭建属于你的实时多人在线对战游戏平台——详尽指南与实战代码解析,带你轻松掌握网络化游戏开发的核心要领与最佳实践路径
【8月更文挑战第31天】构建实时多人对战平台是技术与创意的结合。本文使用成熟的Unity游戏开发引擎,从零开始指导读者搭建简单的实时对战平台。内容涵盖网络架构设计、Unity网络API应用及客户端与服务器通信。首先,创建新项目并选择适合多人游戏的模板,使用推荐的网络传输层。接着,定义基本玩法,如2D多人射击游戏,创建角色预制件并添加Rigidbody2D组件。然后,引入网络身份组件以同步对象状态。通过示例代码展示玩家控制逻辑,包括移动和发射子弹功能。最后,设置服务器端逻辑,处理客户端连接和断开。本文帮助读者掌握构建Unity多人对战平台的核心知识,为进一步开发打下基础。
153 0
|
4月前
|
开发者 图形学 C#
揭秘游戏沉浸感的秘密武器:深度解析Unity中的音频设计技巧,从背景音乐到动态音效,全面提升你的游戏氛围艺术——附实战代码示例与应用场景指导
【8月更文挑战第31天】音频设计在游戏开发中至关重要,不仅能增强沉浸感,还能传递信息,构建氛围。Unity作为跨平台游戏引擎,提供了丰富的音频处理功能,助力开发者轻松实现复杂音效。本文将探讨如何利用Unity的音频设计提升游戏氛围,并通过具体示例代码展示实现过程。例如,在恐怖游戏中,阴森的背景音乐和突然的脚步声能增加紧张感;在休闲游戏中,轻快的旋律则让玩家感到愉悦。
121 0
|
4月前
|
图形学 开发者
【Unity光照艺术手册】掌握这些技巧,让你的游戏场景瞬间提升档次:从基础光源到全局光照,打造24小时不间断的视觉盛宴——如何运用代码与烘焙创造逼真光影效果全解析
【8月更文挑战第31天】在Unity中,合理的光照与阴影设置对于打造逼真环境至关重要。本文介绍Unity支持的多种光源类型,如定向光、点光源、聚光灯等,并通过具体示例展示如何使用着色器和脚本控制光照强度,模拟不同时间段的光照变化。此外,还介绍了动态和静态阴影、全局光照及光照探针等高级功能,帮助开发者创造丰富多样的光影效果,提升游戏沉浸感。
106 0
|
4月前
|
开发者 图形学 Java
Unity物理引擎深度揭秘:从刚体碰撞到软体模拟,全面解析实现复杂物理交互的技巧与秘诀,助你打造超真实游戏体验
【8月更文挑战第31天】物理模拟在游戏开发中至关重要,可让虚拟世界更真实。Unity作为强大的跨平台游戏引擎,内置物理系统,支持从刚体碰撞到布料模拟的多种功能。通过添加Rigidbody组件,可实现物体受力和碰撞;使用AddForce()施加力;通过关节(如Fixed Joint)连接刚体以模拟复杂结构。Unity还支持软体物理,如布料和绳索模拟,进一步增强场景丰富度。掌握这些技术,可大幅提升游戏的真实感和玩家体验。
175 0
|
4月前
|
开发者 图形学 前端开发
绝招放送:彻底解锁Unity UI系统奥秘,五大步骤教你如何缔造令人惊叹的沉浸式游戏体验,从Canvas到动画,一步一个脚印走向大师级UI设计
【8月更文挑战第31天】随着游戏开发技术的进步,UI成为提升游戏体验的关键。本文探讨如何利用Unity的UI系统创建美观且功能丰富的界面,包括Canvas、UI元素及Event System的使用,并通过具体示例代码展示按钮点击事件及淡入淡出动画的实现过程,助力开发者打造沉浸式的游戏体验。
116 0
|
4月前
|
开发者 图形学 UED
深度解析Unity游戏开发中的性能瓶颈与优化方案:从资源管理到代码执行,全方位提升你的游戏流畅度,让玩家体验飞跃性的顺滑——不止是技巧,更是艺术的追求
【8月更文挑战第31天】《Unity性能优化实战:让你的游戏流畅如飞》详细介绍了Unity游戏性能优化的关键技巧,涵盖资源管理、代码优化、场景管理和内存管理等方面。通过具体示例,如纹理打包、异步加载、协程使用及LOD技术,帮助开发者打造高效流畅的游戏体验。文中提供了实用代码片段,助力减少内存消耗、提升渲染效率,确保游戏运行丝滑顺畅。性能优化是一个持续过程,需不断测试调整以达最佳效果。
105 0
下一篇
DataWorks