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" });
}
}

操作步骤

  1. 创建一个空物体,并将Dropdown组件添加到该物体上。
  2. 将DropdownExample脚本添加到该物体上。
  3. 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
  4. 运行游戏,下拉菜单中将显示"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);
}
}

操作步骤

  1. 创建一个空物体,并将Dropdown组件添加到该物体上。
  2. 将DropdownExample脚本添加到该物体上。
  3. 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
  4. 在DropdownExample脚本中,创建一个公共方法OnDropdownValueChanged,并将其绑定到Dropdown组件的On Value Changed事件上。
  5. 运行游戏,选择下拉菜单中的选项,控制台将输出所选选项的文本。

注意事项

  • 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();
}
}

操作步骤

  1. 创建一个空物体,并将Dropdown组件添加到该物体上。
  2. 将DropdownExample脚本添加到该物体上。
  3. 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
  4. 创建一个InputField组件,并将其引用拖拽到DropdownExample脚本的inputField字段上。
  5. 在DropdownExample脚本中,创建一个公共方法AddOption,并将其绑定到一个按钮的OnClick事件上。
  6. 运行游戏,输入一个新选项的文本,点击按钮,下拉菜单中将添加一个新选项。

注意事项

  • 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);
}
}

操作步骤

  1. 创建一个空物体,并将Dropdown组件添加到该物体上。
  2. 将DropdownExample脚本添加到该物体上。
  3. 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
  4. 在Start函数中,使用dropdown.SetValueWithoutNotify方法设置默认选项的索引。
  5. 运行游戏,下拉菜单中将默认选择第二个选项。

注意事项

  • 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;
}
}

操作步骤

  1. 创建一个空物体,并将Dropdown组件添加到该物体上。
  2. 创建一个空物体作为自定义模板,设置其布局和样式。
  3. 将DropdownExample脚本添加到第一个物体上。
  4. 在Inspector面板中,将Dropdown组件的引用拖拽到DropdownExample脚本的dropdown字段上。
  5. 将自定义模板的引用拖拽到DropdownExample脚本的customTemplate字段上。
  6. 运行游戏,下拉菜单将使用自定义模板进行显示。

注意事项

  • 自定义模板需要是一个RectTransform组件。

参考资料

Unity UGUI的Dropdown(下拉菜单)组件的介绍及使用的更多相关文章

  1. 详解Bootstrap下拉菜单组件

    bootstrap框架中的下拉菜单组件是一个独立的组件,根据不同的版本,他对应的文件: less 对应的源码文件为:dropdowns.less sass对应的源码文件为:_dropdowns.scs ...

  2. JS列表的下拉菜单组件(仿美化控件select)

    JS列表的下拉菜单组件(仿美化控件select) 2014-01-23 23:51 by 龙恩0707, 1101 阅读, 6 评论, 收藏, 编辑 今天是农历23 也是小年,在这祝福大家新年快乐!今 ...

  3. 巧用CSS3 :target 伪类制作Dropdown下拉菜单(无JS)

    :target 是CSS3 中新增的一个伪类,用以匹配当前页面的URI中某个标志符的目标元素(比如说当前页面URL下添加#comment就会定位到id=“comment”的位置,俗称锚).CSS3 为 ...

  4. dropdown下拉菜单

    <!--声明方式的下拉菜单:三个要点--> <!--1 外围容器用dropdown包裹--> <!--2 内部点击事件data-toggle--> <!--3 ...

  5. 巧用CSS3:target 伪类制作Dropdown下拉菜单(无JS)

    原文链接:http://devework.com/css3-target-dropdown.html :target 是CSS3 中新增的一个伪类,用以匹配当前页面的URI中某个标志符的目标元素(比如 ...

  6. bootstrap的下拉菜单组件与导航条

    前期准备:bootstrap的css文件和js文件先引入 Bootstrap 组件-拉下菜单(class+js) 下拉菜单必需三级结构 <div class="dropdown&quo ...

  7. Dropdown 下拉菜单

    将动作或菜单折叠到下拉菜单中. 基础用法 移动到下拉菜单上,展开更多操作. 通过组件slot来设置下拉触发的元素以及需要通过具名slot为dropdown 来设置下拉菜单.默认情况下,下拉按钮只要ho ...

  8. 微信小程序 - 下拉菜单组件

    使用: 1.导入组件 2.使用组件 3.数据传入 4. 获取数据(通过同步缓存,获取“choose”)- 发送到后端 点击下载:小程序-下拉组件.

  9. Java Swing实战(二)下拉菜单组件JComboBox及其事件监听

    接下来给"数据源配置"面板添加下拉框. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public class Weimi ...

  10. Element-UI ( Dropdow )下拉菜单组件command传输对象

    通过 :command绑定对象数据,handleCommand方法处理数据 template <div v-for="(item, index) in FlyWarningList&q ...

随机推荐

  1. web自动化04-css定位

    css元素定位 1. 是什么? 用来描述html元素的显示样式 选择器是一种模式,用于选择需要添加样式的元素   selenium中推荐使用css定位,比XPath定位要快    2.如何定位?   ...

  2. 让你的代码动起来:Python进度条神器tqdm详解及应用实例

    各位Python高手,今天我要给大家介绍一个好用的库,它就是:tqdm tqdm在阿拉伯语中的意思是 "进展",所以这个库也被称为 "快速进展条".不得不说,这 ...

  3. 慢 SQL 优化之索引的作用是什么?

    前言 本文针对 MySQL 数据库的 InnoDB 存储引擎,介绍其中索引的实现以及索引在慢 SQL 优化中的作用. 本文主要讨论不同场景下索引生效与失效的原因. 慢SQL与索引的关系 慢SQL优化原 ...

  4. WPF中关于转换器

    实例:关于播放器按钮状态的改变 说明:对Kind(种类)的绑定首先在viewmodel中声明一个属性IsPlay,然后在转换器中实现按钮的状态 转换器 在解决方案中的项目里新建一个Converters ...

  5. K8S 证书详解(认证)

    K8S 证书介绍 在 Kube-apiserver 中提供了很多认证方式,其中最常用的就是 TLS 认证,当然也有 BootstrapToken,BasicAuth 认证等,只要有一个认证通过,那么 ...

  6. 文字生成图像 AI免费工具第二弹 DreamStudio

    介绍Stable Diffution,就也要提一下DreamStudio,它是Stable Diffusion的母公司Stability AI开发的一个文字生成图像工具,邮箱注册后可以免费生成125张 ...

  7. 流程挖掘里程碑:国产RPA首次入选顶级行业报告

    正在成为组织运营标配的流程挖掘,到底有哪些商业价值? 作为超级自动化的重要先驱,流程挖掘正在成为组织运营标配 文/王吉伟 AIGC正在影响越来越多的行业,流程挖掘领域亦不例外. Mindzie首先宣布 ...

  8. 知识图谱之《海贼王-ONEPICE》领域图谱项目实战(含码源):数据采集、知识存储、知识抽取、知识计算、知识应用、图谱可视化、问答系统(KBQA)等

    知识图谱之<海贼王-ONEPICE>领域图谱项目实战(含码源):数据采集.知识存储.知识抽取.知识计算.知识应用.图谱可视化.问答系统(KBQA)等 实体关系可视化页面可视化页面尝鲜 1. ...

  9. 规则引擎 ice

    目录 项目介绍 服务安装 创建数据库(MySQL) 下载安装 服务(启动.停止.重启) 打开后台 Client接入(Spring Boot) 示例 添加配置 新增 ICE liteflow 更适应我们 ...

  10. 文心一言 VS 讯飞星火 VS chatgpt (64)-- 算法导论6.5 3题

    文心一言 VS 讯飞星火 VS chatgpt (64)-- 算法导论6.5 3题 三.要求用最小堆实现最小优先队列,请写出 HEAP-MINIMUM.HEAP-EXTRACT-MIN.HEAP DE ...