美文网首页NGUINGUI 简单实现
NGUI可展开列表的实现

NGUI可展开列表的实现

作者: 网易数帆 | 来源:发表于2018-09-29 11:07 被阅读6次

本文来自网易云社区

作者:汪毅军

最近使用了NGUI做了下可展开列表,其主要思路如下:首先最外层使用Scroll view以达到滑动效果,然后列表使用UITable进行排列,最后通过点击Item控制Item的显示和隐藏。 效果如下:

Item结构

列表层次结构图如下:

每一个Item下可分为两部分:其中HideItem表示隐藏的部分。剩余的表示一直显示的内容,就比如效果图中的“Item1”,“Item2”等内容。 我们可以根据具体需求提前摆放好Item,或者通过代码动态加载。

功能实现

  • 首先给UITable下的每个Item挂载上点击监听

    [SerializeField]    private UITable _table;    private List<Transform> items;    void Start ()
    {
        items = _table.GetChildList();        for (int i = 0; i < items.Count; i++)
        {
            Transform item=items[i];

            UIEventListener.Get(item.gameObject).onClick = OnItemClick;
        }

        _table.Reposition();

    }
  • 其次定义好打开和关闭操作,需要注意的是,每次打来关闭后,务必调用一下_table.Reposition()以触发UITable去重新排列。

    private void OpenItem(Transform transform)
    {
        transform.Find("HideItem").gameObject.SetActive(true);
    }    private void CloseItem(Transform transform)
    {
        transform.Find("HideItem").gameObject.SetActive(false);
    }    private void ToggleItem(Transform transform)
    {        if (transform.Find("HideItem").gameObject.activeSelf)
        {

            CloseItem(transform);
        }        else
        {
            OpenItem(transform);
        }

    }    private void OnItemClick(GameObject go)
    {//      这里用于关闭其他的Item,视具体需求使用//        for (int i = 0; i < items.Count; i++)//        {//            if(items[i]!=go.transform) CloseItem(items[i]); //            //        }

        ToggleItem(go.transform);
        _table.Reposition();

    }

到此为止,一个最简单的可展开列表就实现了。

网易云免费体验馆,0成本体验20+款云产品! 

更多网易研发、产品、运营经验分享请访问网易云社区


相关文章:
【推荐】 深入浅出“跨视图粒度计算”--3、EXCLUDE表达式

相关文章

  • NGUI可展开列表的实现

    本文来自网易云社区 作者:汪毅军 最近使用了NGUI做了下可展开列表,其主要思路如下:首先最外层使用Scroll ...

  • A022-列表容器之ExpandableListView

    概述 本节课介绍Android中可实现二级可展开收缩列表的ExpandableListView容器,笔者感觉它非常...

  • RecycleView实现多布局可展开列表

    前言 在开发的时候,我们不免会遇到这么一种数据展示,该数据有以下特征: 数据要以列表形式展示 每条数据要分多行展示...

  • RecycleView实现多布局可展开列表

    前言 盗用图一张 今天就来讲讲这种效果的实现逻辑吧。 二.实现原理 2.1 首先看看要展示的原始数据结构 结合上面...

  • classList实现列表展开效果

    类似这样的展开效果 页面打开会开始渲染列表,如果点击其中一个列表 list 需要展开其说明或者备注,那我们就需要用...

  • iOS多级展开列表的实现

    iOS多级展开列表的实现 效果图 用法(类似UITableView) 初始化XDMultTableView 实现数...

  • 18NGUI之背包系统

    NGUI背包系统的制作## 一、背包系统的搭建## 二、格子里面物品(预制物的制作)## 格子里面的物体需要实现可...

  • (JSP)列表展开和收缩实现

    这个页面做的非常完善,涉及知识点也比较多:1.动态给标签添加id2.金额格式化(每3位加逗号)3.外层li拼接的实...

  • css实现列表展开与收起

    列表的展开与收起 大家先开看看这张图: 很多人会说,裤子都脱了,你给我看这个?不就是js点击效果么.... NO!...

  • NGUI背包系统

    NGUI背包系统实现装备的拾取、拖拽,交换以及数量的叠加 步骤一:实现游戏装备的拖拽 首先导入NGUI插件,导入后...

网友评论

    本文标题:NGUI可展开列表的实现

    本文链接:https://www.haomeiwen.com/subject/rquvoftx.html