Unity排行榜优化滚动效果

作者:接啊是哦ida 时间:2021-09-08 13:02:07 

本文实例为大家分享了Unity排行榜优化滚动效果的具体代码,供大家参考,具体内容如下

自己做的一个优化排行榜的功能,当有大量的数据需要在scroolRect中可以通过只夹在几个item循环利用便可以展示所需的内容;

下面是效果实现图

Unity排行榜优化滚动效果

下面是我的一个中心思想

Unity排行榜优化滚动效果

通过对处在视野第一个Item左上和左下左边点的位置来判断是将最后一个移动到第一个前面,还是将第一个移动到最后一个后面。

用到的我目前来说不太常用的数据结构 LinkedList 方便用于移除第一个和最后一个;

以下是代码


using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;

public class WuXianGunDong : MonoBehaviour
{
   List<string> strs = new List<string>();//需要修改

public int DataTips;

public Transform content;
   public GameObject loopItemPrefab;

Vector3[] viewCorners = new Vector3[4];
   float hight;  //生成的loopItem所占的区域
   int current = -1;
   int itemCount;//生成的Item的数量

public LinkedList<GameObject> loopItems = new LinkedList<GameObject>();

#region 回调
   private void Awake()
   {
       for (int i = 0; i < DataTips; i++)
       {
           strs.Add(i.ToString());
       }

hight = loopItemPrefab.GetComponent<RectTransform>().sizeDelta.y + content.GetComponent<VerticalLayoutGroup>().spacing;

itemCount = (int)(transform.GetComponent<RectTransform>().sizeDelta.y / hight) + 2;

if (itemCount > DataTips)
           itemCount = DataTips;
       for (int i = 0; i < itemCount; i++)
       {
           GameObject obj = Instantiate(loopItemPrefab, content);
           obj.GetComponentInChildren<Text>().text = strs[i];
           loopItems.AddLast(obj);
           current++;
       }
       transform.GetComponent<RectTransform>().GetWorldCorners(viewCorners);
       content.GetComponent<VerticalLayoutGroup>().enabled = true;
   }

private void Start()
   {
       Invoke("DisGrid", 0.1f);
   }
   #endregion

#region 拖拽的时候
   public void OnChange()
   {
       if (DataTips < itemCount)
       {
           return;
       }
       Vector3[] rectCorners = new Vector3[4];
       //当第一个离开视野的时候
       loopItems.First.Value.GetComponent<RectTransform>().GetWorldCorners(rectCorners);
       if (rectCorners[0].y > viewCorners[1].y)
       {
           if (current + 1 < strs.Count)
           {
               current++;
               loopItems.First.Value.transform.GetComponentInChildren<Text>().text = strs[current];
               loopItems.First.Value.GetComponent<RectTransform>().localPosition = loopItems.Last.Value.GetComponent<RectTransform>().localPosition - new Vector3(0, hight, 0);
               loopItems.AddLast(loopItems.First.Value);
               loopItems.RemoveFirst();
           }
       }
       //当最后一个进入视野的时候
       loopItems.First.Value.GetComponent<RectTransform>().GetWorldCorners(rectCorners);
       if (rectCorners[1].y < viewCorners[1].y)
       {
           if (current - itemCount >= 0)
           {
               loopItems.Last.Value.transform.GetChild(0).GetComponent<Text>().text = strs[current - itemCount];
               loopItems.Last.Value.GetComponent<RectTransform>().localPosition = loopItems.First.Value.GetComponent<RectTransform>().localPosition + new Vector3(0, hight, 0);
               loopItems.AddFirst(loopItems.Last.Value);
               loopItems.RemoveLast();
               current--;
           }
       }
   }
   #endregion

public void DisGrid()
   {
       //关闭LayoutGroup
       content.GetComponent<VerticalLayoutGroup>().enabled = false;
       //设置宽度
       content.GetComponent<RectTransform>().sizeDelta = new Vector2(content.GetComponent<RectTransform>().sizeDelta.x, strs.Count * hight);
   }
}

来源:https://blog.csdn.net/weixin_47634555/article/details/106857090

标签:Unity,排行榜,滚动
0
投稿

猜你喜欢

  • spring cloud gateway跨域全局CORS配置方式

    2021-11-02 01:09:00
  • Android 通过自定义view实现水波纹效果案例详解

    2022-01-12 06:03:48
  • 浅谈Action+Service +Dao 功能

    2023-01-04 13:44:20
  • Spring Boot实现分布式锁的自动释放的示例代码

    2023-10-17 11:06:24
  • mybatis plus自动生成代码的示例代码

    2022-03-01 10:00:25
  • c#源码的执行过程详解

    2023-10-01 17:03:37
  • java 获取字节码文件的几种方法总结

    2023-11-29 15:17:57
  • 理解Java中的内存泄露及解决方法示例

    2023-04-24 23:19:51
  • android之datepicker控件的用法

    2021-12-26 04:07:31
  • C# Math中常用数学运算的示例详解

    2023-10-06 23:06:28
  • SpringBoot整合TomCat实现本地图片服务器代码解析

    2021-07-30 16:34:19
  • Android如何实现非本地图片的点击态

    2023-06-16 00:21:16
  • Flutter 队列任务的实现

    2023-07-07 17:25:14
  • java 学习笔记(入门篇)_java程序helloWorld

    2023-02-28 02:53:44
  • dom4j读取XML文件详解

    2022-02-21 09:23:29
  • Java使用Socket简单通讯详解

    2023-11-03 02:54:43
  • 全网最详细Hutool工具详解

    2023-05-04 06:21:53
  • IDEA使用SpringAssistant插件创建SpringCloud项目

    2021-06-06 10:47:46
  • java二维数组实现推箱子小游戏

    2022-08-31 10:18:40
  • OpenGL ES实现光照效果(六)

    2022-06-30 16:08:52
  • asp之家 软件编程 m.aspxhome.com