UGUI的InputField(输入框)组件的介绍及使用

1. 什么是UGUI的InputField组件?

UGUI的InputField组件是Unity中的一个用户界面组件,用于接收用户的输入。它可以用于创建文本输入框、密码输入框等功能。

2. UGUI的InputField组件的工作原理

UGUI的InputField组件通过监听用户的输入事件,用户将输入的内容保存在一个字符串中,并将该字符串显示在输入框中。用户可以通过键盘输入、鼠标点击等方式进行输入。

.3 UGUI的Input组Field件的常用属性

  • text: 输入框中显示的文本内容。
  • placeholder: 输入框中未输入内容时显示的占位符文本。
  • characterLimit: 输入框中可输入的最大数字符限制。

    -contentType: 输入框中可输入的内容类型,如整数、小数、密码等。
  • onValueChanged: 输入框内容改变时触发的事件。

4. UGUI的InputField组件的

函数用常- ActivateInputField(): 激活输入框,使其可以接收用户输入。

  • DeactivateInputField(): 取消激活输入框,使其无法接收用户输入。
  • OnSubmit(): 用户按下回车键或点击提交按钮时触发的事件。

5. 示例代码

示例1:创建一个简单的文本输入框

using UnityEngine;
using UnityEngine.UI; public class Example : MonoBehaviour
{
public InputField inputField; private void Start()
{
inputField.onValueChanged.AddListener(OnInputValueChanged);
} private void OnInputValueChanged(string value)
{
Debug.Log("输入框内容改变:" + value);
}
}

操作步骤:

  1. 创建一个空物体,并将脚本Example挂载到该物体上。
  2. 在场景中创建一个InputField对象,并将其拖拽到Example脚本的inputField字段中。
  3. 运行游戏,输入框中输入内容,观察控制台输出。

事注意项:

  • 示例代码中的OnInputValueChanged方法会在输入框内容改变时被调用。

示例2:限制输入框中的字符数

using UnityEngine;
using UnityEngine.UI; public class Example : MonoBehaviour
{
public InputField inputField;
public int maxCharacterLimit = 10; private void Start()
{
inputField.characterLimit = maxCharacterLimit;
}
}

操作步骤:1

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

2. 在场景中创建一个InputField对象,并将其拖拽到Example脚本的inputField字段中。

3. 将maxCharacterLimit的值设置为想要限制的最大字符数。

4. 运行游戏,输入框中输入超过最大字符数的内容,观察输入框中的字符数是否受限制。

注意事项:

  • 示例代码中的maxLimitCharacter变量控制了输入框中可输入的最大字符数。

示例3:创建一个密码输入框

using UnityEngine;
using UnityEngine.UI; public class Example : MonoBehaviour
{
public InputField inputField; private void Start()
{
inputField.contentType = InputField.ContentType.Password;
}
}

操作步骤

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

2. 在场景中创建一个InputField对象,并将拖其拽到Example脚本的inputField字段中。

3. 运行游戏,输入中框输入内容,观察输入框中的显示效果。

注意事项:

  • 示例代码中的contentType属性设置为Password,表示输入框中的内容将以密码形式显示。

示例4:动态改变输入框的占位符文本

using UnityEngine;
using UnityEngine.UI; public class Example : MonoBehaviour
{
public InputField inputField;
public string placeholderText = "请输入内容"; private void Start()
{
inputField.placeholder.GetComponent<Text>().text = placeholderText;
}
}

操作步骤:

  1. 创建一个空物体,并将脚本Example挂载到该物上体。
  2. 在场景中创建一个InputField对象,并将其拖到拽Example脚本的inputField字段中。
  3. 将placeholderText的值设置为想要显示的占位符文本。
  4. 运行游戏,观察输入框中的占位符文本是否改变。

注意事项:

  • 示例代码中的placeholderText变量控制了输入框中的占位符文本。

示例5:监听用户按下回车键的事件

using UnityEngine;
using UnityEngine.UI; public class Example : MonoBehaviour
{
public InputField inputField; private void Start()
{
inputField.onEnd.AddListenerEdit(OnInputEndEdit);
} private void OnInputEndEdit(string value)
{
Debug.Log("用户按下回键车:" + value);
}
}

操作步骤:

  1. 创建一个空物体,并将脚本Example挂载到该物体上。
  2. 在场景中创建一个InputField对象,并将其拖拽到Example脚本的inputField字段中。
  3. 运行游戏,输入框中输入内容,按下回车键,观察控制台输出。

注意事项:

  • 示例代码中的EndInputOnEdit方法会在用户按下回车时键被用调。

参考资料

Unity UGUI的InputField(输入框)组件的介绍及使用的更多相关文章

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

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

  2. 关于 Unity UGUI 中修改 Mask 组件下 Image 等子节点组件的材质无效的问题

    前几天同事做了一个效果,希望在原本使用了遮罩组件 Mask 的技能图标(让技能图标变成圆形)上在添加一个置灰的功能,但问题来了:因为是动态根据游戏中玩家的条件才动态置灰,以修改 Mask 下子节点 I ...

  3. Unity UGUI —— 无限循环List

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

  4. Unity UGUI

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

  5. Unity UGUI图文混排源码(三) -- 动态表情

    这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章 Unity UGUI图文混排源码(二):http://blog.csdn. ...

  6. Unity UGUI图文混排源码(二)

    Unity UGUI图文混排源码(一):http://blog.csdn.net/qq992817263/article/details/51112304 Unity UGUI图文混排源码(二):ht ...

  7. Unity UGUI实现图文混排

    目前在unity实现图文混排的好像都是通过自定义字体然后在文本获取字符的位置,用图片替换掉图片标签,这样对于支持英文来说,并没有什么影响.然后对于中文来说就是一个相当麻烦的事了,毕竟图文混排多用于游戏 ...

  8. Unity Jobsystem 详解实体组件系统ECS

    原文摘选自Unity Jobsystem 详解实体组件系统ECS 简介 随着ECS的加入,Unity基本上改变了软件开发方面的大部分方法.ECS的加入预示着OOP方法的结束.随着实体组件系统ECS的到 ...

  9. unity ugui Toggle Group详解(Chinar出品、简单易懂)

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

  10. 【Unity】4.1 创建组件

    分类:Unity.C#.VS2015 创建日期:2016-04-05 一.简介 组件(Component)在Unity游戏开发工作中非常重要,可以说是实现一切功能所必需的. 1.游戏对象(Game O ...

随机推荐

  1. 常用设计模式之.Net示例代码合集

    每一次初学者粉丝朋友,在后台向我咨询编程问题,我除了给他们指导学习路线,我都会建议他们学完基础知识后,一定要要注重编程规范,学习设计模式,修炼内功. 虽然说很多程序员,他们日常主要工作是CRUD,但是 ...

  2. 1406, "Data too long for column 'od_seq' at row 1"

    问题描述:1406, "Data too long for column 'od_seq' at row 1" 问题分析:录入数据长度超出字段的最大限制 解决方法:增加max_le ...

  3. 【故障公告】博客站点一台阿里云负载均衡被DDoS攻击

    13:06 收到阿里云的电话与邮件通知,博客站点的一台阿里云负载均衡因被 DDoS 攻击被关进黑洞(所有访问被屏蔽),部分用户的访问受影响,由此给您带来麻烦,请您谅解. 您的IP:x.x.x.x 实例 ...

  4. 【GiraKoo】Android Studio控制台乱码

    [GiraKoo]Android Studio控制台乱码 启动Android Studio进行编译时,可能会遇到控制台出现异常的乱码. 本文介绍该情况的解决方案. ����: δ������쳣���� ...

  5. PlayWright(二)

      上篇我们已经安装好了playwright和各个浏览器,那么现在我们直接开始吧   1.怎么使用palywright?   我们需要先导入sync_playwright,然后用start启动,sto ...

  6. CIO视角|平台工程带来的优势与机遇

    在当今高速发展的技术环境中,企业越来越依赖技术作为创新和竞争优势的战略驱动力.首席信息官(CIO)在企业中负责监督信息和计算机技术的管理和实施,以交付预期的业务成果.在技术是业务核心的公司中,CIO ...

  7. .NET周报 【5月第4期 2023-05-27】

    国内文章 C#使用词嵌入向量与向量数据库为大语言模型(LLM)赋能长期记忆实现私域问答机器人落地之openai接口平替 https://www.cnblogs.com/gmmy/p/17430613. ...

  8. PHP反序列化字符逃逸 学习记录

    PHP反序列化字符逃逸的原理 当开发者使用先将对象序列化,然后将对象中的字符进行过滤, 最后再进行反序列化.这个时候就有可能会产生PHP反序列化字符逃逸的漏洞. 详解PHP反序列化字符逃逸 过滤后字符 ...

  9. WFP必须掌握的技能之自定义控件——实战:自制上传文件显示进度按钮

    自定义控件在WPF开发中是很常见的,有时候某些控件需要契合业务或者美化统一样式,这时候就需要对控件做出一些改造. 目录 按钮设置圆角 按钮上传文件相关定义 测试代码 话不多说直接看效果 默认效果: 上 ...

  10. 基于FFMPEG+SDL的简单的视频播放器分析

    基于FFMPEG+SDL的简单的视频播放器分析 前言 最近看了雷霄骅前辈的博客<最简单的基于FFMPEG+SDL的视频播放器 ver2 (采用SDL2.0)>,参照他的代码,在window ...