我们有时候会遇到这么一个情况。就是我在一个ListView里面须要显示的东西事实上是有种类之分的。比方我要分冬天,夏天。秋天。春天,然后在这每一个季节以下再去载入各自的条目数据。

还有,比方我们的通讯录。我们须要按A。B,C这种字母顺序分类然后显示。

这个怎么实现呢?

以下我们不用ExpandableListView。而是仅仅用ListView来实现这一显示效果。

MainActivity.java

[java] view
plain
copy

  1. package com.xzq.listviewadapter;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.view.Window;
  5. import android.widget.ListView;
  6. public class MainActivity extends Activity {
  7. private String[] string = { "A", "B", "C", "D", "E", "F", "G", "H", "I",
  8. "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
  9. "W", "X", "Y", "Z" };
  10. /** Called when the activity is first created. */
  11. @Override
  12. public void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. requestWindowFeature(Window.FEATURE_NO_TITLE);
  15. setContentView(R.layout.main);
  16. ListView listview = (ListView) findViewById(R.id.listview);
  17. MyCustomAdapter adapter = new MyCustomAdapter(this);
  18. int size = string.length;
  19. for (int i = 0; i < size; i++) {
  20. adapter.addSeparatorItem(string[i]);
  21. for (int k = 0; k < 5; k++) {
  22. adapter.addItem("item " + k);
  23. }
  24. }
  25. listview.setAdapter(adapter);
  26. }
  27. }

MyCustomAdapter.java

[java] view
plain
copy

  1. package com.xzq.listviewadapter;
  2. import java.util.ArrayList;
  3. import java.util.TreeSet;
  4. import android.content.Context;
  5. import android.view.LayoutInflater;
  6. import android.view.View;
  7. import android.view.ViewGroup;
  8. import android.widget.BaseAdapter;
  9. import android.widget.TextView;
  10. public class MyCustomAdapter extends BaseAdapter {
  11. private static final int TYPE_ITEM = 0;
  12. private static final int TYPE_SEPARATOR = 1;
  13. private static final int TYPE_MAX_COUNT = TYPE_SEPARATOR + 1;
  14. private ArrayList<String> data = new ArrayList<String>();
  15. private LayoutInflater inflater;
  16. private TreeSet<Integer> set = new TreeSet<Integer>();
  17. public MyCustomAdapter(Context context) {
  18. inflater = LayoutInflater.from(context);
  19. }
  20. public void addItem(String item) {
  21. data.add(item);
  22. }
  23. public void addSeparatorItem(String item) {
  24. data.add(item);
  25. set.add(data.size() - 1);
  26. }
  27. public int getItemViewType(int position) {
  28. return set.contains(position) ? TYPE_SEPARATOR : TYPE_ITEM;
  29. }
  30. @Override
  31. public int getViewTypeCount() {
  32. return TYPE_MAX_COUNT;
  33. }
  34. @Override
  35. public int getCount() {
  36. return data.size();
  37. }
  38. @Override
  39. public Object getItem(int position) {
  40. return data.get(position);
  41. }
  42. @Override
  43. public long getItemId(int position) {
  44. return position;
  45. }
  46. @Override
  47. public View getView(int position, View convertView, ViewGroup parent) {
  48. ViewHolder holder = null;
  49. int type = getItemViewType(position);
  50. if (convertView == null) {
  51. holder = new ViewHolder();
  52. switch (type) {
  53. case TYPE_ITEM:
  54. convertView = inflater.inflate(R.layout.item1, null);
  55. holder.textView = (TextView) convertView
  56. .findViewById(R.id.item1);
  57. break;
  58. case TYPE_SEPARATOR:
  59. convertView = inflater.inflate(R.layout.item2, null);
  60. holder.textView = (TextView) convertView
  61. .findViewById(R.id.item2);
  62. break;
  63. }
  64. convertView.setTag(holder);
  65. } else {
  66. holder = (ViewHolder) convertView.getTag();
  67. }
  68. holder.textView.setText(data.get(position));
  69. return convertView;
  70. }
  71. public static class ViewHolder {
  72. public TextView textView;
  73. }
  74. }

main.xml

[html] view
plain
copy

  1. <?xml version="1.0" encoding="utf-8"?

    >

  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:background="#ffffff"
  6. android:orientation="vertical" >
  7. <ListView
  8. android:id="@+id/listview"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:text="@string/hello" />
  12. </LinearLayout>

item1.xml
[html] view
plain
copy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:background="#ffffff"
  6. android:orientation="vertical" >
  7. <TextView
  8. android:id="@+id/item1"
  9. android:layout_width="fill_parent"
  10. android:layout_height="30dip"
  11. android:gravity="center_vertical" />
  12. </LinearLayout>

item2.xml

[html] view
plain
copy

  1. <?

    xml version="1.0" encoding="utf-8"?>

  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical" >
  6. <TextView
  7. android:id="@+id/item2"
  8. android:layout_width="fill_parent"
  9. android:layout_height="30dip"
  10. android:background="#3c4857"
  11. android:gravity="center_vertical" />
  12. </LinearLayout>

最新文章

  1. WPF的二维绘图(一)——DrawingContext
  2. zepto.js的事件处理
  3. 第二十八课:focusin与focusout,submit,oninput事件的修复
  4. Cheatsheet: 2015.02.01 ~ 02.28
  5. Ubuntu 16.04 Mxnet CPU 版本安装
  6. 安装mysql 5.5.14 报错
  7. Spark 中的join方式(pySpark)
  8. 使用react-native做一个简单的应用-03欢迎界面
  9. Eclipse插件基础篇一
  10. Windows phone 8 学习笔记(1) 触控输入
  11. JavaScript里利用DOM获取宽高大全
  12. hdu_5787_K-wolf Number(数位DP)
  13. css :root 选择器
  14. 《XXX重大技术需求征集系统》的可用性和可修改性战术分析
  15. git merge后如何撤销
  16. C++ 入门[1]
  17. C# 实现Remoting双向通信
  18. [LeetCode&amp;Python] Problem 504. Base 7
  19. ida快捷键
  20. Javascript的闭包及其使用技巧实例

热门文章

  1. 微信小程序组件解读和分析:二、scroll-view可滚动视图区域
  2. SpringBoot(1.5.6.RELEASE)源码解析
  3. MFC_2.3 定时器、滑块、进度条控件
  4. Jenkins系列之Jenkins的安装(一)
  5. 文件和打印共享资源(IP地址)处于联机状态,但未对连接尝试做出响应。
  6. 梦想CAD控件 2019.05.05更新
  7. MYEclipse Available Memory is low 警告 解决方法
  8. 简单的jsonp实现跨域原理
  9. Tensorflow学习笔记(1):tf.slice()函数使用
  10. 「 HDU P2089 」 不要62