列表视图(ListView和ListActivity)

在ListView中显示网络图片

 ImageView 类虽然有一个 setImageUri 方法,但不能直接接受一个由网络地址生成的uri作为参数从而显示图片,我们只好使用其 setImageBitmap 方法来转换。 

我们来做一个如下的文章列显示:

先声明一个类文章类来初始化数据:

public class ListViewItemData {
        private String itemTitle;
        private String itemPhoto;
        private String itemSummary;
        private String itemAuthor;
        private String itemPublishtime;

        public ListViewItemData() {
            super();
        }

        public ListViewItemData(String itemTitle, String itemPhoto, String itemSummary, String itemAuthor, String itemPublishtime) {
            super();
            this.itemTitle = itemTitle;
            this.itemPhoto = itemPhoto;
            this.itemSummary = itemSummary;
            this.itemAuthor = itemAuthor;
            this.itemPublishtime = itemPublishtime;
        }

        public String getTitle() {
            return this.itemTitle;
        }

        public Bitmap getPhoto() {
            String url = this.itemPhoto;
            URL myFileUrl = null;
            Bitmap bitmap = null;
            try {
                myFileUrl = new URL(url);
                HttpURLConnection conn = (HttpURLConnection) myFileUrl.openConnection();
                conn.setDoInput(true);//连接设置获得数据流
                conn.connect();
                InputStream is = conn.getInputStream();
                bitmap = BitmapFactory.decodeStream(is);
                is.close();
            } catch (IOException e) {
                e.printStackTrace();
            }

            return bitmap;
        }

        public String getSummary() {
            return this.itemSummary;
        }

        public String getAuthor() {
            return this.itemAuthor;
        }

        public String getPublishtime() {
            return this.itemPublishtime;
        }
    }

其中getPhoto方法根据URL用来获得在线图片,返回对应的Bitmap。

制造数据,一般来说是从网络上获得,此处为了方便手工造:

public List<ListViewItemData> getListData() {
        List<ListViewItemData> listData = new ArrayList<ListViewItemData>();
        listData.add(new ListViewItemData("android异常总结一", "http://pic.cnitblog.com/face/u471123.jpg?id=07112321", "一、场景再现=========================同事甲:搞什么搞,已经两年没参加忘年会了,今年又在这里加班。同事乙:都一样,赶上今天你值夜班,能有什么办法。同事甲:人家忘年会有东西吃,你饿不饿?叫外卖?同事乙:好哦,还是上次那家吧。========================= 二", "烈火残躯", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("HTML5 History API实现无刷新跳转", "http://pic.cnitblog.com/face/306530/20140307103012.png", "本篇和大家一起了解一下Windows 8.1 中磁贴的更新,我们来看看如何利用它做出更好的应用磁贴。首先我们从展现形式上来对比一下Windows 8 与 Windows 8.1 中的磁贴:Windows 8支持两种尺寸的磁贴,正方形磁贴(150 * 150 像素)和长方形磁贴(310 * 150 像", "sdsdsds", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("c++ 异常处理(1)", "http://pic.cnitblog.com/face/u46305.jpg", "图文化的说明,.net程序员,入职后的发展路线。我将发展路线归为三类。1、技术专精;2、产品策划;3、数据运营。并对每条路线进行了优劣势分析。欢迎各位一起来讨论,不能这么浑浑噩噩的折腾了", "幕后黑手-Boss", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("服务器批量管理工具的快速开发", "http://pic.cnitblog.com/face/603528/20140316211142.png", "当我们需要控制一个局域网中的很多台服务器时,一个简单的全局操作可能会被放大地异常繁琐,这时我们就会需要新的工具来帮助我们快速完成这种工作。在本文中,我们在ssh客户端提供的一些工具的基础上完成这一工具的开发,我们的开发平台是GNU/Linux。我们将会开发四个有用的小工具,下面即是我们整个系统的鸟瞰", "东邪独孤", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("揭秘uc浏览器一", "http://pic.cnitblog.com/face/440253/20140306132605.png", "首先,看一下项目完成后的,最终效果是这样的:一.主界面二,书签界面三、主界面四.操作对话框界面这几个界面你是否看到了uc浏览器的影子了,其实我说你也可以了,在接下来篇幅中,我将手把手叫大家完成这个浏览器。首先,我们从主界面开始吧,这是一个主线,项目的一些开始由他开始了。从图一中,我们可以看出其布局文", "laozhu1124", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("【WPF】制作自定义的列表项面板", "http://pic.cnitblog.com/face/367389/20140226103259.png", "我们在使用像ListBox的列表控件时,我们都知道可以通过其ItemsPanel的依赖项属性来自定义一个面板来放置列表控件中的列表项。除了CLR库提供的几个面板外,我们完全可以把自己写的面板作为项列表的容器。先给各位看看效果。如何?效果还好吧?面板的原理是这样的:1、从Panel类派出一个类,我命名", "东邪独孤2", "2014-03-19 22:19"));
        return listData;
    }

然后生成SimpleAdapter需要的数据:

public ArrayList<HashMap<String, Object>> getItem() {

        List<ListViewItemData> listData = this.getListData();
        ArrayList<HashMap<String, Object>> item = new ArrayList<HashMap<String, Object>>();
        for (ListViewItemData data : listData) {
            HashMap<String, Object> map = new HashMap<String, Object>();
            map.put("itemTitle", data.getTitle());
            map.put("itemPhoto", data.getPhoto());
            map.put("itemSummary", data.getSummary());
            map.put("itemAuthor", data.getAuthor());
            map.put("itemPublishtime", data.getPublishtime());
            item.add(map);
        }
        return item;
    }

ListView中item布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:descendantFocusability="afterDescendants"
    android:orientation="vertical" >

    <!-- 博文题目 -->

    <TextView
        android:id="@+id/viewTitle"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:layout_marginTop="5dp"
        android:lines="1"
        android:textColor="#0000FF"
        android:textStyle="bold" />
    <!-- 作者头像和博文概要 -->

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:layout_marginTop="2dp"
        android:orientation="horizontal" >

        <ImageView
            android:id="@+id/imgPhoto"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="2dp"
            android:src="@drawable/ic_launcher"
             />

        <TextView
            android:id="@+id/viewSummary"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="2dp"
            android:lines="3" />
    </LinearLayout>
    <!-- 作者昵称和发布日期 -->

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="2dp"
        android:layout_marginLeft="5dp"
        android:layout_marginTop="2dp"
        android:orientation="horizontal" >

        <TextView
            android:id="@+id/viewAuthor"
            android:layout_width="80dp"
            android:layout_height="wrap_content"
            android:textColor="#0000FF" />

        <TextView
            android:id="@+id/viewPublishtime"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </LinearLayout>

</LinearLayout>

还需要一个ListView,此处我用了一个list_separator_line图片来分隔上下行:

<LinearLayout 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:orientation="vertical" >

    <ListView
        android:id="@+id/listView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:divider="@drawable/list_separator_line" />

</LinearLayout>

 

在SimpleAdapter中需要一个数据源,用来存储数据的,在显示图片时我们要用HashMap<>存储一个Bitmap;但仅存取了Bitmap时在ListView中是无法显示图片的,我们需要对SimpleAdapter进行处理 。

如下是对SimpleAdaptr处理的主要代码

 

simpleAdapter.setViewBinder(new ViewBinder() {

            @Override
            public boolean setViewValue(View view, Object data, String textRepresentation) {
                // 判断是否为我们要处理的对象
                if (view instanceof ImageView && data instanceof Bitmap) {
                    ImageView iv = (ImageView) view;
                    iv.setImageBitmap((Bitmap) data);
                    return true;
                } else
                    return false;

            }
        });

然后给ListView绑定,MainActivity完整代码:

package com.example.androidlistview;

import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.R.integer;
import android.R.string;
import android.os.Bundle;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.view.Menu;
import android.view.View;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.SimpleAdapter.ViewBinder;

public class MainActivity extends Activity {

    private ListView listView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        listView = (ListView) this.findViewById(R.id.listView);
        // 创建简单适配器SimpleAdapter
        SimpleAdapter simpleAdapter = new SimpleAdapter(this, this.getItem(), R.layout.listview_item, new String[] { "itemTitle", "itemPhoto", "itemSummary", "itemAuthor", "itemPublishtime" }, new int[] { R.id.viewTitle, R.id.imgPhoto, R.id.viewSummary, R.id.viewAuthor, R.id.viewPublishtime });
        simpleAdapter.setViewBinder(new ViewBinder() {

            @Override
            public boolean setViewValue(View view, Object data, String textRepresentation) {
                // 判断是否为我们要处理的对象
                if (view instanceof ImageView && data instanceof Bitmap) {
                    ImageView iv = (ImageView) view;
                    iv.setImageBitmap((Bitmap) data);
                    return true;
                } else
                    return false;

            }
        });
        // 加载SimpleAdapter到ListView中
        listView.setAdapter(simpleAdapter);

  

      // 添加点击事件
      listView.setOnItemClickListener(new OnItemClickListener() {

      @Override
      public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
      // 获得选中项的HashMap对象
      HashMap<String, Object> map = (HashMap<String, Object>) listView.getItemAtPosition(arg2);
      String title = map.get("itemTitle").toString();
      String content = map.get("itemAuthor").toString();
      Toast.makeText(getApplicationContext(), "你选择了第" + arg2 + "个Item,itemTitle的值是:" + title + "itemAuthor的值是:" + content, Toast.LENGTH_SHORT).show();
      }

      });

    }

    /**
     * @return
     */
    public ArrayList<HashMap<String, Object>> getItem() {

        List<ListViewItemData> listData = this.getListData();
        ArrayList<HashMap<String, Object>> item = new ArrayList<HashMap<String, Object>>();
        for (ListViewItemData data : listData) {
            HashMap<String, Object> map = new HashMap<String, Object>();
            map.put("itemTitle", data.getTitle());
            map.put("itemPhoto", data.getPhoto());
            map.put("itemSummary", data.getSummary());
            map.put("itemAuthor", data.getAuthor());
            map.put("itemPublishtime", data.getPublishtime());
            item.add(map);
        }
        return item;
    }

    public List<ListViewItemData> getListData() {
        List<ListViewItemData> listData = new ArrayList<ListViewItemData>();
        listData.add(new ListViewItemData("android异常总结一", "http://pic.cnitblog.com/face/u471123.jpg?id=07112321", "一、场景再现=========================同事甲:搞什么搞,已经两年没参加忘年会了,今年又在这里加班。同事乙:都一样,赶上今天你值夜班,能有什么办法。同事甲:人家忘年会有东西吃,你饿不饿?叫外卖?同事乙:好哦,还是上次那家吧。========================= 二", "烈火残躯", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("HTML5 History API实现无刷新跳转", "http://pic.cnitblog.com/face/306530/20140307103012.png", "本篇和大家一起了解一下Windows 8.1 中磁贴的更新,我们来看看如何利用它做出更好的应用磁贴。首先我们从展现形式上来对比一下Windows 8 与 Windows 8.1 中的磁贴:Windows 8支持两种尺寸的磁贴,正方形磁贴(150 * 150 像素)和长方形磁贴(310 * 150 像", "sdsdsds", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("c++ 异常处理(1)", "http://pic.cnitblog.com/face/u46305.jpg", "图文化的说明,.net程序员,入职后的发展路线。我将发展路线归为三类。1、技术专精;2、产品策划;3、数据运营。并对每条路线进行了优劣势分析。欢迎各位一起来讨论,不能这么浑浑噩噩的折腾了", "幕后黑手-Boss", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("服务器批量管理工具的快速开发", "http://pic.cnitblog.com/face/603528/20140316211142.png", "当我们需要控制一个局域网中的很多台服务器时,一个简单的全局操作可能会被放大地异常繁琐,这时我们就会需要新的工具来帮助我们快速完成这种工作。在本文中,我们在ssh客户端提供的一些工具的基础上完成这一工具的开发,我们的开发平台是GNU/Linux。我们将会开发四个有用的小工具,下面即是我们整个系统的鸟瞰", "东邪独孤", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("揭秘uc浏览器一", "http://pic.cnitblog.com/face/440253/20140306132605.png", "首先,看一下项目完成后的,最终效果是这样的:一.主界面二,书签界面三、主界面四.操作对话框界面这几个界面你是否看到了uc浏览器的影子了,其实我说你也可以了,在接下来篇幅中,我将手把手叫大家完成这个浏览器。首先,我们从主界面开始吧,这是一个主线,项目的一些开始由他开始了。从图一中,我们可以看出其布局文", "laozhu1124", "2014-03-19 22:19"));
        listData.add(new ListViewItemData("【WPF】制作自定义的列表项面板", "http://pic.cnitblog.com/face/367389/20140226103259.png", "我们在使用像ListBox的列表控件时,我们都知道可以通过其ItemsPanel的依赖项属性来自定义一个面板来放置列表控件中的列表项。除了CLR库提供的几个面板外,我们完全可以把自己写的面板作为项列表的容器。先给各位看看效果。如何?效果还好吧?面板的原理是这样的:1、从Panel类派出一个类,我命名", "东邪独孤2", "2014-03-19 22:19"));
        return listData;
    }

    @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;
    }

}

以上就是一般的对于网络图片绑定ListView处理方式,好一点的处理方式是定制扩展一个SimpleAdapter专用来处理图片绑定。

 

注意:此例是显示网络图片 要记得添加权限,否则报错:java.net.SocketException: Permission denied

<uses-permission android:name="android.permission.INTERNET">

时间: 2024-12-30 16:54:20

列表视图(ListView和ListActivity)的相关文章

listview-改变列表视图ListView中的字体和背景

问题描述 改变列表视图ListView中的字体和背景 我想改变列表视图ListView中的字体(颜色和大小)和背景.我想用代码改变而不是想通过设置xml的属性实现.以下的list view看起来就像xml: <?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" andr

关于列表视图listview的单元格滚动坐标定位的计算。

问题描述 关于列表视图listview的单元格滚动坐标定位的计算. 关于列表视图listview的单元格滚动坐标定位的计算.怎么在滚动视图以后计算单元格相对屏幕的坐标位置呢? 解决方案 提个思路:知道listview.getChildAt(index)吧?然后看看这个http://blog.csdn.net/youshi520000/article/details/50327225 解决方案二: http://blog.csdn.net/lilybaobei/article/details/81

Qt qml中listview 列表视图控件(下拉刷新、上拉分页、滚动轴)_Android

Qt qml listview下拉刷新和上拉分页主要根据contentY来判断.但要加上顶部下拉指示器.滚动条,并封装成可简单调用的组件,着实花了我不少精力:) 先给大家展示下效果图: [功能] 下拉刷新和上拉分页逻辑 /下拉刷新 /上拉更多 /滚动栏 /工具栏半拉显隐 Author: surfsky.cnblogs.com Lisence: MIT 请保留此文档声明 History: init. surfsky.cnblogs.com, 2015-01 add initPosition pro

listview-lazyadapter 列表视图

问题描述 lazyadapter 列表视图 我想把 ListView 中 selected item 的值传递到另一个 activity 中.我用下面的代码获取 hashmap 的相关细节,但是却获得 java.lang.Integer cannot be cast to java.util.HashMap 错误. public void onItemClick(AdapterView<?> parent View view int position long id) { HashMap<

android-Android中列表视图和对话框问题

问题描述 Android中列表视图和对话框问题 在自定义对话框里有一个id:列表视图.我想在列表中输入R.array.tones资源中的字符串.这个类继承 Activity而不是ListActivity.使用以下代码,系统报错:toneList有一个异常的空指针. Dialog dialog = new Dialog(this); dialog.setContentView(R.layout.tone_dialog); dialog.setTitle(R.string.tonePromptTit

listview-如何从自定义列表视图获得选中的项?

问题描述 如何从自定义列表视图获得选中的项? 程序中的自定义列表视图的每一行都包含许多TextViews,当我点击List Item时,OnListItemClick()没有被调用.如何获取一个自定义列表视图中选中的项? XML for Row: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/ap

android-如何获得列表视图的位置

问题描述 如何获得列表视图的位置 现在 Listview 的 onListItemClick()方法中有问题,不能获取 list 的位置.这是我使用的代码请大家帮忙.coverletterselection.xml <RelativeLayout xmlns:android=""http://schemas.android.com/apk/res/android"" android:layout_width=""wrap_content&q

Android用户界面设计:“.NET研究”创建列表视图程序

列表视图(ListView)是Android平台下用于显示不定数量的数据最有用的视图控件之一.在这个教程中,我们将向你展示如何使用ListView来浏览文章列表. 在之前的文章中,你看到了许多关于不同布局控件的教程.在今天这个教程中,你将结合使用它们.应用程序本身非常简单:它将显示文章标题列表,当点击标题时,显示文章内容.这篇文章的节奏将比我们的入门教程更快一些.如果你对基本的Android控件或概念不熟悉你可能需要复习这个网站上我们其它的一些教程,甚至是Android API参考.最终的开源代

Android用户界面设计:创建列表视图程序

列表视图(ListView)是Android平台下用于显示不定数量的数据最有用的视图控件之一.在这个教程中,我们将向你展示如何使用ListView来浏览文章列表. 在之前的文章中,你看到了许多关于不同布局控件的教程.在今天这个教程中,你将结合使用它们.应用程序本身非常简单:它将显示文章标题列表,当点击标题时,显示文章内容.这篇文章的节奏将比我们的入门教程更快一些.如果你对基本的Android控件或概念不熟悉你可能需要复习这个网站上我们其它的一些教程,甚至是Android API参考.最终的开源代