unity實現(xiàn)無限列表功能
更新時間:2020年04月17日 14:52:47 作者:貪玩的孩紙時代
這篇文章主要介紹了unity實現(xiàn)無限列表功能,水平方向,豎直方向滑動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了unity實現(xiàn)無限列表功能的具體代碼,供大家參考,具體內(nèi)容如下
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的滑動回調(diào)方法中更新UI位置,代碼如下
private void OnScrollRectValueChanged(Vector2 arg0)
{
Dictionary<int, DynamicRect> inOverlaps = new Dictionary<int, DynamicRect>();
mRectMask = 遮罩物體的RectTransform.WorldRect();
//m_DynamicRectDic這個字典保存的是你所有UI需要放置的位置數(shù)據(jù),
//判斷所有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,然后動態(tài)修改gameobject的顯示與隱藏
int len = m_LevelItemList.Count;
for (int i = 0; i < len; ++i)
{
//LevelItem是UI上掛載的腳本,用于更新UI界面的顯示和數(shù)據(jù)存儲的
LevelItem item = m_LevelItemList[i];
if (item.DRect != null && !inOverlaps.ContainsKey(item.DRect.Index))
{
//item的DRect為null時,隱藏物體,否則顯示物體
item.DRect = null;
}
}
//判斷哪些可以重復(fù)利用的UI,然后賦予新的數(shù)據(jù)與位置
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>
/// 通過動態(tài)格子獲得動態(tài)渲染器
/// </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;
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#中async await異步關(guān)鍵字用法和異步的底層原理全解析
這篇文章主要介紹了C#中async await異步關(guān)鍵字用法和異步的底層原理全解析,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2025-04-04
C#中const,readonly和static關(guān)鍵字的用法介紹
這篇文章介紹了C#中const,readonly和static關(guān)鍵字的用法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
使用C#實現(xiàn)Windows組和用戶管理的示例代碼
這篇文章主要介紹了使用C#實現(xiàn)Windows組和用戶管理的示例代碼,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下2021-01-01

