Android中的AsyncTask异步加载图片

AsyncTask简介:

AsyncTask的特点是任务在主线程之外运行,而回调方法是在主线程中执行,这就有效地避免了使用Handler带来的麻烦。

阅读 AsyncTask的源码可知,AsyncTask是使用java.util.concurrent 框架来管理线程以及任务的执行的,concurrent框架是一个非常 成熟,高效的框架,经过了严格的测试。这说明AsyncTask的设计很好的解决了匿名线程存在的问题。 

AsyncTask是抽象类,AsyncTask定义了三种泛型类型 Params,Progress和Result。 

1,Params 启动任务执行的输入参数,比如HTTP请求的URL。

2,Progress 后台任务执行的百分比

3,Result 后台执行任务最终返回的结果,比如String。 

子类必须实现抽象方法doInBackground(Params… p) ,在此方法中实现任务的执行工作,比如连接网络获取数据等。通常还应该实现onPostExecute(Result r)方法,因为应用程序关心的结果在此方法中返回。需要注意的是AsyncTask一定要在主线程中创 建实例。

       AsyncTask的执行分为四个步骤,每一步都对应一个回调方法,需要注意的是这些方法不应该由应用程序调用,开发者需要做的 就是实现这些方法。在任务的执行过程中,这些方法被自动调用,运行过程:

1,onPreExecute() 当任务执行之前开始调用此方法,可以在这里显示进度对话框。2,doInBackground(Params…) 此方法在后台线程执行,完成任务的主要工作,通常需要较长的时间。在执行过程中可以调用 publicProgress(Progress…)来更新任务的进度。 

3,onProgressUpdate(Progress…) 此方法在主线程执行,用于显示任务执行的进度。

4,onPostExecute(Result) 此方法在主线程执行,任务执行的结果作为此方法的参数返回

activity_main.xml

<?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="wrap_content"
    >

    <ListView
        android:id="@+id/listview"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
          
</LinearLayout>
list_item.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="150dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true" >
        <ImageView
            android:id="@+id/imageView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@android:drawable/alert_dark_frame" />
    </LinearLayout>
</RelativeLayout>
ImageAdapter.java

package com.hust.asynctaskdemo;

import java.util.ArrayList;

import android.content.Context;
import android.graphics.drawable.Drawable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;

public class ImageAdapter extends BaseAdapter {
    private ArrayList<Drawable> imagesArrayList;
    private Context mContext;
	private LayoutInflater mInflater;
	
	public ImageAdapter(ArrayList<Drawable> imagesArrayList, Context mContext) {
		super();
		this.imagesArrayList = imagesArrayList;
		this.mContext = mContext;
		mInflater=LayoutInflater.from(this.mContext);
	}

	@Override
	public int getCount() {	
		return imagesArrayList.size();
	}

	@Override
	public Object getItem(int position) {
		
		return imagesArrayList.get(position);
	}

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

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		ViewHolder mHolder=null;
		if(convertView==null){
			convertView=mInflater.inflate(R.layout.list_item, null);
			mHolder=new ViewHolder();
			mHolder.mImageView=(ImageView) convertView.findViewById(R.id.imageView);
			convertView.setTag(mHolder);
			
		}
		else{
			mHolder=(ViewHolder) convertView.getTag();
		}
		mHolder.mImageView.setImageDrawable(imagesArrayList.get(position));
		
		return convertView;
	}
   public class ViewHolder{
	   public ImageView mImageView;
   }
}
MainActivity.java

package com.hust.asynctaskdemo;

import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import android.support.v7.app.ActionBarActivity;
import android.graphics.drawable.Drawable;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ListView;

public class MainActivity extends ActionBarActivity {
    private  ListView mListView;
	private  ArrayList<String> urlList;
	private  ArrayList<Drawable> imagesData;
		  
	@SuppressWarnings("unchecked")
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		urlList=new ArrayList<String>();
		urlList.add("http://img3.douban.com/view/event_poster/large/public/2a35a85a873e8e7.jpg");
		urlList.add("http://img3.douban.com/view/event_poster/large/public/ce66e0569742fd7.jpg");
		urlList.add("http://img3.douban.com/view/event_poster/large/public/4c44752e83900d9.jpg");
				
		mListView=(ListView) findViewById(R.id.listview);
						
		AsyncTask<ArrayList<String>, Integer, ArrayList<Drawable>> task=new AsyncTask<ArrayList<String>, Integer, ArrayList<Drawable>>(){
             
			@Override
			protected void onPreExecute() {
				// TODO Auto-generated method stub
				super.onPreExecute();
			}

			@Override
			protected ArrayList<Drawable> doInBackground(ArrayList<String>... params) {//params是可变数组参数
				List<String> imageUriList = params[0];
				ArrayList<Drawable> imageList=new ArrayList<Drawable>();
				for(String url:imageUriList){
					try {
						URL mUrl=new URL(url);
						Drawable mDrawable=Drawable.createFromStream(mUrl.openStream(), "src");
						imageList.add(mDrawable);
					} catch (IOException e) {					
						e.printStackTrace();
					}
				}
				return imageList;
			}

			@Override
			protected void onPostExecute(ArrayList<Drawable> result) {
				//imagesData=result;
				 ImageAdapter mImageAdapter=new ImageAdapter(result, MainActivity.this);
				 mListView.setAdapter(mImageAdapter);
				
			}		   		
	    };
	    task.execute(urlList);
	    
	}

	
}
网络权限:

   <uses-permission android:name="android.permission.INTERNET"/>


参考:

http://blog.csdn.net/tianxiangshan/article/details/7871667

http://blog.csdn.net/shineflowers/article/details/41746443









  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值