Unity3D 为UGUI InputField添加滑动条

Unity3D 为UGUI InputField添加滑动条

1.先创建一个Scroll View,把横向拖拽条删掉,其他的根据喜好自己设定
请添加图片描述2.Scroll View设置要修改一下,否则子物体位置会有问题
请添加图片描述3.在Content下创建一个InputField再把它撑满设置得很长
请添加图片描述4.把两个子物体也撑满,防止位置有问题
请添加图片描述5.设置InputField为多行并且回车可换行
请添加图片描述6.给Content添加Text组建和ContentSizeFitter,并且Text的参数要和InputField用于子物体的Text参数一样。(InputField无法字适应,我们用一个看不到的Text自适应用来给Scroll View拖拽。而把InputField设置的非常长(也可以写代码根据需求动态修改))
请添加图片描述7.最后要写一个小脚本,让InputField的输入value改变时实时传到Content的Text,如下:

using UnityEngine;
using UnityEngine.UI;

public class InputFieldToContent : MonoBehaviour
{
    private static readonly string no_breaking_space = "\u00A0";
    
    InputField m_InputField;
    Text m_Text;
    void Start()
    {
        m_InputField = GetComponent<InputField>();
        m_Text = transform.parent.GetComponent<Text>();
        m_InputField.onValueChanged.AddListener((value) =>
        {
            //替换空格编码格式
            m_InputField.text = m_InputField.text.Replace(" ", no_breaking_space);

            m_Text.text = m_InputField.text;
        });
    }
}

8.拖到InputField上。

在这里插入图片描述结果
请添加图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值