免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1902 | 回复: 0
打印 上一主题 下一主题

[Android] Android异步下载网络图片(其一) [复制链接]

论坛徽章:
80
20周年集字徽章-庆
日期:2020-10-28 14:09:1215-16赛季CBA联赛之北京
日期:2020-10-28 13:32:5315-16赛季CBA联赛之北控
日期:2020-10-28 13:32:4815-16赛季CBA联赛之天津
日期:2020-10-28 13:13:35黑曼巴
日期:2020-10-28 12:29:1520周年集字徽章-周	
日期:2020-10-31 15:10:0720周年集字徽章-20	
日期:2020-10-31 15:10:07ChinaUnix元老
日期:2015-09-29 11:56:3020周年集字徽章-年
日期:2020-10-28 14:14:56
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-28 13:35 |只看该作者 |倒序浏览
项目中有时候需要获取网络上的图片,并下载下来到手机客户端显示。怎么做呢?

实现思路是:

1:在UI线程中启动一个线程,让这个线程去下载图片。

2:图片完成下载后发送一个消息去通知UI线程

2:UI线程获取到消息后,更新UI。

这里的UI线程就是主线程。

这两个步骤涉及到一些知识点,即是:ProgressDialog,Handler,Thread/Runnable,URL,HttpURLConnection等等一系列东东的使用。

现在让我们开始来实现这个功能吧!

第一步:新建项目。

第二步:设计好UI,如下所示
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.     android:orientation="vertical"
  4.     android:layout_width="fill_parent"
  5.     android:layout_height="fill_parent"
  6.     >
  7.     <Button
  8.       android:id="@+id/btnFirst"
  9.       android:layout_width="fill_parent"
  10.       android:layout_height="wrap_content"
  11.       android:text="异步下载方式一"
  12.      >
  13.     </Button>
  14.    
  15.     <Button
  16.       android:id="@+id/btnSecond"
  17.       android:layout_width="fill_parent"
  18.       android:layout_height="wrap_content"
  19.       android:text="异步下载方式二"
  20.      >
  21.     </Button>
  22.    
  23.     <FrameLayout
  24.      android:layout_width="fill_parent"
  25.      android:layout_height="match_parent"
  26.      android:id="@+id/frameLayout"
  27.     >
  28.    
  29.    <ImageView
  30.     android:id="@+id/image"
  31.     android:layout_width="match_parent"
  32.     android:layout_height="match_parent"
  33.     android:scaleType="centerInside"
  34.     android:padding="2dp"
  35.     >
  36.    </ImageView>
  37.    
  38.     <ProgressBar
  39.      android:id="@+id/progress"
  40.      android:layout_width="wrap_content"
  41.      android:layout_height="wrap_content"
  42.      android:layout_gravity="center">
  43.   </ProgressBar>
  44.    
  45.   </FrameLayout>
  46. </LinearLayout>
复制代码
第三步:获取UI相应View组件,并添加事件监听。
  1. public class DownLoaderActivity extends Activity implements OnClickListener{
  2.     private static final String params="http://upload.wikimedia.org/wikipedia/commons/thumb/e/ea/Hukou_Waterfall.jpg/800px-Hukou_Waterfall.jpg";
  3.     private Button btnFirst,btnSecond;
  4.     private ProgressBar progress;
  5.     private FrameLayout frameLayout;
  6.     private Bitmap bitmap=null;
  7.     ProgressDialog dialog=null;
  8.    
  9.    
  10.     @Override
  11.     public void onCreate(Bundle savedInstanceState) {
  12.         super.onCreate(savedInstanceState);
  13.         setContentView(R.layout.main);
  14.         
  15.         btnFirst=(Button)this.findViewById(R.id.btnFirst);
  16.         btnSecond=(Button)this.findViewById(R.id.btnSecond);
  17.         progress=(ProgressBar)this.findViewById(R.id.progress);
  18.         progress.setVisibility(View.GONE);
  19.         frameLayout=(FrameLayout)this.findViewById(R.id.frameLayout);
  20.         
  21.         btnFirst.setOnClickListener(this);
  22.         btnSecond.setOnClickListener(this);  
  23.     }
复制代码
第四步:在监听事件中处理我们的逻辑,即是下载服务器端图片数据。

这里我们需要讲解一下了。

通常的我们把一些耗时的工作用另外一个线程来操作,比如,下载上传图片,读取大批量XML数据,读取大批量sqlite数据信息。为什么呢?答案大家都明白,用户体验问题。

在这里,首先我构造一个进度条对话框,用来显示下载进度,然后开辟一个线程去下载图片数据,下载数据完毕后,通知主UI线程去更新显示我们的图片。

Handler是沟通Activity 与Thread/runnable的桥梁。而Handler是运行在主UI线程中的,它与子线程可以通过Message对象来传递数据。具体代码如下:
  1. /**这里重写handleMessage方法,接受到子线程数据后更新UI**/
  2.     private Handler handler=new Handler(){
  3.         @Override
  4.         public void handleMessage(Message msg){
  5.             switch(msg.what){
  6.             case 1:
  7.                 //关闭
  8.                 ImageView view=(ImageView)frameLayout.findViewById(R.id.image);
  9.                 view.setImageBitmap(bitmap);
  10.                 dialog.dismiss();
  11.                 break;
  12.             }
  13.         }
  14.     };
复制代码
我们在这里弹出进度对话框,使用HTTP协议来获取数据。
  1. //前台ui线程在显示ProgressDialog,
  2.     //后台线程在下载数据,数据下载完毕,关闭进度框
  3.     @Override
  4.     public void onClick(View view) {
  5.         switch(view.getId()){
  6.         case R.id.btnFirst:
  7.             dialog = ProgressDialog.show(this, "",
  8.                     "下载数据,请稍等 …", true, true);
  9.             //启动一个后台线程
  10.             handler.post(new Runnable(){
  11.                 @Override
  12.                 public void run() {
  13.                      //这里下载数据
  14.                     try{
  15.                         URL  url = new URL(params);
  16.                         HttpURLConnection conn  = (HttpURLConnection)url.openConnection();
  17.                         conn.setDoInput(true);
  18.                         conn.connect();
  19.                         InputStream inputStream=conn.getInputStream();
  20.                         bitmap = BitmapFactory.decodeStream(inputStream);
  21.                         Message msg=new Message();
  22.                         msg.what=1;
  23.                         handler.sendMessage(msg);
  24.                      
  25.                     } catch (MalformedURLException e1) {
  26.                         e1.printStackTrace();
  27.                     } catch (IOException e) {
  28.                         // TODO Auto-generated catch block
  29.                         e.printStackTrace();
  30.                     }  
  31.                 }
  32.             });  
  33.             break;
复制代码
如此以来,你会发现很好的完成了我们的下载目标了,你可以把它应用到其他方面去,举一反三。

运行截图如下:
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP