2016/4/5 17:22】
之前写listview其实写了很多次,但好像还是模模糊糊的感觉,直到今天准备写tab的时候被告诉说原理有像的地方,于是我就先来分析整理一下listview好了
 
先来一种非常自然的理解方式:
ListView其实就是一个View中放入数据呗,于是它的使用原理很可能是这样:
很好理解:
  1. 先得到数据
  2. 然后得到layout中的listview对象
  3. 然后把数据输入到对象中
 
但其实这里稍微有个实际的问题,就是第三步中,数据是不能直接传入listview中的
这也很好理解,因为
  1. 数据可能有很多种,各种各样的,肯定需要一种固定格式的数据才行,所以普通数据到这种特殊的固定格式,就需要适配器了
  2. Listview展示的不止是数据,一条条的List还有布局呢,所以你还需要传入一个布局文件
 
于是安卓中通过一个通用的适配器类(可以通过它来定制自己的)来实现这两个功能
 
这一步的变化就像这样:
    to
 
所以实际的原理示意图会是这样:
 
 

而更加实际的应用中是这样:
 
1、定义一个data类
就是一个data unit,可以定义成bean的形式
但之后真正传给adapter的其实是data list,传入一个List,然后到时候listview显示的顺序就是往List添加dataitem的顺序
代码:
public class Zchooseproject {
        private String name ;
        private String place ;
        private int imageId ;
       
        //这是从外面传入数据的方法
        public Zchooseproject(String name ,String place , int imageId) {
               this.name = name ;
               this.place = place ;
               this.imageId = imageId ;
       }
        //这两个是在外面取数据的方法
        public String getName() {
               return name ;
       }
        public String getPlace() {
               return place ;
       }
        public int getImageId() {
               return imageId ;
       }
              
}
 
2、写一个itemlayout
就是普通的Layout,但是它高度是固定的,不能是matchparent(下面的例子里这块搞得有点怪,因为里边使用了wrap_content)
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent" >
<ImageView
android:id="@+id/fruit_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/fruit_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="10dip" />
</LinearLayout>
 
3、接下来需要创建一个自定义的适配器
这个适配器继承自 ArrayAdapter(是官方适配器的一种),并将泛型指定 为我们的data类。
  1. Adapter重写了父类的一组构造函数,用于将上下文、ListView子项布局的 id和数 据都传递进来
  2. 另外又重写了 getView()方法,这个方法在每个子项被滚动到屏幕内的时候 会被调用
    1. 在 getView方法中,首先通过 getItem()方法得到当前项的 Fruit实例(这个有点怪,不过没事)
    2. 然后使用 LayoutInflater来为这个子项加载我们传入的布局
    3. 接着调用 View的 findViewById()方法分别 获取到 ImageView和 TextView的实例,并分别调用它们的 setImageResource()和 setText()方 法来设置显示的图片和文字
    4. 最后将布局返回,这样我们自定义的适配器就完成了。
 
代码如下所示:
      public class Zchooseprojectadapter extends ArrayAdapter<Zchooseproject> {
               private int resourceId ;
               public Zchooseprojectadapter(Context context , int textViewResourceId,List<Zchooseproject> objects ) {
                      super(context , textViewResourceId , objects );
                      resourceId = textViewResourceId ;
              }
               @Override
               public View getView(int position, View convertView, ViewGroup parent) {
 
                     Zchooseproject fruit = getItem( position); // 获取当前项的Fruit实例
 
                     View view = LayoutInflater.from(getContext()).inflate( resourceId, null );
                     
                     ImageView fruitImage = (ImageView) view.findViewById(R.id.fruit_image);//获取itemlayout中的控件
                     TextView fruitName = (TextView) view.findViewById(R.id.fruit_name);
                     TextView fruitName2 = (TextView) view.findViewById(R.id.place);
 
                      fruitImage.setImageResource(fruit .getImageId());
                      fruitName.setText(fruit .getName());
                      fruitName2.setText(fruit .getPlace());
                     
                      return view ;
              }
     }
 
4、OK,在onCreate方法中装配adapter吧!
4.1、初始化data list
              private List<Zchooseproject> fruitList = new ArrayList<Zchooseproject>();
 
              Zchooseproject apple = new Zchooseproject("项目名称" ,"项目地点      项目信息", R.drawable. icon_project);
               fruitList.add(apple );
              Zchooseproject banana = new Zchooseproject("项目名称" ,"项目地点      项目信息", R.drawable. icon_project);
               fruitList.add(banana );
              Zchooseproject orange = new Zchooseproject("项目名称" ,"项目地点      项目信息", R.drawable. icon_project);
               fruitList.add(orange );
                         ......
              Zchooseproject mango = new Zchooseproject("项目名称" ,"项目地点      项目信息", R.drawable. icon_project);
               fruitList.add(mango );
4.2、装配adapter
              Zchooseprojectadapter adapter = new Zchooseprojectadapter(this ,R.layout.z_chooseprojectitem, fruitList);
 
5、结束!装配ListView
              ListView listView = (ListView) findViewById(R.id. list_view);
               listView.setAdapter( adapter);
 
因为贴图的繁琐。。。所以以上图片不完整。。。完整的在这里:

通俗易懂的ListView讲解(Adapter、图、实例)的更多相关文章

  1. Android listview与adapter用法

    listview与adapter用法 博客分类: android   一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView ...

  2. ListView 和 Adapter用法

    一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView就是实现这个功能的.第二点也不难做到,在后面的学习中读者会发现,这非常 ...

  3. 【转】Android listview与adapter用法

    一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView就是实现这个功能的.第二点也不难做到,在后面的学习中读者会发现,这非常 ...

  4. listview与adapter用法

    Android listview与adapter用法 listview与adapter用法 博客分类: android   一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用 ...

  5. ListView适配器Adapter介绍与优化

    一.ListView与Adapter的关系 ListView是Android开发过程中较为常见的组件之一,它将数据以列表的形式展现出来.一般而言,一个ListView由以下三个元素组成: 1.View ...

  6. ListView和Adapter的配合使用以及Adapter的重写

    ListView和Adapter的使用   首先介绍一下ListView是Android开发过程中较为常见的组件之一,它将数据以列表的形式展现出来.一般而言,一个ListView由以下三个元素组成: ...

  7. ListView及Adapter的使用

    一.使用ArrayAdapter 其中ArrayAdapter的构造函数有如下几个,其中resource是指每个列表项的布局文件,objects是指列表项的数据源,此处通常指一个数组 ArrayAda ...

  8. android 开发之 ListView 与Adapter 应用实践

    在开发android中,ListView 的应用显得非常频繁,只要需要显示列表展示的应用,可以说是必不可少,下面是记录开发中应用到ListView与Adapter 使用的实例: ListView 所在 ...

  9. 通俗易懂--SVM算法讲解(算法+案例)

    1.SVM讲解 新闻分类案例 SVM是一个很复杂的算法,不是一篇博文就能够讲完的,所以此篇的定位是初学者能够接受的程度,并且讲的都是SVM的一种思想,通过此篇能够使读着会使用SVM就行,具体SVM的推 ...

随机推荐

  1. 汇编语言学习笔记(5)——[bx]和loop

    1.[bx]代表将bx寄存器中的值作为偏移地址. 2.loop与循环有关 3.inc bx的含义为bx中的内容+1 4.loop指令的格式为: loop 标号 CPU运行loop指令的时候.要进行两步 ...

  2. C# keybd_event模拟对照表以及用法.

    Windows提供了一个模拟键盘API函数Keybd_event(),该函数能触发一个按键事件,也就是说会产生一个WM_KEYDOWN或WM_KEYUP消息. [DllImport("use ...

  3. 十大免费教程资源帮助新手快速学习JavaScript

    “JavaScript”的名头相信大家肯定是耳熟能详,但只有一小部分人群了解它的使用与应用程序构建方式.这“一小部分”人指的当然是技术过硬的有为青年.网络程序员以及IT专业人员.但对于一位新手或者说外 ...

  4. .NET通过async/await实现并行

    如果可以并行可以大大提高性能,但在我们的使用中,不可能全是并行的也是要有线行操作,所以我们需要在业务逻辑层进行并行操作的护展: 数据访问层不变还是以前一样如下: public class UserDA ...

  5. 如何在IIS7下配置ASP+ACCESS环境

    如何在IIS7下配置ASP+ACCESS环境 | 浏览:901 | 更新:2013-01-16 17:46 1 2 3 4 5 6 7 分步阅读 默认装完IIS7之后,使用ASP程序会发现提示数据库连 ...

  6. android 打包流程

    .使用Android SDK提供的aapt.exe生成R.java类文件 .使用Android SDK提供的aidl.exe把.aidl转成.java文件(如果没有aidl,则跳过这一步) .使用JD ...

  7. thinking in object pool

    1.背景 对象池为了避免频繁创建耗时或耗资源的大对象,事先在对象池中创建好一定数量的大对象,然后尽量复用对象池中的对象,用户用完大对象之后放回对象池. 2.问题 目前纵观主流语言的实现方式无外乎3个步 ...

  8. php中并发读写文件冲突的解决方案(文件锁应用示例)

    PHP(外文名: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言.语法吸收了C语言.Java和Perl的特点,入门门槛较低,易于学习,使用广泛,主要适 ...

  9. CSS - Select 标签在不同浏览器中的高度设置

    当使用Select标签时,在不同浏览器中显示的高度不同,如何解决此问题: 解决方法链接:http://stackoverflow.com/questions/20477823/select-html- ...

  10. 使用NSKeyedArchiver归档

    将各种类型的对象存储到文件中,而不仅仅是字符串.数组和字典类型,有一种更灵活的方法.就是利用NSKeyedAarchiver类创建带键(keyed)的档案来完成. Mac OS X从版本10.2开始支 ...