Android之ListView常用技巧

时间:2023-03-09 06:08:03
Android之ListView常用技巧

  ListView是一个非常常用的列表控件,虽然在5.x时代ListView的风头正在逐渐的被RecyclerView抢去,但是ListView的使用范围依然十分广泛.

  接下来的ListView的常用技巧是在平时的开发和学习中了解到的,如有雷同,纯属我抄!

  •   技巧1:设置项目间分隔线
  •   技巧2:隐藏滚动条
  •   技巧3:设置第一个可视条目是第几项
  •   技巧4:添加/取消item的点击效果.
  •   技巧5:处理数据项为空的时候的ListView
  •  技巧6:动态更新ListView

  

  下面依次介绍

  1.设置项目间的分割线

    这是个很常用的使用技巧,开发中可以使用ListView提供的divider和dividerHeight这个属性去完成,如下-->

    android:divider="#ff0000"   这里可以设置颜色等属性,可以自定义颜色的十六进制数值,也可以使用Android提供的颜色

    android:dividerHeight="5dp"  这里通过输入的数值设置分割线的高度

    ***某些时候可能不需要项目间的分隔线,如右--> android:divider="@null"

  2.隐藏滚动条

    隐藏滚动条很简单,只要在控件中加入一个属性便可,如右-->  android:scrollbars="none"

  3.设置第一个可视条目是第几项

    初始化ListView控件以后,再调用setSelection(int a)方法,

    private ListView listView;

    listView = (ListView)findViewById(R.id.listView);

    listView.setSelection(5);   //****这一句需要放在setAdapter之后执行

  4.添加/取消item的点击效果

    点击ListView中的一项,系统默认的会有一个点击效果.5.0以下是一个改变背景颜色的效果,5.0以上是一个波纹效果

    这个效果可以通过修改listSelector属性来添加/取消点击后的回馈效果,如下-->

    android:listSelector="#ff0000"

    android:listSelector="@android:color/transparent"

  5.处理数据项为空的时候的ListView

    开发中经常会遇到列表获取不到数据的情况,导致数据为空,这个时候如果什么都不做,就会显示一片空白,这样用户体验会非常不好.

    为了避免这种情况,,可以预先做一下处理.如下-->

    listView.setEmptyView();

  

  6.动态更新ListView

    列表数据发生改变的时候,可以通过重新设置ListView的Adapter来实现列表数据更新,但是这样会很不友好,效率也不高.

    这里可以用一个更简单的方法去处理.

    当数据列表的数据源发生改变时:adapter.notifyDataSetChange();

  代码:

  MainActivity.java

  

 package com.cx.listview;

 import java.util.ArrayList;

 import android.app.Activity;
 import android.os.Bundle;
 import android.view.Menu;
 import android.view.MenuItem;
 import android.view.View;
 import android.view.View.OnClickListener;
 import android.widget.AdapterView;
 import android.widget.AdapterView.OnItemClickListener;
 import android.widget.Button;
 import android.widget.ListView;
 import android.widget.Toast;

 public class MainActivity extends Activity {
     private Button button;
     private ListView listView;
     private MyAdapter adapter;
     private ArrayList<String> mDataList;
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
         button = (Button) findViewById(R.id.addData);
         listView = (ListView) findViewById(R.id.listView);

         initData();
         initView();
         initEvent();
     }

     private void initData() {
         mDataList = new ArrayList<String>();
         for(int i=0;i<40;i++){
             mDataList.add("这是条目"+(i+1));
         }
         adapter = new MyAdapter(this,mDataList);

     }
     private void initView() {
         listView.setEmptyView(View.inflate(this, R.layout.empty_view, null)); //处理空ListView
         listView.setAdapter(adapter);
         listView.setSelection(5);  //这一句需要放在setAdapter后面执行,否则无效

     }

     private void initEvent() {
         button.setOnClickListener(new OnClickListener() {

             @Override
             public void onClick(View v) {
                 mDataList.add(0, "新添加的数据!");
 //                mDataList.add("新添加的数据!");
                 adapter.notifyDataSetChanged();  //d动态修改ListView
             }
         });

         listView.setOnItemClickListener(new OnItemClickListener() {

             @Override
             public void onItemClick(AdapterView<?> parent, View view,
                     int position, long id) {
                 Toast.makeText(MainActivity.this, "这是第"+(position+1)+"个条目!", Toast.LENGTH_SHORT).show();

             }

         });

     }
 }

MyAdapter.java

 package com.cx.listview;

 import java.util.ArrayList;

 import android.content.Context;
 import android.view.View;
 import android.view.ViewGroup;
 import android.widget.BaseAdapter;
 import android.widget.TextView;

 public class MyAdapter extends BaseAdapter {
     private ArrayList<String> mDataList;
     private Context context;
     public MyAdapter(Context context, ArrayList<String> mDataList) {
         this.mDataList = mDataList;
         this.context = context;
     }

     @Override
     public int getCount() {
         // TODO Auto-generated method stub
         return mDataList.size();
     }

     @Override
     public Object getItem(int position) {
         // TODO Auto-generated method stub
         return mDataList.get(position);
     }

     @Override
     public long getItemId(int position) {
         // TODO Auto-generated method stub
         return position;
     }

     @Override
     public View getView(int position, View convertView, ViewGroup parent) {
         // TODO Auto-generated method stub
         ViewHolder holder;
         if(convertView == null){
             holder = new ViewHolder();
             convertView = View.inflate(context, R.layout.list_item, null);
             holder.text = (TextView) convertView.findViewById(R.id.item_text);
             convertView.setTag(holder);
         }else{
             holder = (ViewHolder) convertView.getTag();
         }
         holder.text.setText(mDataList.get(position));

         return convertView;
     }

     class ViewHolder{
         TextView text;
     }

 }

activity_main.xml

  

 <RelativeLayout 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"
 >

     <Button
         android:id="@+id/addData"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:text="添加数据"
         />
     <ListView
         android:id="@+id/listView"
         android:layout_width="match_parent"
         android:layout_height="match_parent"
         android:layout_margin="5dp"
         android:layout_below="@id/addData"
         android:divider="#ff0000"
            android:dividerHeight="5dp"
            android:scrollbars="none"
            android:listSelector="#00ff00"
         />

 </RelativeLayout>

empty_view.xml

  

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

 <ImageView
     android:id="@+id/empty_view"
     android:layout_width="match_parent"
     android:layout_height="match_parent"
     android:src="@drawable/ic_launcher"
     />
 </LinearLayout>

  

  效果图:

  

  Android之ListView常用技巧