AbsListView 快速滚动如何更高效
来源:互联网 发布:广告优化师创业 编辑:程序博客网 时间:2024/04/26 22:49
这次接收一个类似微信选择本地图片上传的功能,主要问题在于如果本地图片量很大的情况下,用户快速滑动的过程中,我们无需再快速滑动的时候去处理本地图片并显示,而是等到滑动结束时去处理最后显示的几张图片,主要使用onScrollListener,中去判断滑动的状态,
grid.setOnScrollListener(new OnScrollListener() {
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
if(scrollState == AbsListView.OnScrollListener.SCROLL_STATE_FLING){
} else {
}
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
}
});
在OnScrollStateChanged方法中,参数scrollstate可以判断当前滑动的状态,AbsListView.OnScrollListener.SCROLL_STATE_FLING,这个状态代表当前scrollView处于快速滚动状态,此时我们去做处理,当处于这种状态时,我们去停止加载显示图片的动作,当处于其他状态时,开启加载图片的动作,在这种情景下,最好用的是synchronized,private final Object mPauseWorkLock = new Object();
synchronized (mPauseWorkLock) {
mPauseWork = pauseWork;
if (!mPauseWork) {
mPauseWorkLock.notifyAll();
}
}
synchronized (mPauseWorkLock) {
while (mPauseWork && !isCancelled()) {
try {
mPauseWorkLock.wait();
} catch (InterruptedException e) {}
}
}
- AbsListView 快速滚动如何更高效
- AS-->如何更高效的使用 Gradle, 快速build apk
- 如何更高效的使用 Gradle, 快速build apk
- 如何更高效
- 实用教程:如何着色更高效
- 如何使JavaScript更高效
- 如何使JavaScript更高效!!?
- 如何使 JavaScript 更高效?
- 如何使 JavaScript 更高效?
- 如何更高效的调试.Net程序。
- 如何更高效的进行回归测试?
- 如何使CSS渲染更高效
- 如何使CSS渲染更高效
- 如何成为更高效的学习者
- 如何更高效地使用 OkHttp
- 如何更高效地使用 OkHttp
- 如何更高效地使用 OkHttp
- 如何使用才能让缓存更高效
- 翻译:PostgreSql数据库的日常Vacuuming-未完待续
- Java并发包中的几种ExecutorService
- 给定a和n,计算a+aa+aaa+aaaa+...+a...a(n个a)的和.
- linux 查找目录或文件
- Linux 查看登录日志及登录失败用户的ip
- AbsListView 快速滚动如何更高效
- linux系统环境下--学会使用简单的MySQL操作
- php日期格式。记录
- org.activiti.engine.impl.db.DbSqlSession - problem during schema drop, statement drop index ACT_IDX_
- Exception from HRESULT: 0x80131904
- org.activiti.engine.ActivitiObjectNotFoundException: no deployed process definition found with id 's
- linux系统日常管理【转载】
- cengos 查看文件夹下文件大小
- LeetCode Word Search