ListView加载网络数据和图片

2013-09-25 00:08:10|  分类: 默认分类 |  标签:android  |举报|字号 订阅

 
 
如,从服务器端获得商品名称、价格、简介和图片,加载到Android ListView中。又如加载微博内容。

 
需了解熟悉:
1、ListView行布局,排版,getView方法
这个案例可以说是实现ListView图文混排的网络版。关于在ListView中实现排版的方法,参      考:http://blog.163.com/ppy2790@126/blog/static/1032422412013731115643829/
2、异步任务的实现,Handler+Thread , AsyncTask
3、JSON解析方式
 
 
实现思路:
1、异步加载服务器访问商品数据(json格式)
      封装网络访问的方法
2、json数据转为Adapter数据(List<Map<String,Object>>)
     封装数据转换的方法
3、Adapter先加载文本内容信息
     使用AsyncTask加载网络访问的集合数据
     加载ListView中的文本信息
4、json数据中有图片信息(路径),异步读取加载图片
    采用接口回调的方法,加载图片信息(Handler+Thread)
 

public class HttpUtil {

public static final String BASE_URL = "http://10.0.2.2:8080/jsontest/servlet/ProductServlet";

public static final String IMG_URL = "http://10.0.2.2:8080/jsontest/upload/";

public static HttpClient httpClient = new DefaultHttpClient();

// post方法访问服务器,返回json字符串

public static String getRequest(String url){

String result = null;

HttpGet httpGet = new HttpGet(url);

try {

HttpResponse httpResponse = httpClient.execute(httpGet);

if (httpResponse.getStatusLine().getStatusCode() == 200) {

result = EntityUtils.toString(httpResponse.getEntity(),"utf-8");

}

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

return result;

}

// 字符串转成集合数据

public static void resultString2List(List<Map<String ,Object>> list, String str,String title) {

try {

JSONObject jsonObject = new JSONObject(str);

JSONArray jsonArray = jsonObject.getJSONArray(title);

for (int i = 0; i < jsonArray.length(); i++) {

JSONObject jsonObject2 = jsonArray.getJSONObject(i);

Map<String ,Object> map = new HashMap<String, Object>();

Iterator<String> iterator = jsonObject2.keys();

while (iterator.hasNext()) {

String key = iterator.next();

Object value = jsonObject2.get(key);

map.put(key, value);

}

list.add(map);

}

} catch (JSONException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

// post方法访问服务器,返回集合数据

public static List<Map<String,Object>> getRequest2List(String url,String title){

List<Map<String,Object>> list = new ArrayList<Map<String ,Object>>();

resultString2List(list, url, title);

return list;

}

// get方法访问服务器,返回json字符串

public static String postRequest(String url, Map<String,String> rawParams) throws Exception{

HttpPost post = new HttpPost(url);

List<NameValuePair> params = new ArrayList<NameValuePair>();

for (String key:rawParams.keySet()) {

params.add(new BasicNameValuePair(key, rawParams.get(key)));

}

post.setEntity(new UrlEncodedFormEntity(params, "UTF-8"));

HttpResponse httpResponse = httpClient.execute(post);

if(httpResponse.getStatusLine().getStatusCode() == 200){

String result = EntityUtils.toString(httpResponse.getEntity());

return result;

}

return null;

}

//post访问的方法,还可继续封装,略。。。

}

异步任务,得到网络json转换的集合数据,并在完成后加载到listview中(onPostExcute方法中执行)

public class MyTask extends AsyncTask<String, Void, List<Map<String,Object>>>{

@Override

protected void onPreExecute() {

// TODO Auto-generated method stub

super.onPreExecute();

progressDialog.show();

}

@Override

protected void onPostExecute(List<Map<String, Object>> result) {

// TODO Auto-generated method stub

super.onPostExecute(result);

adapter.setData(result);

listview.setAdapter(adapter);

adapter.notifyDataSetChanged();

progressDialog.dismiss();

}

@Override

protected List<Map<String, Object>> doInBackground(String... params) {

// TODO Auto-generated method stub

List<Map<String,Object>> list ;

String str = HttpUtil.getRequest(params[0]);

list = HttpUtil.getRequest2List(str, "products");

return list;

}

}

 
OnCreate()方法中启动异步任务:

progressDialog = new ProgressDialog(this);

progressDialog.setTitle("正在下载....");

adapter = new MyAdapter(this);

new MyTask().execute(HttpUtil.BASE_URL);

 
Adapter:
 

public class MyAdapter extends BaseAdapter{

private Context context;

private LayoutInflater layoutInflater;

private List<Map<String,Object>> list;

public MyAdapter(Context context) {

this.context = context;

layoutInflater = layoutInflater.from(context);

}

public List getData(){

return list;

}

public void setData(List<Map<String,Object>> data){

this.list = data;

}

@Override

public int getCount() {

// TODO Auto-generated method stub

return list.size();

}

@Override

public Object getItem(int position) {

// TODO Auto-generated method stub

return list.get(position);

}

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

// TODO Auto-generated method stub

View view = null;

final ViewHolder viewHolder;

if (convertView == null ) {

convertView = layoutInflater.inflate(R.layout.item, null);

viewHolder = new ViewHolder();

viewHolder.id = (TextView)convertView.findViewById(R.id.textView1);

viewHolder.name = (TextView)convertView.findViewById(R.id.textView2);

viewHolder.address = (TextView)convertView.findViewById(R.id.textView3);

viewHolder.img = (ImageView)convertView.findViewById(R.id.imageView1);

convertView.setTag(viewHolder);

}else{

viewHolder = (ViewHolder)convertView.getTag();

}

viewHolder.id.setText(list.get(position).get("sid").toString());

viewHolder.name.setText(list.get(position).get("name").toString());

viewHolder.address.setText(list.get(position).get("addr").toString());

//接口回调的方法,完成图片的读取;

DownImage downImage = newDownImage(HttpUtil.IMG_URL+list.get(position).get("pic").toString()+".jpg");

downImage.loadImage(new ImageCallBack() {

@Override

public void getDrawable(Drawable drawable) {

// TODO Auto-generated method stub

viewHolder.img.setImageDrawable(drawable);

}

});

return convertView;

}

}

public class ViewHolder{

ImageView img;

TextView id;

TextView name;

TextView address;

}

 
 
异步加载图片的类:

public class DownImage {

public String image_path;

public DownImage(String image_path) {

this.image_path = image_path;

}

public void loadImage(final ImageCallBack callBack){

final Handler handler = new Handler(){

@Override

public void handleMessage(Message msg) {

// TODO Auto-generated method stub

super.handleMessage(msg);

Drawable drawable = (Drawable) msg.obj;

callBack.getDrawable(drawable);

}

};

new Thread(new Runnable() {

@Override

public void run() {

// TODO Auto-generated method stub

try {

Drawable drawable = Drawable.createFromStream(new URL(image_path).openStream(), "");

Message message = Message.obtain();

message.obj = drawable;

handler.sendMessage(message);

} catch (MalformedURLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}).start();

}

public interface ImageCallBack{

public void getDrawable(Drawable drawable);

}

}

listview加载网络图片的更多相关文章

  1. 详解ListView加载网络图片的优化,让你轻松掌握!

    详解ListView加载网络图片的优化,让你轻松掌握! 写博客辛苦了,转载的朋友请标明出处哦,finddreams(http://blog.csdn.net/finddreams/article/de ...

  2. 详解ListView加载网络图片的优化

    我们来了解一些ListView在加载大量网络图片的时候存在的常见问题: 1.性能问题,ListView的滑动有卡顿,不流畅,造成非常糟糕的用户体验. 2.图片的错位问题. 3.图片太大,加载Bitma ...

  3. [android]完美的解决方案ListView加载网络图片反弹问题

    为什么 先说为什么有照片反弹. 使用convertView对ListView的每一个item优化,item的复用能够有效减少内存的占用.使ListView滑动更为流畅. 但会带来一个问题,当最顶部的i ...

  4. (BUG已修改,最优化)安卓ListView异步加载网络图片与缓存软引用图片,线程池,只加载当前屏之说明

    原文:http://blog.csdn.net/java_jh/article/details/20068915 迟点出更新的.这个还有BUG.因为软引应不给力了.2.3之后 前几天的原文有一个线程管 ...

  5. wemall app商城源码Android之ListView异步加载网络图片(优化缓存机制)

    wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之L ...

  6. Android中用双缓存技术,加载网络图片

    最近在学校参加一个比赛,写的一个Android应用,里面要加载大量的网络图片,可是用传统的方法图片一多就会造成程序出现内存溢出而崩溃.因为自己也在学习中,所以看了很多博客和视频,然后参照这些大神的写源 ...

  7. Gilde加载网络图片(一)

    前两天 一个朋友要在本地加载几M的大图 用于用户滚动查看.按照思路 是压缩后加载显示但是这样会不清晰, 其实gilde用来加载图片 很牛掰 于是了解一下 下面贴上两个工具类: package com. ...

  8. Afianl加载网络图片(续)

    上一篇已经讲了如何利用Afianl加载网络图片和下载文件,这篇文章将继续讲解使用Afinal加载网络图片的使用,主要结合listview的使用: 看效果图: listview在滑动过程中没用明显卡顿, ...

  9. 【WPF】wpf image控件加载网络图片不显示问题,

    1.加载网络图片到内存system.drawing.image对象中2.内存中的image 转Bitmap 再转适合system.windows.controls.image 的BitmapImage ...

随机推荐

  1. mysql中的意向锁IS,IX

    知识储备: 1.官方文档上说mysql是支持非锁定读的:这个功能是这样实现的,如果事务a 要对行的数据进行更新的话,那么事务a要得到行的x锁,并把这一行  之前的样子记录在undo log里面,这样一 ...

  2. BZOJ 3529 数表(莫比乌斯反演)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3529 思路:令F(i)为i的约数和, 1<=x<=n,1<=y<=m G(i ...

  3. Windows7里的“计算器”你真的会用吗?

    “计算器”是不同Windows版本中的必备工具,虽然功能单一,但的确是人们日常工作中不可缺少的辅助工具,本文就来谈谈它的使用. 一.标准型和科学型两种面板 我们既可从Windows附件菜单中启动它,也 ...

  4. Redhat关闭SELinux和防火墙的办法(转)

    Redhat使用了SELinux来增强安全,关闭的办法为:1. 永久有效修改 /etc/selinux/config 文件中的 SELINUX="" 为 disabled ,然后重 ...

  5. [Ubuntu]在Ubuntu下搭建自己的源服务器

    1.摘要     网上有很很多关于搭建源镜像的文章,但是对于一般人来讲,用不着镜像所有的deb包,只对我们能用到的感兴趣.另外,对于一些在Ubuntu的源中没有的软件,我们也可以放在我们自己的源里,这 ...

  6. swing的第一课

    Swing介绍 Swing API 可扩展 GUI组件,以减轻开发者的生活创造基于JAVA前端/GUI应用.它是建立在AWT API之上,并作为 AWTAPI 的更换,因为它几乎每一个控制对应 AWT ...

  7. Android学习总结——适配器

    适配器是AdapterView视图(如ListView - 列表视图控件.Gallery - 缩略图浏览器控件.GridView - 网格控件.Spinner - 下拉列表控件.AutoComplet ...

  8. ROI 脚本

    ROI: receiving open interface, 是提供给客户的接口, 通过 ROI 客户能够不通过EBS form 界面做receiving 的动作, 而是通过脚本插入相关的接口表 ( ...

  9. APPCAN学习笔记004---AppCan与Hybrid,appcan概述

    APPCAN学习笔记004---AppCan与Hybrid,appcan概述 技术qq交流群:JavaDream:251572072 本节讲了appcan的开发流程,和开发工具 笔记不做具体介绍了,以 ...

  10. 杭电 3887 Counting Offspring

    根据上篇翻译的文章以及很多个帖子,都讲述了树状数组最基本的功能就是tree[i]保存的是位置i左边小于等于a[i]的数的个数. 这样也就可以解释代码中为什么有f[i]=getsum(sd[i-1])- ...