android Universal-Image-Loader框架学习(下)

一.GridView显示图片加进度框:

在Universal-Image-Loader框架可以让加载图片变的简单,下面我们看一下如何在GridView中使用附加上进度条。

效果图:

主界面:

<span style="font-size:18px;">public class GridActivity extends Activity{

	private GridView grid;
	public static final String[] IMAGES = new String[] {
		"http://img.dapixie.com/uploads/allimg/111105/1-111105145231.jpg",
		"http://img3.3lian.com/2014/c2/61/d/1.jpg",
		"http://img3.3lian.com/2014/c2/61/d/2.jpg",
		"http://img3.3lian.com/2014/c2/61/d/3.jpg",
		"http://img3.3lian.com/2014/c2/61/d/4.jpg",
		"http://img3.3lian.com/2014/c2/61/d/5.jpg",
		"http://img3.3lian.com/2014/c2/61/d/6.jpg",
		"http://img3.3lian.com/2014/c2/61/d/7.jpg",
		"http://img3.3lian.com/2014/c2/61/d/8.jpg",
		"http://img3.3lian.com/2014/c2/61/d/9.jpg",
		"http://img3.3lian.com/2014/c2/61/d/10.jpg",
		"http://img3.3lian.com/2014/c2/61/d/11.jpg",
		"http://img3.3lian.com/2014/c2/61/d/12.jpg" };

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.grid_activity);

		grid = (GridView)findViewById(R.id.grid);
		grid.setAdapter(new ImageAdapter(this));

	}
	@Override
	protected void onDestroy() {
		super.onDestroy();
		ImageLoader.getInstance().clearMemoryCache();// 清空缓存
		ImageLoader.getInstance().clearDiskCache();//清空缓存
		ImageLoader.getInstance().stop();// 停止
	}

	private static class ImageAdapter extends BaseAdapter {

		private static final String[] IMAGE_URLS = GridActivity.IMAGES;

		private LayoutInflater inflater;

		private DisplayImageOptions options;

		ImageAdapter(Context context) {
			inflater = LayoutInflater.from(context);

			options = new DisplayImageOptions.Builder()
					.showImageOnLoading(R.drawable.ic_stub)
					.showImageForEmptyUri(R.drawable.ic_empty)
					.showImageOnFail(R.drawable.ic_error)
					.cacheInMemory(true)
					.cacheOnDisk(true)
					.considerExifParams(true)
					.bitmapConfig(Bitmap.Config.RGB_565)
					.build();
		}

		@Override
		public int getCount() {
			return IMAGE_URLS.length;
		}

		@Override
		public Object getItem(int position) {
			return null;
		}

		@Override
		public long getItemId(int position) {
			return position;
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			final ViewHolder holder;
			View view = convertView;
			if (view == null) {
				view = inflater.inflate(R.layout.grid_listview_item, parent, false);
				holder = new ViewHolder();
				assert view != null;
				holder.imageView = (ImageView) view.findViewById(R.id.image);
				holder.progressBar = (ProgressBar) view.findViewById(R.id.progress);
				view.setTag(holder);
			} else {
				holder = (ViewHolder) view.getTag();
			}

			ImageLoader.getInstance()
					.displayImage(IMAGE_URLS[position], holder.imageView, options, new SimpleImageLoadingListener() {
						@Override
						public void onLoadingStarted(String imageUri, View view) {
							//设置进度条为0
							holder.progressBar.setProgress(0);
							//开始下载时显示
							holder.progressBar.setVisibility(View.VISIBLE);
						}

						@Override
						public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
							//下载失败隐藏
							holder.progressBar.setVisibility(View.GONE);
						}

						@Override
						public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
							//下载失败隐藏
							holder.progressBar.setVisibility(View.GONE);
						}
					}, new ImageLoadingProgressListener() {
						@Override
						public void onProgressUpdate(String imageUri, View view, int current, int total) {
							//current当前进度,total总进度
							holder.progressBar.setProgress(Math.round(100.0f * current / total));
						}
					});

			return view;
		}
	}

	static class ViewHolder {
		ImageView imageView;
		ProgressBar progressBar;
	}
}</span>

主界面布局:

<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <GridView
	android:id="@+id/grid"
	android:layout_width="match_parent"
	android:layout_height="match_parent"
	android:gravity="center"
	android:horizontalSpacing="4dip"
	android:numColumns="3"
	android:stretchMode="columnWidth"
	android:verticalSpacing="4dip"
	android:padding="4dip" />

</LinearLayout>
</span>

grid_item布局:

<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="match_parent"
	android:layout_height="120dip">

	<ImageView
		android:id="@+id/image"
		android:layout_width="match_parent"
		android:layout_height="120dip"
		android:adjustViewBounds="true"
		android:contentDescription="@string/descr_image"
		android:scaleType="centerCrop" />

	<ProgressBar
		android:id="@+id/progress"
		android:layout_width="match_parent"
		android:layout_height="wrap_content"
		android:indeterminate="false"
		android:max="100"
		android:layout_gravity="bottom"
		style="@style/ProgressBarStyle" />
</FrameLayout></span>

进度条样式:

<span style="font-size:18px;"><style name="ProgressBarStyle" parent="@android:style/Widget.Holo.ProgressBar.Horizontal"/></span>

ImageLoader配置:

<span style="font-size:18px;">public class MyApp extends Application {

	@Override
	public void onCreate() {
		super.onCreate();
		initImageLoader1(getApplicationContext());

	}
	/*
	 * 自定义配置
	 */
	public static void initImageLoader(Context context) {
		ImageLoaderConfiguration.Builder config = new ImageLoaderConfiguration.Builder(
				context);
		config.threadPoolSize(3);//线程池内加载的数量
		config.threadPriority(Thread.NORM_PRIORITY - 2);
		config.denyCacheImageMultipleSizesInMemory();// 不缓存图片的多种尺寸在内存中
		config.diskCacheFileNameGenerator(new Md5FileNameGenerator());// 将保存的时候的URI名称用MD5
		config.diskCacheSize(50 * 1024 * 1024); // 50 MiB
		config.tasksProcessingOrder(QueueProcessingType.LIFO);
		config.writeDebugLogs();// Remove for release app
		// 初始化ImageLoader使用
		ImageLoader.getInstance().init(config.build());
	}

	/*
	 * 默认的配置,一般没有特殊的要求的时候就使用默认就好了。
	 */
	public static void initImageLoader1(Context context) {
		// 创建默认的ImageLoader配置参数
		ImageLoaderConfiguration configuration = ImageLoaderConfiguration.createDefault(context);
		// 初始化ImageLoader使用
		ImageLoader.getInstance().init(configuration);
	}
}</span>

这个例子是从上篇文章继续写的,也是在它项目里继续写的。

如果你想在滑动中停止加载,而在停止滑动后再继续加载图片,Universal-Image-Loader也提供了这样的功能,PauseOnScrollListener这个类就是监听。

listView.setOnScrollListener(new PauseOnScrollListener(ImageLoader.getInstance(), pauseOnScroll, pauseOnFling));

PauseOnScrollListener的第一个参数是图片加载对象ImageLoader,第二个是控制是否在滑动过程中暂停加载图片,如果需要暂停传true就行了,第三个参数控制猛的滑动界面的时候图片是否加载。

时间: 2024-12-17 04:42:16

android Universal-Image-Loader框架学习(下)的相关文章

Android Universal Image Loader 使用

1. 功能介绍 1.1 Android Universal Image Loader Android Universal Image Loader 是一个强大的.可高度定制的图片缓存,本文简称为UIL. 简单的说 UIL 就做了一件事--获取图片并显示在相应的控件上. 1.2 基本使用 1.2.1 初始化 添加完依赖后在Application或Activity中初始化ImageLoader,如下: public class YourApplication extends Application

Android Universal Image Loader 架构剖析

简介 Android Universal Image Loader简称UIL, 其github链接https://github.com/nostra13/Android-Universal-Image-Loader, 它用于Android应用中的图片加载(从网络,本地文件,或资源文件),本地缓存(内存和磁盘), 以及展示在ImageView中. 示例 整体框架 各模块的流程图 Task流程: 下载流程: decode流程: cache流程: 主要类图:

Android Universal Image Loader java.io.FileNotFoundException: http:/xxx/lxx/xxxx.jpg

前段时间在使用ImageLoader异步加载服务端返回的图片时总是出现 java.io.FileNotFoundException: http://xxxx/l046/10046137034b1c0db0.jpg at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:177) at com.nostra13.universalimageloader.core.download.URL

Android图片异步加载框架Universal Image Loader的源码分析

项目地址:https://github.com/nostra13/android-universal-image-loader 1. 功能介绍 1.1 Android Universal Image Loader Android Universal Image Loader 是一个强大的.可高度定制的图片缓存,本文简称为UIL. 简单的说 UIL 就做了一件事--获取图片并显示在相应的控件上. 1.2 基本使用 1.2.1 初始化 添加完依赖后在Application或Activity中初始化I

Android 图片加载框架Universal-Image-Loader源码解析

Universal-Image-Loader(项目地址)可以说是安卓知名图片开源框架中最古老.使用率最高的一个了.一张图片的加载对于安卓应用的开发也许是件简单的事,但是如果要同时加载大量的图片,并且图片用于ListView.GridView.ViewPager等控件,如何防止出现OOM.如何防止图片错位(因为列表的View复用功能).如何更快地加载.如何让客户端程序员用最简单的操作完成本来十分复杂的图片加载工作,成了全世界安卓应用开发程序员心头的一大难题,所幸有了Universal-Image-

Android中Universal Image Loader开源框架的简单使用

UIL (Universal Image Loader)aims to provide a powerful, flexible and highly customizable instrument for image loading, caching and displaying. It provides a lot of configuration options and good control over the image loading and caching process.(不知道

Android——Volley框架学习总结

Volley框架特点: 适用于频繁请求而每次请求数据量不会很大: 在请求的基础上做了磁盘缓存: 防止多次相同请求浪费资源: 提供String.Json.图片异步下载: 网络请求的优先级处理: 图片请求无需担心生命周期问题. Volley框架使用: 首先,通过Volley的静态方法new一个请求队列 1 RequestQueue mQueue = Volley.newRequestQueue(context); 假如我们创建一个StringRequest实例(Volley提供,StringRequ

android Universal-Image-Loader框架学习

一.Universal-Image-Loader概述:    Android-Universal-Image-Loader是一个开源的图片加载框架,这个项目的目的是提供一个可重复使用的仪器为异步图像加载,缓存和显示.   开源库的特性: (1).多线程下载图片. (2).可通过配置ImageLoader,改变线程池,图片下载器,等等的配置. (3).支持图片的在内存缓存,文件系统缓存或sd卡缓存. (4).支持图片下载的监听. (5).可以较好的控制图片的加载过程,例如在listview滑动时停

Android Afinal框架学习(二) FinalActivity 一个IOC框架

框架地址:https://github.com/yangfuhai/afinal 对应的源码: net.tsz.afinal.annotation.view.* FinalActivity FinalActivity是一个基础类,结合注解实现了,依赖注入(view的资源id,常用的监听器), 利用set方式注入 完全注解方式就可以进行UI绑定和事件绑定,无需findViewById和set event Listener 这个过程:initInjectedView>findViewById.set

Android SQLite, KopDB 框架学习1——使用

前言 我的博客:http://mrfufufu.github.io/ 最近项目中要用到数据库,因为之前需要本地存储的数据量并不是非常大,SharedPreferences 足以解决大部分的数据存储问题,所以,我们一直没有用到 SQLite.现在产品需要优化私信模块体验,所以增加私信本地存储是非常必要的.这时候用上 SQLite 就非常必要了.好在我们的老大之前就已经封装好了一份非常完善的数据库框架了,拿来就能用.看了源码研究了一天,大概有了写心得体会,整理出来,学习使用. 就给他起名叫 KopD