UGUI交互组件Toggle

一.Toggle对象的构造

Toggle和Button类似,是交互组件的一种

如果所示,通过菜单创建了两个Toggle,Toggle2中更换了背景和标记资源

对象 说明
Toggle 含有Toggle组件的对象
Background 开关背景
Checkmark 开关选中标记
Label 名称文本

二.Toggle组件属性

属性 说明
Is On 开关按钮
Toggle Transition Toggle过渡
Graphic 用来控制 Toggle 开关图片的显示/隐藏
Group 用来表示 Toggle 所属开关组/群(下文会讲到)
On Value Changed 监听事件,值改变时调用

三.事件监听

3.1 可视化监听

注意:事件响应函数需要为单参数才能在这里找到

3.2 代码监听

cs 复制代码
public class CToggle : MonoBehaviour
{
    private Toggle m_Toggle;
    void Start()
    {
        m_Toggle = GameObject.Find("Toggle").GetComponent<Toggle>();
        m_Toggle.onValueChanged.AddListener(delegate (bool isOn)
        {
            ToggleOnValueChanged(isOn);
        });
    }
    public void ToggleOnValueChanged(bool isOn)
    {
        if (isOn)
        {
            Debug.Log("toggle On");
        }
        else
        {
            Debug.Log("toggle off");
        }
    }
}

四.Toggle Group

4.1 开关的两个重要应用场景:页签切换和单选设置

4.2 Toggle Group组件

要实现这样的效果需要使用Toggle Group组件,创建一个空对象,添加Toggle Group组件

Toggle Group组件只有一个属性Allow Switch Off

默认情况下,一组Toggle至少会有一个处于激活状态,如果这个选项不勾选的话,是不可能存在一组内一个Toggle都未激活的。

如果勾选了这个Allow Switch Off就相当于允许本组内的Toggle出现一个都未选中激活的状态。

4.3 Toggle组件的Group属性

将所有Toggle的Group属性设置为GameObject,可以选中所有Toggle然后把GameObject拖进去

接下来运行就变成单选效果了。

4.4 换页效果的一种做法

由于实现简单这里不做过多说明,直接上代码

cs 复制代码
public class CToggle : MonoBehaviour
{
    private Toggle[] allToggle;
    private Image[] allBg;
    void Start()
    {
        allToggle = new Toggle[3];
        allBg = new Image[3];
        for (int i = 0; i < 3; i++)
        {
            int idx = i;
            allToggle[i] = GameObject.Find("Toggle" + i).GetComponent<Toggle>();
            allBg[i] = GameObject.Find("bg" + i).GetComponent<Image>();
            allToggle[i].onValueChanged.AddListener(delegate (bool isOn)
            {
                ToggleOnValueChanged(isOn, idx);
            });
        }
    }
    public void ToggleOnValueChanged(bool isOn, int selectIndex)
    {
        string str = isOn ? " on" : " off";
        Debug.Log("Toggle"+ selectIndex + str);
        if (isOn)
        {
            for (int i = 0; i < allBg.Length; i++)
            {
                allBg[i].gameObject.SetActive(false);
            }
            allBg[selectIndex].gameObject.SetActive(true);
        }
    }
}
相关推荐
NRatel6 小时前
亚马逊S3的使用简记(游戏资源发布更新)
游戏·unity·amazon s3
SmalBox12 小时前
【渲染流水线】[几何阶段]-[屏幕映射]以UnityURP为例
unity·渲染
SmalBox1 天前
【渲染流水线】[几何阶段]-[归一化NDC]以UnityURP为例
unity·渲染
SmalBox2 天前
【渲染流水线】[几何阶段]-[图元装配]以UnityURP为例
unity·渲染
霜绛3 天前
Unity:GUI笔记(一)——文本、按钮、多选框和单选框、输入框和拖动条、图片绘制和框绘制
笔记·学习·unity·游戏引擎
谷宇.3 天前
【Unity3D实例-功能-移动】角色行走和奔跑的相互切换
游戏·unity·c#·unity3d·游戏开发·游戏编程
17岁的勇气3 天前
Unity Shader unity文档学习笔记(十九):粘土效果,任意网格转化成一个球(顶点动画,曲面着色器)
笔记·学习·unity·图形渲染·顶点着色器·曲面着色器
benben0443 天前
《Unity Shader入门精要》学习笔记一
unity·shader
YF云飞3 天前
Unity图片优化与比例控制全攻略
游戏·unity·游戏引擎·游戏程序·个人开发
SmalBox4 天前
【渲染流水线】[几何阶段]-[几何着色]以UnityURP为例
unity·渲染