Unity UGUI的Dropdown(下拉菜单)组件的介绍及使用
Unity UGUI的Dropdown(下拉菜单)组件的介绍及使用
1. 什么是Dropdown组件?
Dropdown(下拉菜单)是Unity UGUI中的一个常用组件,用于在用户点击或选择时显示一个下拉菜单,提供多个选项供用户选择。
2. Dropdown组件的工作原理
Dropdown组件由两部分组成:一个可点击的按钮和一个下拉菜单。当用户点击按钮时,下拉菜单会展开,显示所有选项。用户可以通过点击选项来进行选择。
3. Dropdown组件的常用属性
- Options:下拉菜单中的选项列表。
- Caption Text:按钮上显示的文本。
- Template:下拉菜单的模板。
- Item Text:下拉菜单中选项的文本。
- On Value Changed:当选择的值发生变化时触发的事件。
4. Dropdown组件的常用函数
- ClearOptions():清空下拉菜单中的选项。
- AddOptions(List options):向下拉菜单中添加选项。
- SetValueWithoutNotify(int value):设置当前选择的值,但不触发事件。
5. 示例代码
示例1:创建一个简单的下拉菜单
using UnityEngine;
using UnityEngine.UI;
public class DropdownExample : MonoBehaviour
{
public Dropdown dropdown;
void Start()
{
dropdown.ClearOptions();
dropdown.AddOptions(new List<string> { "Option 1", "Option 2", "Option 3" });
}
}
操作步骤:
- 创建一个空物体,并将Dropdown组件添加到该物体上。
- 将DropdownExample脚本添加到该物体上。
- 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
- 运行游戏,下拉菜单中将显示"Option 1"、"Option 2"和"Option 3"三个选项。
注意事项:
- 在Start函数中添加选项,确保在游戏开始时下拉菜单已经初始化。
示例2:获取当前选择的值
using UnityEngine;
using UnityEngine.UI;
public class DropdownExample : MonoBehaviour
{
public Dropdown dropdown;
void Start()
{
dropdown.ClearOptions();
dropdown.AddOptions(new List<string> { "Option 1", "Option 2", "Option 3" });
}
public void OnDropdownValueChanged(int value)
{
Debug.Log("Selected option: " + dropdown.options[value].text);
}
}
操作步骤:
- 创建一个空物体,并将Dropdown组件添加到该物体上。
- 将DropdownExample脚本添加到该物体上。
- 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
- 在DropdownExample脚本中,创建一个公共方法OnDropdownValueChanged,并将其绑定到Dropdown组件的On Value Changed事件上。
- 运行游戏,选择下拉菜单中的选项,控制台将输出所选选项的文本。
注意事项:
- OnDropdownValueChanged方法的参数value表示当前选择的索引。
示例3:动态添加选项
using UnityEngine;
using UnityEngine.UI;
public class DropdownExample : MonoBehaviour
{
public Dropdown dropdown;
public InputField inputField;
void Start()
{
dropdown.ClearOptions();
dropdown.AddOptions(new List<string> { "Option 1", "Option 2", "Option 3" });
}
public void AddOption()
{
string newOption = inputField.text;
dropdown.options.Add(new Dropdown.OptionData(newOption));
dropdown.RefreshShownValue();
}
}
操作步骤:
- 创建一个空物体,并将Dropdown组件添加到该物体上。
- 将DropdownExample脚本添加到该物体上。
- 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
- 创建一个InputField组件,并将其引用拖拽到DropdownExample脚本的inputField字段上。
- 在DropdownExample脚本中,创建一个公共方法AddOption,并将其绑定到一个按钮的OnClick事件上。
- 运行游戏,输入一个新选项的文本,点击按钮,下拉菜单中将添加一个新选项。
注意事项:
- AddOption方法通过inputField获取新选项的文本,并使用dropdown.options.Add方法添加新选项。
- 添加新选项后,需要调用dropdown.RefreshShownValue方法刷新下拉菜单的显示。
示例4:设置默认选项
using UnityEngine;
using UnityEngine.UI;
public class DropdownExample : MonoBehaviour
{
public Dropdown dropdown;
void Start()
{
dropdown.ClearOptions();
dropdown.AddOptions(new List<string> { "Option 1", "Option 2", "Option 3" });
dropdown.SetValueWithoutNotify(1);
}
}
操作步骤:
- 创建一个空物体,并将Dropdown组件添加到该物体上。
- 将DropdownExample脚本添加到该物体上。
- 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
- 在Start函数中,使用dropdown.SetValueWithoutNotify方法设置默认选项的索引。
- 运行游戏,下拉菜单中将默认选择第二个选项。
注意事项:
- SetValueWithoutNotify方法用于设置当前选择的值,但不触发On Value Changed事件。
示例5:自定义下拉菜单模板
using UnityEngine;
using UnityEngine.UI;
public class DropdownExample : MonoBehaviour
{
public Dropdown dropdown;
public GameObject customTemplate;
void Start()
{
dropdown.ClearOptions();
dropdown.AddOptions(new List<string> { "Option 1", "Option 2", "Option 3" });
dropdown.template = customTemplate.transform as RectTransform;
}
}
操作步骤:
- 创建一个空物体,并将Dropdown组件添加到该物体上。
- 创建一个空物体作为自定义模板,设置其布局和样式。
- 将DropdownExample脚本添加到第一个物体上。
- 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
- 将自定义模板的引用拖拽到DropdownExample脚本的customTemplate字段上。
- 运行游戏,下拉菜单将使用自定义模板进行显示。
注意事项:
- 自定义模板需要是一个RectTransform组件。
参考资料
- Unity官方文档:Dropdown
Unity UGUI的Dropdown(下拉菜单)组件的介绍及使用的更多相关文章
- 详解Bootstrap下拉菜单组件
bootstrap框架中的下拉菜单组件是一个独立的组件,根据不同的版本,他对应的文件: less 对应的源码文件为:dropdowns.less sass对应的源码文件为:_dropdowns.scs ...
- JS列表的下拉菜单组件(仿美化控件select)
JS列表的下拉菜单组件(仿美化控件select) 2014-01-23 23:51 by 龙恩0707, 1101 阅读, 6 评论, 收藏, 编辑 今天是农历23 也是小年,在这祝福大家新年快乐!今 ...
- 巧用CSS3 :target 伪类制作Dropdown下拉菜单(无JS)
:target 是CSS3 中新增的一个伪类,用以匹配当前页面的URI中某个标志符的目标元素(比如说当前页面URL下添加#comment就会定位到id=“comment”的位置,俗称锚).CSS3 为 ...
- dropdown下拉菜单
<!--声明方式的下拉菜单:三个要点--> <!--1 外围容器用dropdown包裹--> <!--2 内部点击事件data-toggle--> <!--3 ...
- 巧用CSS3:target 伪类制作Dropdown下拉菜单(无JS)
原文链接:http://devework.com/css3-target-dropdown.html :target 是CSS3 中新增的一个伪类,用以匹配当前页面的URI中某个标志符的目标元素(比如 ...
- bootstrap的下拉菜单组件与导航条
前期准备:bootstrap的css文件和js文件先引入 Bootstrap 组件-拉下菜单(class+js) 下拉菜单必需三级结构 <div class="dropdown&quo ...
- Dropdown 下拉菜单
将动作或菜单折叠到下拉菜单中. 基础用法 移动到下拉菜单上,展开更多操作. 通过组件slot来设置下拉触发的元素以及需要通过具名slot为dropdown 来设置下拉菜单.默认情况下,下拉按钮只要ho ...
- 微信小程序 - 下拉菜单组件
使用: 1.导入组件 2.使用组件 3.数据传入 4. 获取数据(通过同步缓存,获取“choose”)- 发送到后端 点击下载:小程序-下拉组件.
- Java Swing实战(二)下拉菜单组件JComboBox及其事件监听
接下来给"数据源配置"面板添加下拉框. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public class Weimi ...
- Element-UI ( Dropdow )下拉菜单组件command传输对象
通过 :command绑定对象数据,handleCommand方法处理数据 template <div v-for="(item, index) in FlyWarningList&q ...
随机推荐
- 开源 API 网关-访问策略(二)
在上篇文章API网关:开源 API 网关-访问策略(一) 中,我们简单演示了如何在IP维度中对请求路径设置黑白名单,以此来限制客户端请求的权限和范围. 此外,Apinto网关为客户端提供了一种统一的. ...
- 【python基础】函数-初识函数
函数是带名字的代码块,用于完成具体的工作,无需反复编写完成该工作的代码.之前我们接触过print函数,数据类型转换中的int函数.str函数,还有列表中的append函数.pop函数.remove函数 ...
- Flutter状态管理新的实践
1 背景介绍 1.1 声明式ui 声明式UI其实并不是近几年的新技术,但是近几年声明式UI框架非常的火热.单说移动端,跨平台方案有:RN.Flutter.iOS原生有:SwiftUI.android原 ...
- LLE算法的应用场景和案例:详解LLE算法在实际问题中的效果和表现
目录 引言 随着深度学习技术的不断发展,神经网络模型在人工智能领域的应用越来越广泛.其中,LLE(Largely Element-wise Linear) 神经网络是一种常用的神经网络模型,其基本思想 ...
- 【大数据OLAP技术新书推荐】 字节跳动、阿里巴巴大厂资深架构师程序员多年实践经验总结《ClickHouse入门、实战与进阶》
ClickHouse 领域集大成之作-ClickHouse 入门进阶实战的标准参考书-日常工作案头必备! 如果需要购买阅读的话,可以点击: https://item.jd.com/1007763561 ...
- Django容易被遗忘却无比重要的框架默认文件介绍及使用方法
在Python Web开发领域,Django框架的地位犹如璀璨的明星,其全面.高效和安全的特性使其在全球范围内广受欢迎.本文将全面解析Django框架的默认文件,并深入探讨每个文件及其组成的意义和用途 ...
- html实现原生table并设置表格边框的两种方式
虽然第三方表格插件多不胜数,但是很多场景还是需要用到原生<table>,掌握html原生table的实现方法,是前端开发的必备技能.例如:print-js打印.html2canvas生成图 ...
- List去除重复数据的五种方式
来自:CSDN,作者:多纤果冻 链接:https://blog.csdn.net/qq_37939251/article/details/90713643 以下介绍五种-不同的方法去除 Java 中A ...
- CF1580C Train Maintenance题解
我们以 \(\sqrt m\) 为分界点来进行平衡. 设当前在进行第 \(k\) 次操作,询问 \(i\). 对于 \(x_i + y_i \leq \sqrt m\),可以在 \(last_{x_i ...
- ubuntu22.04安装vsftp遇到的问题
问题 FileZilla连接文件服务器时出现"无法读取文件目录",随后出现"20秒后无活动,连接超时"."无法连接到服务器"文件目录无法读取 ...