Android网络图片异步加载实例
2014-07-25 13:29
369 查看
实现思路是:
1:在UI线程中启动一个线程,让这个线程去下载图片。
2:图片完成下载后发送一个消息去通知UI线程
2:UI线程获取到消息后,更新UI。
这里的UI线程就是主线程。
这两个步骤涉及到一些知识点,即是:ProgressDialog,Handler,Thread/Runnable,URL,HttpURLConnection等等一系列东东的使用。
现在让我们开始来实现这个功能吧!
第一步:新建项目。
第二步:设计好UI,如下所示:
第三步:获取UI相应View组件,并添加事件监听。
第四步:在监听事件中处理我们的逻辑,即是下载服务器端图片数据。
这里我们需要讲解一下了。
通常的我们把一些耗时的工作用另外一个线程来操作,比如,下载上传图片,读取大批量XML数据,读取大批量sqlite数据信息。为什么呢?答案大家都明白,用户体验问题。
在这里,首先我构造一个进度条对话框,用来显示下载进度,然后开辟一个线程去下载图片数据,下载数据完毕后,通知主UI线程去更新显示我们的图片。
Handler是沟通Activity与Thread/runnable的桥梁。而Handler是运行在主UI线程中的,它与子线程可以通过Message对象来传递数据。具体代码如下:
我们在这里弹出进度对话框,使用HTTP协议来获取数据。
如此以来,你会发现很好的完成了我们的下载目标了,你可以把它应用到其他方面去,举一反三。
运行截图如下
1:在UI线程中启动一个线程,让这个线程去下载图片。
2:图片完成下载后发送一个消息去通知UI线程
2:UI线程获取到消息后,更新UI。
这里的UI线程就是主线程。
这两个步骤涉及到一些知识点,即是:ProgressDialog,Handler,Thread/Runnable,URL,HttpURLConnection等等一系列东东的使用。
现在让我们开始来实现这个功能吧!
第一步:新建项目。
第二步:设计好UI,如下所示:
01 | <? xml version = "1.0" encoding = "utf-8" ?> |
02 | < LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" |
03 | android:orientation = "vertical" |
04 | android:layout_width = "fill_parent" |
05 | android:layout_height = "fill_parent" |
06 | > |
07 | < Button |
08 | android:id = "@+id/btnFirst" |
09 | 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 > |
01 | public class DownLoaderActivity extends Activity implementsOnClickListener{ |
02 | private static final String params= "http://upload.wikimedia.org/wikipedia/commons/thumb/e/ea/Hukou_Waterfall.jpg/800px-Hukou_Waterfall.jpg" ; |
03 |
04 | private Button btnFirst,btnSecond; |
05 | private ProgressBar progress; |
06 | private FrameLayout frameLayout; |
07 | private Bitmap bitmap= null ; |
08 | ProgressDialog dialog= null ; |
09 |
10 |
11 | @Override |
12 | public void onCreate(Bundle |
13 | super .onCreate(savedInstanceState); |
14 | setContentView(R.layout.main); |
15 |
16 | btnFirst=(Button) this .findViewById(R.id.btnFirst); |
17 | btnSecond=(Button) this .findViewById(R.id.btnSecond); |
18 | progress=(ProgressBar) this .findViewById(R.id.progress); |
19 | progress.setVisibility(View.GONE); |
20 | frameLayout=(FrameLayout) this .findViewById(R.id.frameLayout); |
21 |
22 | btnFirst.setOnClickListener( this ); |
23 | btnSecond.setOnClickListener( this ); |
24 | } |
这里我们需要讲解一下了。
通常的我们把一些耗时的工作用另外一个线程来操作,比如,下载上传图片,读取大批量XML数据,读取大批量sqlite数据信息。为什么呢?答案大家都明白,用户体验问题。
在这里,首先我构造一个进度条对话框,用来显示下载进度,然后开辟一个线程去下载图片数据,下载数据完毕后,通知主UI线程去更新显示我们的图片。
Handler是沟通Activity与Thread/runnable的桥梁。而Handler是运行在主UI线程中的,它与子线程可以通过Message对象来传递数据。具体代码如下:
01 | **这里重写handleMessage方法,接受到子线程数据后更新UI**/ |
02 | private Handler handler= new Handler(){ |
03 | @Override |
04 | public void handleMessage(Message msg){ |
05 | switch (msg.what){ |
06 | case 1 : |
07 | //关闭 |
08 | ImageView view=(ImageView)frameLayout.findViewById(R.id.image); |
09 | view.setImageBitmap(bitmap); |
10 | dialog.dismiss(); |
11 | break ; |
12 | } |
13 | } |
14 | }; |
01 | //前台ui线程在显示ProgressDialog, |
02 | //后台线程在下载数据,数据下载完毕,关闭进度框 |
03 | @Override |
04 | public void onClick(View |
05 | switch (view.getId()){ |
06 | case R.id.btnFirst: |
07 | dialog= ProgressDialog.show( this , "" , |
08 | "下载数据,请稍等 …" , true , true ); |
09 | //启动一个后台线程 |
10 | handler.post( new Runnable(){ |
11 | @Override |
12 | public void run() { |
13 | //这里下载数据 |
14 | try { |
15 | URL new URL(params); |
16 | HttpURLConnection |
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 |
26 | e1.printStackTrace(); |
27 | } catch (IOException |
28 | // |
29 | e.printStackTrace(); |
30 | } |
31 | } |
32 | }); |
33 | break ; |
34 | } |
35 | } |
运行截图如下
相关文章推荐
- Android Async异步操作实例---加载网络图片(慕课网笔记)
- 实例讲解Android中如何实现图片的异步加载功能
- android Gallery实现异步加载网络图片 并只加载当前停止页面图
- Android在网络异步加载图片方式总结
- [Android] AsyncTask使用实例---加载网络图片
- 实例讲解Android中如何实现图片的异步加载功能
- Android异步加载网络图片
- Android网络图片异步加载
- Android异步加载网络图片-good
- android开发--ListView+Json+异步网络图片加载+滚动翻页的例子(图片能缓存,图片不错乱)
- Android异步网络加载图片的控件
- 实例讲解Android中如何实现图片的异步加载功能
- Android Listview异步动态加载网络图片
- android异步回调加载网络图片
- android中listView实现异步加载网络图片
- Android从网络上 异步加载图片
- Android 异步加载网络图片
- android中listView实现异步加载网络图片
- Android中网络图片的异步加载
- Android ListView异步加载网络图片