[UI列表]LoopScrollRect无限滑动不卡顿
应用场景
对于背包界面,排行榜列表,聊天消息,等有大量的UI列表的界面,常规做法是为每一条数据生成一个格子,在数据量越大的情况下,会生成越来越多的Gameobject,引起卡顿。
这篇文章讲述的就是解决UI列表卡顿的方法,在列表中只生成指定数量的Gameobject,滑动时进行数据更新,保证性能。

LoopScrollRect(UGUI循环列表不卡顿)
插件地址:https://github.com/qiankanglai/LoopScrollRect
中文文档:http://qiankanglai.me/2015/08/15/LoopScrollRect/
适用于UGUI,支持UGUI原生的GridLayout,ScrollBar
我的修改版本:https://github.com/zhaoqingqing/LoopScrollRect.git
原理分析
在UGUI的ScrollRect基础上作的修改
两者的差异部分使用//==========LoopScrollRect========== 标识出来了,源代码对比:
UGUI的ScrollRect:https://bitbucket.org/Unity-Technologies/ui/src/5.2/UnityEngine.UI/UI/Core/ScrollRect.cs?fileviewer=file-view-default
LoopScrollRect:https://github.com/qiankanglai/LoopScrollRect/blob/master/Assets/Scripts/LoopScrollRect.cs
使用示例
可以参考demo的示例
如果在lua中使用,逻辑和C#的一样,步骤如下:
1.注册事件、取消注册
2.在刷新函数根据数据更新列表
3.调用逻辑
注册事件
注册列表滑动事件,在OnOpen中注册,用来刷新列表
此事件在C#中触发,Lua中注册回调,事件有两个参数
self.chatScrollRect.dataSource.ScrollToTextEvent = function(cellTrans, idx) self:OnScrollChat(cellTrans, idx) end
取消注册
取消注册的列表滑动事件,在OnClose中取消
self.chatScrollRect.dataSource.ScrollToTextEvent = nil
触发滑动事件(刷新每一项)
在以下情况事件会被触发:
- 如果列表的值已全部生成出来,在滑动过程中不会触发,否则会触发
- 调用RefreshCells或RefillCellsFromEnd时,会触发
function UIRewardResources:OnScrollEvent(cellTrans, idx)
if (not cellTrans or not idx) then
return
end
idx = idx + 1 -- Lua的索引从1开始,而scrollRect是从0开始
local data = DataCenter.resource.data[idx]
--执行你的刷新逻辑
self:DoRenderItem(cellTrans, data)
end
手动刷新列表
--设置列表的总数,并刷新cell
self.scrollRect.itemTypeStart = 0 ---让列表从头开始滑动
self.chatScrollRect.totalCount = 10
self.chatScrollRect:RefreshCells()
刷新并让列表滑动到底部
在聊天列表中每次发言完都是最新消息都在最底下,可以使用这个接口
self.chatScrollRect:RefillCellsFromEnd()
如果在模拟器上出现无法滑动到底部的现象,在Unity 2018.4.15f + 网易MuMu模拟环境下可添加下列代码
IEnumerator RefreshToEnd()
{
yield return null;
yield return null;
Canvas.ForceUpdateCanvases();
loop_scroll.verticalNormalizedPosition = 1.0f;
}
两个刷新函数区别
RefreshCells:列表刷新
RefillCellsFromEnd:从最底部的消息开始刷新,并滑动到底部
列表滑动到底部的事件
和UGUI的ScrollRect的做法一样,为scrollRect添加一个scrollbar,捕捉OnEndDrag事件,示例如下:
self.chatScrollRect.onEndDrag = function(data)
if self.chatScrollbar.value >= 1 then
print("scroll to bottom")
end
end
如果你的数据量特别大,在滑动到底部事件时进行分页请求数据
如果是做分页:建议在滑动到某个数量级且滑动到底部时,设置一次数据,保证滑动的流畅性
prefabSource为nil
如果在热更新的包中报prefabSource为nil,是因为热更新dll之后,prefabSource会丢失,需要在lua对prefabSource重新赋值,示例:
self.scrollRect.prefabSource = CS.UnityEngine.UI.XLoopScrollPrefabSource(self.itemCell.gameObject)
跳转到指定的index/Item
参考:https://github.com/qiankanglai/LoopScrollRect/issues/14
方法一:
设置itemTypeStart为需要的Pos
self.scrollRectEquipList.content.anchoredPosition = Vector2.zero
self.scrollRectEquipList.itemTypeStart = pos - 1
self.scrollRectEquipList.totalCount = equipCount
self.scrollRectEquipList:RefreshCells()
方法二:不绑定initInStart脚本,并调用 RefillCells(90)
两次调用列表滑动位置不正确
对于tab页签,左右切页都使用同一个ScrollRect,在前一个滑动到底部之后,再切到下一个页签,会出现列表还在滑动的现象,在切换页签前添加以下代码,停止上一次的滑动,并把位置进行复位
void ResetPos()
{
loop_scroll.StopAllCoroutines();
loop_scroll.StopMovement();
loop_scroll.content.anchoredPosition = Vector2.zero;
}
技巧和事项
Cell指:每一个格子,或每一项列表
为每一个Cell都绑定LayoutElement组件,并勾选Preferred Width 和Preferred Height,且给它们赋合适值,保证列表自适应。
查找某一项的取巧做法:可以用id做为Cell的名字,当在查找时,根据FindChild(id)找到这一项,进行刷新。
滑动到指定的index/Item:
https://github.com/qiankanglai/LoopScrollRect/issues/14
https://github.com/qiankanglai/LoopScrollRect/issues/27
[UI列表]LoopScrollRect无限滑动不卡顿的更多相关文章
- IScroll在某些手机浏览器上不能滑动和卡顿解决办法
1.不能滑动,增加一句 if (scroll != null) scroll.refresh();2.卡顿,增加 <script>window.PointerEvent = undefin ...
- viewpager+fragment滑动切换卡顿问题
最近在做项目的时候遇到个问题,viewpager中的fragment添加使用listview添加数据后出现滑动卡顿,造成用户体验感极差.找了很久的资料,也试了很多大方法,在这里给大家分享下: 1.添加 ...
- 性能优化九之UI卡顿分析
在前一篇博客中提到内存抖动和耗时复杂的计算会导致UI卡顿. 那为什么内存抖动会导致UI卡顿呢? 其实在 性能优化一之内存与垃圾回收器 这篇文章中已经有所提及. 这里来详细说明一下: 渲染功能是应用程序 ...
- ios添加-webkit-overflow-scrolling依然卡顿
项目由vue-cli2创建 在overflow: auto区域内滑动ios手机出现卡顿,搜索资料后添加-webkit-overflow-scrolling: touch ios bug: 1.滑动区域 ...
- Android异常与性能优化相关面试问题-ui卡顿面试问题详解
UI卡顿原理: “60fps(Frames Per Second每秒传输帧数) ----> 16ms” 针对上面标红的数字,下面具体说明一下:最主要的根源在于渲染性,Android会每隔16ms ...
- Android ListView只加载当前屏幕内的图片(解决list滑动时加载卡顿)
最近在做ListView分页显示,其中包括图片 和文字(先下载解析文字内容,再异步加载图片)发现每次点击下一页后,文字内容加载完毕,马上向下滑动,由于这时后台在用线程池异步下载图片,我每页有20条,也 ...
- bootsrtap h5 移动版页面 在苹果手机ios滑动上下拉动滚动卡顿问题解决方法
bootsrtap h5 移动版页面 在苹果手机ios滑动上下拉动滚动卡顿问题解决方法 bootsrtap框架做的h5页面,在android手机下没有卡顿问题,在苹果手机就一直存在这问题,开始毫无头绪 ...
- Android Scrollview嵌套RecyclerView导致滑动卡顿问题解决
一个比较长的界面一般都是Scrollview嵌套RecyclerView来解决.不过这样的UI并不是我们开发人员想看到的,实际上嵌套之后.因为Scrollview和RecyclerView都是滑动控件 ...
- Android 界面滑动卡顿分析与解决方案(入门)
Android 界面滑动卡顿分析与解决方案(入门) 导致Android界面滑动卡顿主要有两个原因: 1.UI线程(main)有耗时操作 2.视图渲染时间过长,导致卡顿 目前只讲第1点,第二点相对比较复 ...
随机推荐
- C:\WINDOWS\system32\wmp.dll”受到“Windows 系统文件保护”
在VC# 2005 中,要是打包的程序中包含了Windows Media Player 这个组件的话,在生成解决方案的过程中会提示出错: "错误1,应将“wmp.dll”排除,原因是其源文 ...
- Python手动实现k-means
import numpy as np import matplotlib.pyplot as plt def kmeans(data, cluster_num, method='mean'): poi ...
- 【JDK1.8】JDK1.8集合源码阅读——TreeMap(一)
一.前言 在前面两篇随笔中,我们提到过,当HashMap的桶过大的时候,会自动将链表转化成红黑树结构,当时一笔带过,因为我们将留在本章中,针对TreeMap进行详细的了解. 二.TreeMap的继承关 ...
- python 小白(无编程基础,无计算机基础)的开发之路 day2
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- python坑之input获取字符串
space = input("set user quotation:").strip() quotation = int(space* 1024 * 1024) print(quo ...
- LayoutInflater 三种获得方式
LayoutInflater 作用是从外部加载一个xml布局文件. 获得 LayoutInflater 实例的三种方式: 1.LayoutInflater inflater = getLayoutIn ...
- RedHat升级Python到2.7.6
今天本来想研究一下Python paramiko模块,安装安装 paramiko-1.10.1.tar.gz的时候报错,!看了一下虚拟机RedHat中的python,发现还是原生的2.4.3,所以决 ...
- 解决WebSocket兼容ie浏览器版本问题
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7942323.html 在使用Netty进行WebSocket开发时,测试发现:ie 11系列个别低版本连接W ...
- 【MAVEN】maven系列--pom.xml标签详解
pom文件作为MAVEN中重要的配置文件,对于它的配置是相当重要.文件中包含了开发者需遵循的规则.缺陷管理系统.组织.licenses.项目信息.项目依赖性等.下面将重点介绍一下该文件的基本组成与功能 ...
- python3.5安装pyHook,解决【TypeError: MouseSwitch() missing 8 required positional arguments: 'msg', 'x', 'y', 'data', 'time', 'hwnd', and 'window_name'】这个错误!
为什么安装 pyHook包:为Windows中的全局鼠标和键盘事件提供回调. Python应用程序为用户输入事件注册事件处理程序,例如鼠标左键,鼠标左键,键盘键等 先要实时获取系统的鼠标位置或者键盘输 ...