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. Jmeter的简单练习

    一.安装Jmeter 1.下载Jmeter 下载地址:http://jmeter.apache.org/download_jmeter.cgi 目前最新版为2.9,其余文件如源代码等也可从如下官网下载 ...

  2. 学习Emacs

    1.http://ergoemacs.org/emacs/emacs.html 2.Debian7安装emacs24 http://my.oschina.net/xuzhouyu/blog/14954 ...

  3. 客户端HttpClient处理 Servlet Gzip

    服务端采用gzip对文本内容进行压缩处理,客户端使用HttpClient获取数据并进行gzip解压缩. 一: 服务端 public class GzipTestServlet extends Http ...

  4. Qt中调用PolarSSL库(一)

    最近一直在学习SSL相关的知识,也是先了解理论相关的知识,主要是SSL相关的基本概念和连接建立过程,主要是基于PolarSSL开源库进行学习.学习完了之后就希望能给有所运用,就想用Qt写一个简单的程序 ...

  5. Android ListView实现圆角

    首先呢,我们还是看几个示图: 这种带有圆角的listview' 看起来很棒吧,确实是这样,其实也不能这么说,主要方形太多了,斯通见惯就不值钱了,“物以稀为贵嘛”. 就好比学java都搞androd,很 ...

  6. UESTC_秋实大哥与小朋友 2015 UESTC Training for Data Structures<Problem A>

    A - 秋实大哥与小朋友 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Sub ...

  7. LeeCode-Rotate Array

    Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, the array  ...

  8. 如何区分监督学习(supervised learning)和非监督学习(unsupervised learning)

    监督学习:简单来说就是给定一定的训练样本(这里一定要注意,样本是既有数据,也有数据对应的结果),利用这个样本进行训练得到一个模型(可以说是一个函数),然后利用这个模型,将所有的输入映射为相应的输出,之 ...

  9. 【转】10个你必须掌握的超酷VI命令技巧

    摘要:大部分Linux开发者对vi命令相当熟悉,可是遗憾的是,大部分开发者都只能掌握一些最常用的Linux vi命令,下面介绍的10个vi命令虽然很多不为人知,但是在实际应用中又能让你大大提高效率. ...

  10. JavaWeb——文件上传和下载

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...