unity学习56:旧版legacy和新版TMP文本输入框 InputField学习

目录

1 旧版文本输入框 legacy InputField 

1.1 新建一个文本输入框

1.2 InputField 的子物体构成

1.3 input field的的component

1.4 input Field的属性

2 过渡 transition

3 控件导航 navigation

4 占位文本 placeholder

5 文本 text

5.1 文本内容,用户来input

5.2 内容类型 content type

5.3 line type 

5.4  光标 caret相关

5.5 其他

6 相关触发事件

7 代码

7.1 UI相关代码必须先引用  UnityEngine.UI

7.2 声明 InputField类型的变量,然后在unity里拖动和获取到这个控件

7.3  然后再 inputField下面的创建新事件,并关联到脚本的对应函数

7.4 测试代码

8 新版TMP InputField

8.1 子物体的构成,结构有变换,功能差不多

8.2  属性有一些不同,大部分相同

8.3 事件不一样

9 新版 TMP InputField 代码差别

9.1 改变,新包 TMPro

9.2 改变,新类型TMP_InputField

9.3 其他绑定方式类似

9.4 代码实测


1 旧版文本输入框 legacy InputField 

1.1 新建一个文本输入框

1.2 InputField 的子物体构成

主物体/主控件 InputField 下面包含2个文本

  1. 一个是place holder  //占位文本
  2. 一个是text               //就是用户输入时的显示文本

1.3 input field的的component

  • rect transform
  • canvas render
  • image
  • input Field

1.4 input Field的属性

  • actable 可交互性
  • 如果不可交互,就无法选中了,类纯看的图片

2 过渡 transition

  • 过渡 transition
  • 类前面的button

3 控件导航 navigation

  • 多个控件之间的导航,类前面的button
  • 没仔细看,以后再说

4 占位文本 placeholder

  • 点击 placeholder  会跳转到子物体placeholder 
  • 然后在placeholder  上面修改文本内容

5 文本 text

5.1 文本内容,用户来input

  • 就是用户的文本输入的内容
  • 注意是用户来input
  • 一般这里不应该填写内容,如果填写了就会覆盖 place holder
  • 而且需要用户自己删掉,可能是提示必须填的文本格式?

  • 虽然不填内容,等用户来填写
  • 但是各种对文本的 控制,都可以提前设置
  • 比如
  • character limit 字符数限制

5.2 内容类型 content type

  • 整数int
  • 小数
  • 密码, 会自动屏蔽为***
  • 字母
  • 电邮
  • 等等

5.3 line type 

5.4  光标 caret相关

5.5 其他

移动时输入会弹出一个键盘?

6 相关触发事件

  • on  value changed
  • on submit
  • on end edit

7 代码

7.1 UI相关代码必须先引用  UnityEngine.UI

  • 开头需要添加
  • using UnityEngine.UI

7.2 声明 InputField类型的变量,然后在unity里拖动和获取到这个控件

  • 脚本中,先声明 public InputField inputField1;
  • 因为这个脚本挂载canvas上面
  • 然后拖动关联到canvas下面的脚本的公共变量上
  • 注意,需要让unity可读到显示,都必须声明为public

7.3  然后再 inputField下面的创建新事件,并关联到脚本的对应函数

  • 然后再 inputField下面的创建新事件 on value changed
  • 把脚本所在的canvas挂上去
  • 从右边找到 脚本,然后找到脚本里的新建的函数 inputTextChanged

7.4 测试代码

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;public class TestUI : MonoBehaviour
{public InputField inputField1;// Start is called before the first frame updatevoid Start(){using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;public class TestUI : MonoBehaviour
{public InputField inputField1;// Start is called before the first frame updatevoid Start(){}// Update is called once per framevoid Update(){}// Update is called once per framepublic void buttonClick(){Debug.Log("buttonClick");}public void InputTextChanged(){Debug.Log("InputTextChanged");Debug.Log(inputField1.text);}}}// Update is called once per framevoid Update(){}// Update is called once per framepublic void buttonClick(){Debug.Log("buttonClick");}public void InputTextChanged(){Debug.Log("InputTextChanged");Debug.Log(inputField1.text);}}

8 新版TMP InputField

8.1 子物体的构成,结构有变换,功能差不多

8.2  属性有一些不同,大部分相同

8.3 事件不一样

  • on value changed
  • on end edit
  • on select
  • on deselect

9 新版 TMP InputField 代码差别

9.1 改变,新包 TMPro

  • using TMPro;
  • 因为TMP使用的包不一样

9.2 改变,新类型TMP_InputField

  • public TMP_InputField inputField2;
  • 文本框的类型,完全不同

9.3 其他绑定方式类似

9.4 代码实测

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/71092.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

汽车电子电控软件开发中因复杂度提升导致的架构恶化问题

针对汽车电子电控软件开发中因复杂度提升导致的架构恶化问题,建议从以下方向进行架构优化和开发流程升级,以提升灵活性、可维护性和扩展性: 一、架构设计与模块化优化 分层架构与模块解耦 采用AUTOSAR标准的分层架构(应用层、运行…

【弹性计算】弹性裸金属服务器和神龙虚拟化(一):功能特点

弹性裸金属服务器和神龙虚拟化(一):功能特点 特征一:分钟级交付特征二:兼容 VPC、SLB、RDS 等云平台全业务特征三:兼容虚拟机镜像特征四:云盘启动和数据云盘动态热插拔特征五:虚拟机…

腾讯云大模型知识引擎驱动的DeepSeek满血版医疗顾问大模型搭建实战

文章目录 1. 引言2. 什么是腾讯云大模型知识引擎(LKE)?核心优势功能特点应用场景 3. 模型搭建过程3.1 注册登录产品3.2 创建应用3.3 配置模型3.4 配置角色指令3.5 配置欢迎语3.6 配置知识库3.7 配置工作流3.8 启用联网搜索3.9 发布模型 4. 问…

nio中ByteBuffer使用

创建ByteBuffer ByteBuffer buffer ByteBuffer.allocate(10);// 字符串转 bytebufferByteBuffer buffer01 Charset.defaultCharset().encode("hello world"); ByteBuffer buffer02 ByteBuffer.wrap("hello".getBytes()); ByteBuffer buffer03 Standard…

如何在 IntelliJ IDEA 中集成 DeepSeek

如何在 IntelliJ IDEA 中集成 DeepSeek 在本教程中,我们将带您一步步完成将 DeepSeek 集成到 IntelliJ IDEA 中的过程。通过此集成,您可以在IDE中利用DeepSeek强大的功能,提高开发工作效率。 步骤 1:安装 Proxy AI 插件 首先&a…

【Maven】入门介绍 与 安装、配置

文章目录 一、Maven简介1. Maven介绍2. Maven软件工作原理模型图 二、Maven安装和配置1. Maven安装2. Maven环境配置3. Maven功能配置4. IDEA配置本地Maven软件 一、Maven简介 1. Maven介绍 https://maven.apache.org/what-is-maven.html Maven 是一款为 Java 项目管理构建、…

Java数据结构第十六期:走进二叉树的奇妙世界(五)

专栏:Java数据结构秘籍 个人主页:手握风云 目录 一、非递归实现遍历二叉树 1.1. 二叉树的前序遍历 1.2. 二叉树的中序遍历 1.3. 二叉树的后序遍历 一、非递归实现遍历二叉树 1.1. 二叉树的前序遍历 我们这里要使用栈来进行实现。我们反向思考一下为…

算法004——盛最多水的容器

力扣——盛最多水的容器点击即可跳转 当我们选择1号线和8号线时,下标为 1 和 8 形成容器的容积的高度是由 较矮的决定的,即下标为 8 的位置; 而宽度则是 1到8 之间的距离,为 8-17,此时容器的容积为 7 * 7 49。 当我…

算法-二叉树篇26-将有序数组转换为二叉搜索树

将有序数组转换为二叉搜索树 力扣题目链接 题目描述 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。 解题思路 很简单的遇到递归题目,对数组取半,然后构建中间节点作为该数组对应的…

十一、Spring Boot:使用JWT实现用户认证深度解析

Spring Boot JWT(JSON Web Token):无状态认证 在现代 Web 开发中,无状态认证是一种重要的安全机制,它允许服务器在不存储会话信息的情况下验证用户身份。JSON Web Token(JWT)是一种常用的无状态…

MIT何恺明再次突破传统:分形递归架构引爆生成模型新纪元!

论文链接:https://arxiv.org/pdf/2502.17437 代码链接:https://github.com/LTH14/fractalgen 亮点直击 分形生成模型:首次将分形理论引入生成模型,提出了一种具有自相似性的递归生成框架。 递归模块化:通过递归调用生…

用Python之requests库调用大型语言模型(LLM)API的流式输出与非流式输出比较

文章目录 1. 非流式输出与流式输出概述2. 非流式输出2.1 代码实例12.2 代码实例2 3. 流式输出3.1 流式输出的定义和作用3.2 流式输出适用的场景3.3 流式输出的实现方式与实现技术3.4 代码实例33.5 代码实例4 4. 小结 1. 非流式输出与流式输出概述 大模型收到输入后并不是一次性…

大模型技术:重塑未来的力量

大模型技术之所以成为当今科技领域的热点,是因为它拥有改变游戏规则的能力。以ChatGPT为例,这款由OpenAI开发的大型语言模型,首次实现了基于语言的智能涌现,推动了通用人工智能的技术飞跃和快速进化。大模型通过强大的数据处理能力…

【朝夕教育】《鸿蒙原生应用开发从零基础到多实战》005-TypeScript 中的枚举

标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主&…

框架模块说明 #09 日志模块_02

背景 上篇我们介绍了系统日志处理方式,也结合我们实际和日志系统集成的需求,将我们的日志文件配置成json格式。这次我们针对我们操作日志的处理进行一些介绍。 还是采用传统的aop的形式进行操作日志的保存,并按业务类型进行定义保存到mongodb…

DeepSeek-R1自写CUDA内核跑分屠榜:开启GPU编程自动化新时代

引言 在AI领域,深度学习模型的性能优化一直是研究者们关注的核心。最近,斯坦福和普林斯顿的研究团队发现,DeepSeek-R1生成的自定义CUDA内核不仅超越了OpenAI的o1和Claude 3.5 Sonnet,还在KernelBench框架中取得了总排名第一的好成…

记Android12上一个原生bug引起的system_server crash

欢迎使用Markdown编辑器 一. 现象描述 近日测试上报一个几乎必现的crash,描述如下: 现象: launcher编辑状态与锁屏解锁交互时系统概率性重启 操作步骤: 进入launcher组件编辑状态按电源键灭屏后亮屏,锁屏界面上滑解锁launcher编辑状态向右或向左滑动重…

系统架构设计师—计算机基础篇—计算机体系结构

文章目录 计算机硬件分级存储体系目的特点 硬件组成CPU运算器控制器 主存储器 指令系统流水线 内存按字节编址磁盘阵列 计算机硬件 分级存储体系 寄存器组(CPU)Cache(内存)主存Flash(外存/辅存) 目的 解…

Qt基于等待条件QWaitCondition实现的任务队列模型示例

核心概念 Qt中的QWaitCondition是一个用于多线程同步的类,允许线程在某些条件满足时唤醒其他等待的线程。它通常与QMutex配合使用,协调线程之间的执行顺序,适用于生产者-消费者模型、任务队列调度等场景。 ​wait():使当前线程进…

JAVA实战开源项目:安康旅游网站(Vue+SpringBoot) 附源码

本文项目编号 T 098 ,文末自助获取源码 \color{red}{T098,文末自助获取源码} T098,文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…