`
libo19881179
  • 浏览: 269821 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

【BUG解决】Android ListView只加载当前屏幕内的图片(解决list滑动时加载卡顿)

阅读更多

http://androiddada.iteye.com/

  最近在做ListView分页显示,其中包括图片 和文字(先下载解析文字内容,再异步加载图片)发现每次点击下一页后,文字内容加载完毕,马上向下滑动,由于这时后台在用线程池异步下载图片,我每页有20条,也就是20张图片,会导致listview滑动卡顿!

这是用户不想看到的,我参考了网易新闻和电子市场等应用,发现它们都是只加载屏幕内的图片,不现实的不加载,于是我也仿照做了一个。我是菜鸟,我承认 呵呵,虽然不见得完全和他们的一样,但是确实解决了翻页时那一刻的卡顿现象。

因为未发现网上有相关文章,希望对朋友们有用~

下面是相关代码(分页的就没放):

 

 

	/**
		 * list滚动监听
		 */
		listView.setOnScrollListener(new OnScrollListener() {
			@Override
			public void onScrollStateChanged(AbsListView view, int scrollState) {
				// TODO Auto-generated method stub
				// 异步加载图片
				if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {//list停止滚动时加载图片
					pageImgLoad(_start_index, _end_index);
				}
			}
			@Override
			public void onScroll(AbsListView view, int firstVisibleItem,
					int visibleItemCount, int totalItemCount) {
				// TODO Auto-generated method stub
				//设置当前屏幕显示的起始index和结束index
				_start_index = firstVisibleItem;
				_end_index = firstVisibleItem + visibleItemCount;
				if (_end_index >= totalItemCount) {
					_end_index = totalItemCount - 1;
				}
			}
		});

   http://androiddada.iteye.com/

/**
	 * 只加载from start_index to end_index 的图片 
	 * @param start_index
	 * @param end_index
	 */
	private void pageImgLoad(int start_index, int end_index) {
		for (; start_index < end_index; start_index++) {
			HashMap<String, Object> curr_item = adapter.getItem(start_index);
			if (curr_item.get(Constant.NEWS_ICON_URL) != null
					&& curr_item.get(Constant.NEWS_ICON) == null) {
				loadImage(curr_item);
			}
		}
	}

 

异步加载图片代码,这里我之前使用的是AsyncTask,但是继承AsyncTask后不能被执行多次,所以我改用了线程呼叫handler更新UI:

/**
	 * 异步加载图片
	 * @param curr_item
	 */
	private void loadImage(final HashMap<String, Object> curr_item) {
		executorService.submit(new Runnable() {
			public void run() {
				try {
					Drawable curr_icon = null;
					String icon_URL = (String) curr_item
							.get(Constant.NEWS_ICON_URL);
					String newsId = (String) curr_item.get(Constant.NEWS_ID);

					if (imageCache.containsKey(icon_URL)) {//软引用
						SoftReference<Drawable> softReference = imageCache
								.get(icon_URL);
						curr_icon = softReference.get();
						System.out.println("CASE USING SoftReference!!!!!!!!!!!!!!!!!!!!");
					}
					if (curr_icon == null) {
						HttpUtils hu = new HttpUtils();
						FileUtils fu = new FileUtils();
						if (hu.is_Intent(Home_Activity.this)) {
							fu.write2LocalFromIS(Home_Activity.this, newsId
									+ Constant.SAVE_NEWS_ICON_NAME
									+ Constant.SAVE_IMG_SUFFIX,
									hu.getISFromURL(icon_URL));
						}
						// 从本地加载图片 如果没网则直接加载本地图片
						curr_icon = fu.readDrawableFromLocal(
								Home_Activity.this, newsId
										+ Constant.SAVE_NEWS_ICON_NAME
										+ Constant.SAVE_IMG_SUFFIX);
						imageCache.put(icon_URL, new SoftReference<Drawable>(
								curr_icon));
					}
					curr_item.put(Constant.NEWS_ICON, curr_icon);
					// UI交给handler更新
					Message msg = _viewHandler.obtainMessage();
					msg.arg1 = Constant.MSG_LIST_IMG_OK;
					msg.sendToTarget();
				} catch (Exception e) {
					throw new RuntimeException(e);
				}
			}
		});
	}

 

 

handler代码:
Handler _viewHandler = new Handler() {
	@Override
		public void handleMessage(Message msg) {
			switch (msg.arg1) {
			case Constant.MSG_LIST_IMG_OK:
				// 更新UI
				adapter.notifyDataSetChanged();
				break;
			}
			super.handleMessage(msg);
		}
	};

 上个图吧:


http://androiddada.iteye.com/

  • 大小: 68.2 KB
9
3
分享到:
评论
10 楼 roseteam 2013-11-14  
LZ能发一份源码给我么?邮箱 416563137@qq.com
9 楼 roseteam 2013-11-14  
LZ能发一份源码给我么?邮箱 649865915@qq.com
8 楼 libo19881179 2012-06-25  
zingsky 写道
reeceran 写道
libo19881179 写道
reeceran 写道
问你个问题,当刚进去的时候,没有滑动,onScrollStateChanged函数不会调用,图片也不会下载,这个怎么解决?

判断下adapter==null时加载

还是不明白,能说详细点吗?

可以这样做,在getView中添加一个布尔值,如果布尔值是true,那么启动下载,当listview开始滑动的时候,把这个布尔值变为false这样就不会在getView中继续下载了,也就达到了效果

这样会有一个问题,getview只在初始化时调用,所以是瞬时的,而下载是持续的(单独的线程),getview里加个开关不能完全控制新的线程!除非锁住线程
7 楼 zingsky 2012-06-25  
reeceran 写道
libo19881179 写道
reeceran 写道
问你个问题,当刚进去的时候,没有滑动,onScrollStateChanged函数不会调用,图片也不会下载,这个怎么解决?

判断下adapter==null时加载

还是不明白,能说详细点吗?

可以这样做,在getView中添加一个布尔值,如果布尔值是true,那么启动下载,当listview开始滑动的时候,把这个布尔值变为false这样就不会在getView中继续下载了,也就达到了效果
6 楼 zingsky 2012-06-20  
楼主有项目么,还不清楚下载完成后如何更新UI
5 楼 reeceran 2012-04-19  
libo19881179 写道
reeceran 写道
问你个问题,当刚进去的时候,没有滑动,onScrollStateChanged函数不会调用,图片也不会下载,这个怎么解决?

判断下adapter==null时加载

还是不明白,能说详细点吗?
4 楼 libo19881179 2012-04-17  
reeceran 写道
问你个问题,当刚进去的时候,没有滑动,onScrollStateChanged函数不会调用,图片也不会下载,这个怎么解决?

判断下adapter==null时加载
3 楼 reeceran 2012-04-16  
问你个问题,当刚进去的时候,没有滑动,onScrollStateChanged函数不会调用,图片也不会下载,这个怎么解决?
2 楼 xh416563137 2011-11-29  
LZ能发一份源码给我么?邮箱 416563137@qq.com
非常感谢!!!
1 楼 zhongxinhu 2011-11-07  
学习一下!

相关推荐

    listview 只加载当前屏幕内项目

    标题“listview只加载当前屏幕内项目”指的是ListView的一项优化策略,称为“按需加载”或“懒加载”。这种策略只会在用户滚动到屏幕可见区域时加载相应的列表项,以减少内存消耗和提高应用性能。 描述中提到的...

    android ListView滑动自动加载

    ListView的优势在于它可以高效地管理内存,只加载屏幕可见的视图,从而节省系统资源。本篇将详细讲解如何实现ListView的滑动自动加载功能,即“无限滚动”。 首先,我们要理解这个功能的基本原理:当用户滚动...

    android listView图片异步加载(拖动时不加载,双缓存)

    3. 延迟加载:对于屏幕外的图片,可以延迟加载,只在即将显示时才开始加载。 4. 图片压缩:对下载的图片进行压缩,减少内存占用。 5. 使用高效的图片库:如Picasso、Glide等,它们已经实现了上述功能,可以简化代码...

    Android Listview异步加载图片

    然而,当ListView中的每个项都包含图片时,如果直接在主线程中加载图片,会导致UI卡顿,用户体验下降。为了解决这个问题,我们需要实现ListView的图片异步加载。本文将深入探讨Android ListView中异步加载图片的策略...

    android listView 异步加载图片

    这里的“android listView 异步加载图片”指的是在不阻塞UI线程的情况下,从网络、本地存储或其他来源加载图片到ListView中的技术。 这篇名为“ImageLoader”的Java文件很可能就是一个实现图片异步加载的工具类。在...

    android listview 加载图片错乱(错位)

    然而,开发者在实现ListView加载图片时可能会遇到图片错乱或错位的问题,这通常是由于不当的图片加载策略或者ListView的复用机制导致的。本篇文章将深入探讨这个问题,并提供解决方案。 一、ListView图片错乱的原因...

    Android实现ListView异步加载图片

    "Android实现ListView异步加载图片" Android 实现 ListView 异步加载图片是一种常见的技术,旨在提高应用程序的性能和用户体验。本文将详细介绍 Android 中实现 ListView 异步加载图片的方法,并对相关的技术概念...

    android listView 分页加载

    每个页面对应ListView的一个部分,当用户滑动到新的页面时,加载相应数据。 - RecyclerView + Paging Library:现代Android开发更推荐使用RecyclerView,结合Android官方提供的Paging Library,可以轻松实现高效、...

    android Listview分批加载+自动加载改进版 源码下载

    在Android开发中,ListView是常用的数据展示控件,尤其在数据量较大的场景下,为了提高用户体验和节省系统资源,分批加载(Lazy Loading)和自动加载(Infinite Scrolling)技术变得至关重要。本文将深入探讨这两种...

    android listview滑动到底部加载数据

    "android listview滑动到底部加载数据"这个主题涉及到一个常见的功能需求:无限滚动或称为“上拉加载更多”。这种设计模式允许用户在滚动到ListView底部时动态加载更多的内容,从而提供更好的用户体验,避免一次性...

    Android,ListView解决嵌套滑动性能问题

    解决复杂布局,scrollview嵌套ListView滑动性能的问题,提供下拉刷新和暴露对外操作listview控件UI的方法,同步博文:http://blog.csdn.net/qq_28690547/article/details/50792439

    android listview从mysql加载数据和图片

    本示例"android listview从mysql加载数据和图片"将介绍如何从MySQL数据库获取数据,并在ListView中显示这些数据以及对应的图片。这个过程涉及到Web服务端、Android客户端以及MySQL数据库的交互。 首先,我们需要在...

    Android 使用软引用解决listView卡顿问题

    在Android开发中,ListView是一种常见的...这就是如何利用Android的软引用来优化ListView的图片加载,解决卡顿问题。在实际开发中,还可以结合其他技术,如LruCache、 Glide 或 Picasso 等图片加载库,进一步提升性能。

    android Listview下拉刷新 上拉(滑动分页)加载更多

    在Android开发中,ListView是常用的数据展示控件,用于显示大量的列表数据。为了提供更好的用户体验,通常会添加下拉刷新和上拉加载更多的功能。这些功能使得用户可以在滚动到列表顶部时更新数据(下拉刷新),或者...

    android listview 异步加载图片并防止错位

    3. **延迟加载**:对于未出现在屏幕内的item,我们可以选择延迟加载其图片,只在item进入可视区域时才开始加载。这可以通过计算ListView的滚动位置和item的位置来实现。 4. **使用 placeholder 图片**:在图片实际...

    基于Android ListView之加载使用技巧

    在Android开发中,ListView是一个非常重要的组件,常用于展示大量数据列表。本篇文章将探讨如何高效、优雅地在ListView中实现加载与显示数据的技巧。 首先,ListView的使用涉及到两个核心概念:Adapter和ViewHolder...

    Android ListView 下拉刷新、上拉加载

    在Android开发中,ListView是常用的一种控件,用于展示大量数据列表。`下拉刷新`和`上拉加载`功能的实现,极大地提升了用户体验,让用户能够实时获取到最新的数据。本篇文章将深入探讨如何在ListView中实现这两种...

    ListView异步加载图片

    ①ListView异步加载图片的方式 ②给ImageView设置Tag,解决图片覆盖问题 ③采用LruCache缓存已经加载过的图片 ④当ListView滚动时不加载图片,滚动停止时才加载...⑤当ListView加载图片时只加载当前屏幕内可见的条目

    安卓图片加载缓存相关-AsyncTask的使用及ListView的常见优化asyncTask异步加载数据使用了LruCache优化图片加载通过滑动监听提高ListView滑动流畅度.rar

    AsyncTask的使用及ListView的常见优化 asyncTask异步加载数据 使用了LruCache优化图片加载 通过滑动监听提高ListView滑动流畅度.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习...

    Android ListView异步加载图片

    Android 异步加载图片,对ListView的异步加载图片的功能演示,主要根据url读取图片返回流的方法。为了方便演示,将请求图片的链接先固定,每读取好一个图片就更新,界面比较简单,当然你可以做成比较好的,像很多好...

Global site tag (gtag.js) - Google Analytics