unity实现无限列表功能

 更新时间:2020年04月17日 14:52:47   作者:贪玩的孩纸时代  
这篇文章主要介绍了unity实现无限列表功能,水平方向,竖直方向滑动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了unity实现无限列表功能的具体代码,供大家参考,具体内容如下

public static class RectTransformExtensions
 {
  public static bool Overlaps(this RectTransform a, RectTransform b)
  {
   return a.WorldRect().Overlaps(b.WorldRect());
  }
  public static bool Overlaps(this RectTransform a, RectTransform b, bool allowInverse)
  {
   return a.WorldRect().Overlaps(b.WorldRect(), allowInverse);
  }
 
  public static Rect WorldRect(this RectTransform rectTransform)
  {
   Vector2 sizeDelta = rectTransform.sizeDelta;
   float rectTransformWidth = sizeDelta.x * rectTransform.lossyScale.x;
   float rectTransformHeight = sizeDelta.y * rectTransform.lossyScale.y;
 
   Vector3 position = rectTransform.position;
 
   return new Rect(
    position.x - rectTransformWidth * rectTransform.pivot.x,
    position.y - rectTransformHeight * rectTransform.pivot.y,
    rectTransformWidth,
    rectTransformHeight);
  }
  /// <summary>
  /// 
  /// </summary>
  /// <param name="rectTransform"></param>
  /// <param name="pos">世界坐标的position</param>
  /// <returns></returns>
  public static Rect WorldRect2(this RectTransform rectTransform, Vector3 pos)
  {
   Rect rect = new Rect();
   Vector2 sizeDelta = rectTransform.sizeDelta;
   float rectTransformWidth = sizeDelta.x * rectTransform.lossyScale.x;
   float rectTransformHeight = sizeDelta.y * rectTransform.lossyScale.y;
 
   Vector3 position = pos;
 
   rect.x = position.x - rectTransformWidth * rectTransform.pivot.x;
   rect.y = position.y - rectTransformHeight * rectTransform.pivot.y;
   rect.width = rectTransformWidth;
   rect.height = rectTransformHeight;
 
   return rect;
  }
 }

以上拓展方法是判断两个Recttransform类型的物体是否相交。

然后ScrollRec的滑动回调方法中更新UI位置,代码如下

private void OnScrollRectValueChanged(Vector2 arg0)
  {
   Dictionary<int, DynamicRect> inOverlaps = new Dictionary<int, DynamicRect>();
 
   mRectMask = 遮罩物体的RectTransform.WorldRect();
   //m_DynamicRectDic这个字典保存的是你所有UI需要放置的位置数据,
   //判断所有UI哪个是可见哪个不可见 ,保存起来
   foreach (DynamicRect dR in m_DynamicRectDic.Values)
   {
    tmpTra.localPosition = dR.localPos;
    //获取每个位置UI的世界坐标Rect
    Rect rect = m_LevelItemPrefabRT.WorldRect2(tmpTra.position);
    if (rect.Overlaps(mRectMask))
    {
     inOverlaps.Add(dR.Index, dR);
    }
   }
   //m_LevelItemList是保存你实例化后的UI列表,比如你这个遮罩页面最多显示3个UI,你需要实例化4个UI,然后动态修改gameobject的显示与隐藏
   int len = m_LevelItemList.Count;
   for (int i = 0; i < len; ++i)
   {
    //LevelItem是UI上挂载的脚本,用于更新UI界面的显示和数据存储的
    LevelItem item = m_LevelItemList[i];
    if (item.DRect != null && !inOverlaps.ContainsKey(item.DRect.Index))
    {
     //item的DRect为null时,隐藏物体,否则显示物体
     item.DRect = null;
    }
   }
   //判断哪些可以重复利用的UI,然后赋予新的数据与位置
   foreach (DynamicRect dR in inOverlaps.Values)
   {
    if (GetDynmicItem(dR) == null)
    {
     LevelItem item = GetNullDynmicItem();
 
     if (item == null) continue;
 
     item.DRect = dR;
     //更新UI的位置和显示(自己计算,每种显示不一样)
     _UpdateChildTransformPos(item.gameObject, dR.Index);
    }
   }
  }
 
  /// <summary>
  /// 通过动态格子获得动态渲染器
  /// </summary>
  /// <param name="rect"></param>
  /// <returns></returns>
  private LevelItem GetDynmicItem(DynamicRect rect)
  {
   int len = m_LevelItemList.Count;
   for (int i = 0; i < len; ++i)
   {
    LevelItem item = m_LevelItemList[i];
    if (item.DRect == null)
     continue;
    if (rect.Index == item.DRect.Index)
     return item;
   }
   return null;
  }
  /// <summary>
  /// 获得待渲染的渲染器
  /// </summary>
  /// <returns></returns>
  private LevelItem GetNullDynmicItem()
  {
   int len = m_LevelItemList.Count;
   for (int i = 0; i < len; ++i)
   {
    LevelItem item = m_LevelItemList[i];
    if (item.DRect == null)
     return item;
   }
 
   return null;
  }
 
 public class DynamicRect
 {
  /// <summary>
  /// 本地坐标
  /// </summary>
  public Vector3 localPos;
  /// <summary>
  /// 格子索引
  /// </summary>
  public int Index;
 
  public DynamicRect(int index, Vector3 localPos)
  {
   this.Index = index;
   this.localPos = localPos;
  }
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C#并查集(union-find)算法详解

    C#并查集(union-find)算法详解

    本文详细讲解了C#并查集(union-find)算法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • c#动态编译执行对象方法示例 运用映射机制创建对象

    c#动态编译执行对象方法示例 运用映射机制创建对象

    本示例核心技术是运用.NET动态编译技术+.NET映射技术,把一个代码块中的代码,动态编译成程序集后,在运用映射机制,创建对象示例,调用对象方法
    2014-01-01
  • C#动态创建Access数据库及表的方法

    C#动态创建Access数据库及表的方法

    这篇文章主要介绍了C#动态创建Access数据库及表的方法,以实例形式分析了创建access数据库及在access数据库中建表的完整过程,是非常实用的技巧,需要的朋友可以参考下
    2014-12-12
  • c#快速写本地日志方法

    c#快速写本地日志方法

    下面小编就为大家分享一篇c#快速写本地日志方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • C#实现双端队列的示例代码

    C#实现双端队列的示例代码

    双端队列是一种可以在两端扩展或收缩的序列化容器,本文主要介绍了C#实现双端队列的示例代码,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • C# Winform消息通知之系统本地通知local toast notification

    C# Winform消息通知之系统本地通知local toast notification

    这篇文章主要为大家介绍了C# Winform消息通知之系统本地通知local toast notification使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • C#和Java中二维数组区别分析

    C#和Java中二维数组区别分析

    这篇文章主要介绍了C#和Java中二维数组区别分析,主要讲述了二维数组在C#和Java中定义及应用的区别,非常实用,需要的朋友可以参考下
    2014-10-10
  • 关于C#委托三种调用的分享使用

    关于C#委托三种调用的分享使用

    这篇文章主要介绍了关于C#委托三种调用的分享使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • C#使用OpenCvSharp实现透视变换功能

    C#使用OpenCvSharp实现透视变换功能

    这篇文章主要为大家详细介绍了C#如何使用OpenCvSharp实现透视变换的功能,文中的示例代码简洁易懂,具有一定的学习价值,需要的小伙伴可以参考下
    2023-11-11
  • Unity实现攻击范围检测并绘制检测区域

    Unity实现攻击范围检测并绘制检测区域

    这篇文章主要介绍了Unity实现攻击范围检测并绘制检测区域,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04

最新评论