listview加载图片显示
Adapter: ----
//adapter的构造方法: 参数1 为url数组:
public static String[] mList;// 讲url保村在静态的String[] 中 在其他类可以直接调用
public MyListAdapter(String[] list, Context context, ListView listView) {
this.mList = list;
this.mContext = context;
bitmapUtils = new HttpUtils(context, listView);
listView.setOnScrollListener(this);
}
在getView()方法中为url设置tag 但获取发的url是一样的 这样就导只tag长向是和其他一样
holder.mImageView.setTag(mList[position]);
bitmapUtils.display(item, mImageView);//加载图片 不过不加载网络图片 只加载内存和本地图片 没有不加载
//为Adapter添加 listView的滑动监听
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
// 加载可见项
bitmapUtils.loadImage(mStart, mEnd);
} else {
bitmapUtils.stopLoad();
}
}
private boolean isFrist = true;
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
mStart = firstVisibleItem;
mEnd = firstVisibleItem + visibleItemCount;
if (isFrist && visibleItemCount > 0) {
bitmapUtils.loadImage(mStart, mEnd);
isFrist = false;
}
}
图片加载类 :主要用到LruCache 类和异步加载: 然后关于图片的错乱处理:(还可以加上本地缓存来进一步优化)
ImageView image =(ImageView)listiew.findViewWithTag(url); 来找到控件:
//-------------------------犹豫的分割线----------------======================
package com.example.listoptimization.activity;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.HashSet;
import java.util.Set;
import com.example.listoptimization.R;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
import android.support.v4.util.LruCache;
import android.widget.ImageView;
import android.widget.ListView;
/**
* 还差本地缓存 实现了网络和内存加载
*
* @author chen
*
*/
public class HttpUtils {
private ImageView mImageView;
private String murl;
private Context mContext;
private LruCache<String, Bitmap> mCache;
public HttpUtils(Context context, ListView list) {
this.mContext = context;
this.mListView = list;
int maxSize = (int) Runtime.getRuntime().maxMemory();
int cacheSize = maxSize / 5;
mCache = new LruCache<String, Bitmap>(cacheSize) {
@Override
protected int sizeOf(String key, Bitmap value) {
return value.getByteCount();
}
};
mSet = new HashSet<HttpUtils.MyAsyncTask>();
}
public void display(String url, ImageView image) {
this.mImageView = image;
this.murl = url;
Bitmap bitmapFromCache = getBitmapFromCache(url);
if (bitmapFromCache != null) {
System.out.println("内存中加载");
image.setImageBitmap(bitmapFromCache);
} else {
image.setImageResource(R.drawable.ic_launcher);
}
}
// 加载万络图片
public void loadImage(String url, ImageView imageView) {
Bitmap bitmapFromCache = getBitmapFromCache(url);
if (bitmapFromCache == null) {
new MyAsyncTask(url).execute(url);
} else {
imageView.setImageBitmap(bitmapFromCache);
}
}
// 从LruCachhe中获取
public Bitmap getBitmapFromCache(String path) {
if (path != null) {
Bitmap mBitmap = mCache.get(path);
return mBitmap;
}
return null;
}
// 保村图片到缓存中去
public void saveBitmapToCache(String path, Bitmap bitmap) {
if (path != null) {
if (getBitmapFromCache(path) == null) {
mCache.put(path, bitmap);
}
}
}
// 根据url获取Bitmap
public Bitmap getBitmapFromService(String url) {
Bitmap bitmap = null;
try {
URL murl = new URL(url);
HttpURLConnection mHttpConnection = (HttpURLConnection) murl.openConnection();
mHttpConnection.setRequestMethod("GET");
mHttpConnection.setConnectTimeout(3000);
if (mHttpConnection.getResponseCode() == 200) {
InputStream mInputStream = mHttpConnection.getInputStream();
bitmap = BitmapFactory.decodeStream(mInputStream);
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return bitmap;
}
public class MyAsyncTask extends AsyncTask<String, Void, Bitmap> {
String url;
public MyAsyncTask(String url) {
this.url = url;
}
@Override
protected Bitmap doInBackground(String... params) {
Bitmap bitmapFromService = getBitmapFromService(params[0]);
saveBitmapToCache(url, bitmapFromService);
return bitmapFromService;
}
@Override
protected void onPostExecute(Bitmap result) {
super.onPostExecute(result);
ImageView mImageView = (ImageView) mListView.findViewWithTag(url);
if (mImageView != null && result != null) {
mImageView.setImageBitmap(result);
}
mSet.remove(url);
}
}
private Set<MyAsyncTask> mSet;// 用于管理task任务
private ListView mListView;
public void loadImage(int start, int end) {
for (int i = start; i < end; i++) {
String url = MyListAdapter.mList[i];
Bitmap bitmapFromCache = getBitmapFromCache(url);
if (bitmapFromCache != null) {
ImageView mImageView = (ImageView) mListView.findViewWithTag(url);
mImageView.setImageBitmap(bitmapFromCache);
} else {
MyAsyncTask task = new MyAsyncTask(url);
task.execute(url);
mSet.add(task);
}
}
}
public void stopLoad() {
if (mSet != null) {
for (MyAsyncTask myAsyncTask : mSet) {
myAsyncTask.cancel(false);
}
}
}
}
listview加载图片显示的更多相关文章
- Unity3d:加载Format是RGB24位的图片失败(加载图片显示问号)
问题描述:加载图片显示是个红色的问号,调试发现,Texture的Format=RGB24的都加载失败,ARGB32位的都能成功,按照常规,首先去度娘,看是否有人遇到和我同样的问题,结果一无所获.将用N ...
- android listview 加载图片错乱(错位)
写道 今天晚上一个朋友介绍我看了一篇文章,也是解决android中listview在加载图片错位的问题,看了之后,感觉写的很好,自己也遇到这个问题,但是又不知道从何下手,看到这篇文章后,我的问题 ...
- React-Native ListView加载图片淡入淡出效果的组件
今天练习项目中需要给listview在加载图片时增加一个淡入淡出的效果,因此干脆就自己封装了一个组件: 'use strict' import React from 'react-native' va ...
- 使用自定义的item、Adapter和AsyncTask、第三方开源框架PullToRefresh联合使用实现自定义的下拉列表(从网络加载图片显示在item中的ImageView)
AsyncTask使用方法详情:http://www.cnblogs.com/zzw1994/p/4959949.html 下拉开源框架PullToRefresh使用方法和下载详情:http://ww ...
- Android webView加载图片显示过大的问题
webview的基本使用流程这里我就不重复说明了,本篇针对的是文章详情加载完成后出现的情况,这里我们使用的方法是:通过js脚本,重置img标签中图片的宽度和高度. 使用步骤: 1.此方法需要使用js, ...
- BackgroundWorker实现的winfrom中实现异步等待加载图片显示
BackgroundWorker简介 BackgroundWorker在winfrom中有对应控件,该有三个事件:DoWork .ProgressChanged 和 RunWorkerCompl ...
- Android之ListView异步加载图片且仅显示可见子项中的图片
折腾了好多天,遇到 N 多让人崩溃无语的问题,不过今天终于有些收获了,这是实验的第一版,有些混乱,下一步进行改造细分,先把代码记录在这儿吧. 网上查了很多资料,发现都千篇一律,抄来抄去,很多细节和完整 ...
- android listview 异步加载图片并防止错位
网上找了一张图, listview 异步加载图片之所以错位的根本原因是重用了 convertView 且有异步操作. 如果不重用 convertView 不会出现错位现象, 重用 convertVie ...
- [Android]异步加载图片,内存缓存,文件缓存,imageview显示图片时增加淡入淡出动画
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3574131.html 这个可以实现ImageView异步加载 ...
随机推荐
- float right 换行bug
Bug产生原因:块里面有换行的元素. CSS: .left{float: left;width: 100px;background: #fff000;} .right{float: right;wid ...
- Omnithreadlibary学习(1)-异步执行
program main; {$APPTYPE CONSOLE} {$R *.res} uses System.SysUtils, OtlParallel; begin Parallel.Async( ...
- Python httpsqs封装类
''' httpsqs队列封装 @author xp_go@qq.com a = HttpsqsClient('192.168.0.218','1218','httpsqsmmall.com') pr ...
- UITableView中复用cell显示信息错乱
UITableView继承自UIScrollview,是苹果为我们封装好的一个基于scroll的控件.上面主要是一个个的 UITableViewCell,可以让UITableViewCell响应一些点 ...
- bzoj 1964: hull 三维凸包 计算几何
1964: hull 三维凸包 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 54 Solved: 39[Submit][Status][Discuss ...
- [原博客] POI系列(1)
正规.严谨.精妙. -POI 发现POI(波兰信息学奥赛)的题都很有意思.于是开刷bzoj上的poi题目(按ac人数降序..).顺手写一写题解,加深印象. 为了防止一篇文章过于长,打算每五道题另起一篇 ...
- Druid :大数据实时处理的开源分布式系统(1)
引言 Druid 是一个快速,近实时的查询海量只读数据的系统.Druid 的目标是可用性要达到100%,即使在部署新代码,或者某些节点 down 机的情况下. Druid 目前支持的单表查询方式和 D ...
- OA学习笔记-002-Sruts2.1配置
一.jar commons-fileupload-1.2.1.jarcommons-io-1.3.2.jarfreemarker-2.3.15.jarognl-2.7.3.jarstruts2-cor ...
- Android Training精要(四) Intent注意事项
判断有处理Intent的Activity PackageManager packageManager = getPackageManager(); List<ResolveInfo> ac ...
- android Theme使用三
☆ obtainStyledAttributes参数说明 和使用说明 1) obtainStyledAttributes(int[]attrs) int[] attrs返回的是attrs.xml里一 ...