把生活的优质寄托于别人,一昧的祈求别人同情和怜悯,短时间可能会有所收获,但随着时间,同情和怜悯最终只会变成反感和厌恶。而真正能够改变自己命运的,只有自己努力。
你若精彩,蝴蝶自来。 ——出自青坏坏语录
大家还记得我们之前用BaseAdapter去实现Spinner的使用吗,其实适配器可以完成的工作不仅仅是Spinner的适配,还有很多控件都可以,比如我们今天要学习的ListView和GridView。
一、ListView实现列表
我们大家都玩过QQ,我们都知道在我们QQ消息栏里面都是这个样子的:
![10608194-ad3ad16ba1672348.png](https://i-blog.csdnimg.cn/blog_migrate/5fdd784560424b4803dd2d5d93b79b3f.png)
今天,我们就用ListView来实现这个效果。
我们先看看实现以后的效果:
![10608194-41f7c1335c0835ea.png](https://i-blog.csdnimg.cn/blog_migrate/b0aeacf3fa472da21ebfc58e113a0f31.png)
首先我们在activity.xml文件中,创建ListView,id设为mLv。
![10608194-b4d8c8040df86dec.png](https://i-blog.csdnimg.cn/blog_migrate/44318bdfc2ffb6a878dfcabb4c74c34e.png)
好了,下面我们来在java代码中声明并赋值。
![10608194-3f4e25c9a86afafb.png](https://i-blog.csdnimg.cn/blog_migrate/f6c39886bcaaa94db88c8774075a6107.png)
很简单,对吧,下面一步我们来先添加一下适配器,
![10608194-7ecbe73dfdb8a7e4.png](https://i-blog.csdnimg.cn/blog_migrate/13a00df5ddfd13fd5a60ba3e02186a4b.png)
我们看到他接收的是一个ListAdapter类型的参数,而BaseAdapter接收ListAdapter接口的抽象类,所以我们可以通过继承实现BaseAdapter类来自定义一个adapter(话有点绕口,多读几遍)。
![10608194-d843605335dcc61d.png](https://i-blog.csdnimg.cn/blog_migrate/536b1424df0082fe4f9e746069ebe442.png)
我起名为TheListAdapter(你们随意)。
跟之前使用BaseAdapter实现Spinner的步骤一样,我们在TheListAdapter中创建了两个参数用于接收传递过来的上下文和集合数据。
![10608194-4c3c80830f0bd2e2.png](https://i-blog.csdnimg.cn/blog_migrate/6d9c999d5953a2ce55fedcf3bd50cda1.png)
在这里我们指定接收的数据类型为Msg类型,这个Msg类型是我自定义的类型,它是用来存储我们消息条目中的数据。
![10608194-a2a305d76fc0a140.png](https://i-blog.csdnimg.cn/blog_migrate/3b9a5528126554f5da23fb3ef4b895a9.png)
我们按照刚才的例子来做,我拿出来其中一个条目来看,他有四个数据量,最左边是图片,然后中间上面是名字,下面是消息,最右边是时间,所以很明确,我们的Msg里面有四个属性,分别是图片id、名字String、消息String、时间String(我是这么个思路,当然你可以有别的思路,同样也可以实现这个)。
![10608194-44968c09e6f9690c.png](https://i-blog.csdnimg.cn/blog_migrate/2c122786b6e35c407b3bc72f9004589d.png)
里面看上去和复杂,其实很少的信息量,四个属性对应我们刚才说的四个,然后就是一个构造器和四个属性分别对应的get和set方法,很简单对吧。
我们回到TheListAdapter中,继续写我们的构造器。根据之前学过的,我们把四个方法分别改写(前三个不谈了,最后一个说一下)。
![10608194-6630d1f2db09ef2b.png](https://i-blog.csdnimg.cn/blog_migrate/a7e9e206c0a62615ae84a94e0cfa89fe.png)
既然我们自己创建了消息类型,那么我们的layout肯定要用自己定义的布局类型,否则我们的上面的四个数据怎么显示(如果数据很简单的话,比如只有一个TextView用String输入的话,那就可以用系统内置的了,不过如果只有一个String,那就不用什么自定义消息类了,直接接受String就好,我这段话大家好好揣摩一下)。
所以我们创建一个layout,名字起为thelist_item,然后把布局设置为我们上面需要的版式,就按照这个就好。
![10608194-9760c6e810af8e55.png](https://i-blog.csdnimg.cn/blog_migrate/da827ef4f99b5335bd9560613d26bf87.png)
![10608194-55eb975579bf906b.png](https://i-blog.csdnimg.cn/blog_migrate/d83172b87153cf58696bea8c55ab19fe.png)
做的还是有莫有样的是吧,其实文字和图片不用添加,(只是有时候为了看看规格是不是正好,看到如果可以的话就去掉数据源就好了),但是id一定要指定,我先声明一下我的id:
图片:head_item ,刚才忘记了,我们指定图片的长款都为40dp。
来源:name_item
信息:msg_item
时间:time_item。
接下来就很简单了,我们继续MyListAdapter适配器的编写。
![10608194-516c6b97f62172a7.png](https://i-blog.csdnimg.cn/blog_migrate/9d4ea05be14c1dcd800ccfd59dfaa631.png)
信息量是不是有点大,我们慢慢来看,
首先第一行我们找到了当前的布局,我们从这个布局中分别获取对应的id,并且分别转换成对应的类型,
然后开始添加数据,而数据的来源就是mList,我们从mList得到对应位置的Msg,并且将对应类型的数据获取、添加到对应控件中。
最后别忘记return convertVIew。
![10608194-afe422e4550ad0d2.png](https://i-blog.csdnimg.cn/blog_migrate/6e285be6e3e1ccd0c2a467d3bdda9345.png)
所以上面这段代码现在看着很清楚了吧,我们创建了一个ArrayList数据来传入适配器,然后将适配器传入mLv中。
现在我们要做的最后一步就是添加假数据:
![10608194-6749da5c58cc6aeb.png](https://i-blog.csdnimg.cn/blog_migrate/d18d5ce911ceaa9b6b665f175881036e.png)
我从网上找到了7个logo图标,我将它添加到项目中。
![10608194-df8ac50104b9530c.png](https://i-blog.csdnimg.cn/blog_migrate/1995b95655cdd0e8aa98fdbf2d8f51fc.png)
好了,我们最后的假数据也添加好了,现在我们开始跑一下程序。
![10608194-842f9b247d0f7239.png](https://i-blog.csdnimg.cn/blog_migrate/07a1b2619739e11bf80c2f556720075e.png)
有点不太美观,不要紧,我们来调整一下间距就好。
![10608194-4555f3d874075f14.png](https://i-blog.csdnimg.cn/blog_migrate/f5b5cc455265393d94ad74dbcc572dac.png)
好了, 现在看着是不是舒服多了,大家现在应该会自己来通过ListView写一个消息列表了吧。