Android使用AsyncTask實現(xiàn)多線程下載的方法
本文實例講述了Android使用AsyncTask實現(xiàn)多線程下載的方法。分享給大家供大家參考,具體如下:
public class MainActivity extends Activity implements OnClickListener { private Button btn1, btn2, btn3; private ProgressBar progressBar1, progressBar2, progressBar3; private ImageView img1, img2, img3; private static final String IMG_URI = "http://www.dbjr.com.cn/images/logo.gif"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); initListener(); } /** * 初始化監(jiān)聽器 */ private void initListener() { btn1.setOnClickListener(this); btn2.setOnClickListener(this); btn3.setOnClickListener(this); } /** * * 初始化控件 */ private void initView() { btn1 = (Button) findViewById(R.id.btn1); btn2 = (Button) findViewById(R.id.btn2); btn3 = (Button) findViewById(R.id.btn3); progressBar1 = (ProgressBar) findViewById(R.id.progressbar1); progressBar2 = (ProgressBar) findViewById(R.id.progressbar2); progressBar3 = (ProgressBar) findViewById(R.id.progressbar3); img1 = (ImageView) findViewById(R.id.img1); img2 = (ImageView) findViewById(R.id.img2); img3 = (ImageView) findViewById(R.id.img3); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public void onClick(View arg0) { // 點擊按鈕模擬下載 MyDownloadAsy down = new MyDownloadAsy(); down.execute(IMG_URI, arg0.getId() + ""); } /** * 1.Params,傳遞給后臺任務的參數類型。 * * 2.Progress,后臺計算執(zhí)行過程中,進步單位(progress units)的類型。(就是后臺程序已經執(zhí)行了百分之幾了。) * * 3.Result, 后臺執(zhí)行返回的結果的類型。 */ class MyDownloadAsy extends AsyncTask<String, Integer, Bitmap> { private static final String TAG = "asy"; private int clickBtn = 0; private void i(String object) { Log.i(TAG, object); } @Override protected void onPreExecute() { // TODO Auto-generated method stub super.onPreExecute(); i("準備運行線程"); progressBar1.setProgress(0);// 進度條復位 progressBar2.setProgress(0);// 進度條復位 progressBar3.setProgress(0);// 進度條復位 } @Override protected Bitmap doInBackground(String... arg0) { switch (Integer.parseInt(arg0[1])) { case R.id.btn1: clickBtn = 1; break; case R.id.btn2: clickBtn = 2; break; case R.id.btn3: clickBtn = 3; break; default: break; } i("正在后臺執(zhí)行"); publishProgress(0); // 下載圖片 HttpClient hc = new DefaultHttpClient(); // 等待2s sleepWait(); publishProgress(50); HttpGet hg = new HttpGet(arg0[0]);// 獲取jb51的logo final Bitmap bm; try { HttpResponse hr = hc.execute(hg); bm = BitmapFactory.decodeStream(hr.getEntity().getContent()); } catch (Exception e) { return null; } sleepWait(); publishProgress(100); // mImageView.setImageBitmap(result); 不能在后臺線程操作ui return bm; } /** * 等待2s鐘 */ private void sleepWait() { try { Thread.sleep(2000); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } } protected void onProgressUpdate(Integer... values) { // 動態(tài)更新 i("進度更新"); switch (clickBtn) { case 1: progressBar1.setProgress(values[0]);// 更新進度條的進度 break; case 2: progressBar2.setProgress(values[0]);// 更新進度條的進度 break; case 3: progressBar3.setProgress(values[0]);// 更新進度條的進度 break; default: break; } } protected void onPostExecute(Bitmap result) { // TODO Auto-generated method stub super.onPostExecute(result); i("線程執(zhí)行完成"); if (result != null) { i("下載圖片成功"); switch (clickBtn) { case 1: img1.setImageBitmap(result); break; case 2: img2.setImageBitmap(result); break; case 3: img3.setImageBitmap(result); break; default: break; } } else { i("下載圖片失敗"); } } @Override protected void onCancelled() { // TODO Auto-generated method stub super.onCancelled(); i("取消線程"); switch (clickBtn) { case 1: progressBar1.setProgress(0);// 進度條復位 break; case 2: progressBar2.setProgress(0);// 進度條復位 break; case 3: progressBar3.setProgress(0);// 進度條復位 break; default: break; } } } }
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" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <TableLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_centerHorizontal="true" > <TableRow> <Button android:id="@+id/btn1" android:text="@string/btn1" /> <ProgressBar android:id="@+id/progressbar1" style="?android:attr/progressBarStyleHorizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <ImageView android:id="@+id/img1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:contentDescription="@id/img1" android:src="@drawable/ic_launcher" /> </TableRow> <TableRow> <Button android:id="@+id/btn2" android:text="@string/btn2" /> <ProgressBar android:id="@+id/progressbar2" style="?android:attr/progressBarStyleHorizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <ImageView android:id="@+id/img2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:contentDescription="@id/img2" android:src="@drawable/ic_launcher" /> </TableRow> <TableRow> <Button android:id="@+id/btn3" android:text="@string/btn3" /> <ProgressBar android:id="@+id/progressbar3" style="?android:attr/progressBarStyleHorizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <ImageView android:id="@+id/img3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:contentDescription="@id/img3" android:src="@drawable/ic_launcher" /> </TableRow> </TableLayout> </RelativeLayout>
AndroidManifast:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.xunfang.asynctackdemo" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="10" android:targetSdkVersion="10" /> <!-- 訪問網絡的權限 --> <uses-permission android:name="android.permission.INTERNET" > </uses-permission> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.xunfang.asynctackdemo.MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
更多關于Android相關內容感興趣的讀者可查看本站專題:《Android調試技巧與常見問題解決方法匯總》、《Android開發(fā)入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
- android教程之使用asynctask在后臺運行耗時任務
- Android帶進度條的文件上傳示例(使用AsyncTask異步任務)
- Android中AsyncTask異步任務使用詳細實例(一)
- Android中使用AsyncTask實現(xiàn)文件下載以及進度更新提示
- Android 中使用 AsyncTask 異步讀取網絡圖片
- Android中使用AsyncTask實現(xiàn)下載文件動態(tài)更新進度條功能
- Android使用AsyncTask下載圖片并顯示進度條功能
- 詳解Android中AsyncTask的使用方法
- Android AsyncTask詳解及使用方法
- Android中AsyncTask的入門使用學習指南
相關文章
Kotlin開發(fā)實戰(zhàn)之hello world
這篇文章主要為大家詳細介紹了Kotlin開發(fā)實戰(zhàn)之hello world的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05學習使用Material Design控件(四)Android實現(xiàn)標題欄自動縮放、放大效果
這篇文章主要為大家介紹了學習使用Material Design控件的詳細教程,Android實現(xiàn)標題欄自動縮放、放大效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07android實現(xiàn)ViewPager的Indicator的實例代碼
本篇文章主要介紹了android實現(xiàn)ViewPager的Indicator的實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02Android自定義View實現(xiàn)仿網易音樂唱片播放效果
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)仿網易音樂唱片播放效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04