Android开发之ListView实现不同品种分类分隔栏的效果(非ExpandableListView实现)

我们有时候会遇到这么一个情况。就是我在一个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>
时间: 2024-11-08 22:38:08

Android开发之ListView实现不同品种分类分隔栏的效果(非ExpandableListView实现)的相关文章

【转】Android开发之ListView+EditText-要命的焦点和软键盘问题解决办法

Android开发之ListView+EditText-要命的焦点和软键盘问题解决办法 [原文链接] 这篇文章完美的解决了我几个月没结论的bug... 感谢热爱分享的技术达人~ 我是怎么走进这个大坑的..... 需求: 在listview中出一个EditText 接受用户输入消息. 前期解决方案: 给这个EditText绑定焦点事件.... 悲剧就开始了... 知道吗?当这个EditTextView被点了下,它的焦点就不断的获取,失去,获取,失去...  只点一下... 就频繁的重复..最后大部

Android开发之ListView排序

下面是activity: [java] view plaincopy public class MainActivity extends Activity { private ListView mListView = null; private List<TestDate> mList = null; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); s

Android开发之ListView添加多种布局效果演示

在这个案例中展示的新闻列表,使用到ListView控件,然后在适配器中添加多种布局效果,这里通过重写BaseAdapter类中的 getViewType()和getItemViewType()来做判断,指定ListView列表中指定位置的item加载对应的布局,在 getView中返回对应的视图,之前由于不清楚getViewTypeCount()和getItemViewType()方法,使用得比较少,一直以 为需要添加多个适配器,现在看来当时的想法说明自己见识还不够,哈哈. 第一步:创建放置Li

Android开发之ListView中的Button点击设置

在ListView的Item中,如果有Button控件,那么要实现Button和Item点击都有响应,可以将Item的Layout中Button的focusable属性设为false,然后设置layout的属性android:descendantFocusability="blocksDescendants". 代码如下: 1 <?xml version="1.0" encoding="utf-8"?> 2 <LinearLay

Android开发之ListView中Adapter的优化

ListView是Android开发最常用的控件,适配器adapter是将要显示的数据映射到View中并添加到ListView中显示 在实现ListView时,我们需要定义适配器如BaseAdapter.ArrayAdapter.CursorAdapter.SimpleAdapter等,并且重写其一下四个方法: 1 public int getCount(): 2 public Object getItem(int position) 3  public long getItemId(int p

Android开发之ListView条目批量选择删除

ListView实现的列表,假设是可编辑,可删除的,一般都要提供批量删除功能,否则的话,一项一项的删除体验非常不好,也给用户带来了非常大的麻烦. 实现效果图 详细实现代码 select.xml 主布局文件包括一个ListView另一个隐藏的布局,包括了两个Button一个TextView,默认布局为gone,当监听到长按响应事件时候显示. 1 <?xml version="1.0" encoding="utf-8"?> 2 <LinearLayou

Android开发之ListView中BaseAdapter的使用

BaseAdapter,官网链接--http://developer.android.com/intl/zh-cn/reference/android/widget/BaseAdapter.html 继承:Object 接口:ListAdapter  SpinnerAdapter 已知直接子类: ArrayAdapter<T>, CursorAdapter, SimpleAdapter 已知间接子类: ResourceCursorAdapter, SimpleCursorAdapter 使用B

Android开发之ListView利用OnScrollListener实现分页加载数据

上篇博文和大家分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现.

android控件开发之ListView

android控件开发之ListView 本文主要讲述安卓开发中的ListView控件的使用方法 java代码: package com.example.listview; import java.util.ArrayList; import java.util.HashMap; import android.app.ListActivity; import android.os.Bundle; import android.view.Menu; import android.view.View