Android ListView常用小技巧汇总

ListView在我们Android项目中的地位是有目共睹的,相信几乎每一个App中都有它的身影。
ListView主要是用列表形式来加载数据,在特定情况下需要实现一些特殊功能:如刷新数据,加载数据,实现动画效果等。
作为我们常用的控件,有哪些需要注意的呢?
**为ListView的每一Item设置分隔线

第一种方法:也是最简单地方法,在布局文件中设置ListView的
divider属性
如:android:divider=”@color/black”
第二种方法:设置android:divider=”@null”表示不要分隔线,然后,自己在Item布局中添加分隔线。

 <ListView>
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:divider="#d1d1d1"<!--设置分隔线颜色-->
    android:dividerHeight="1px"<!--设置分隔线高度-->
    >
 </ListView>

** 默认情况下,ListView的item有点击效果,怎么样改变这种效果呢?
设置ListViewr的android:listSelector属性,比如可以设置透明取消这种效果android:listSelector=”@android:color/transparent”
也可以设置自己想要的效果,添加对应的color资源或drawble资源 就可以了。
** 当数据比较多的时候,ListView在滚动时候会显示一个默认的滚动条,要取消这个滚动条的话,可以设置android:scrollbars属性
如:android:scrollbars=”none”
** ListView性能优化,必用ViewHolder来充分发挥ListView的recycle机制
** ListView中数据动态变化,添加或删除数据操作,效果显而易见。

//实现ListView数据添加删除
public class MainActivity extends Activity implements View.OnClickListener {
  private ListView test_lv;
  private List<TestBean> dataList;
  private TestAdapter adapter;
  private Button add_btn, del_btn;
  private ImageView emptyIv;
  private LinearLayout operator_ll;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initDatas();
    initViews();

  }

  private void initDatas() {
    dataList = new ArrayList<>();
    for (int i = 0; i < 5; i++) {
      TestBean bean = new TestBean();
      bean.setTitle("标题_" + i);
      bean.setContent("这是内容_" + i);
      bean.setType(i % 2 == 0 ? 1 : 2);
      dataList.add(bean);
    }
  }

  private void initViews() {
    this.test_lv = (ListView) findViewById(R.id.test_lv);
    this.add_btn = (Button) findViewById(R.id.add_btn);
    this.del_btn = (Button) findViewById(R.id.del_btn);
    emptyIv = (ImageView) findViewById(R.id.empty_iv);
    operator_ll=(LinearLayout)findViewById(R.id.operator_ll);
    this.add_btn.setOnClickListener(this);
    this.del_btn.setOnClickListener(this);
    if (dataList.size() == 0) {
      emptyIv.setVisibility(View.VISIBLE);
      operator_ll.setVisibility(View.GONE);
      test_lv.setEmptyView(emptyIv);
    } else {
      emptyIv.setVisibility(View.GONE);
      operator_ll.setVisibility(View.VISIBLE);
      adapter = new TestAdapter(this, dataList);
      test_lv.setAdapter(adapter);
    }
    test_lv.setSelection(15);
  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.add_btn:
        //默认增加在第一个位置
        TestBean bean = new TestBean();
        bean.setTitle("增加项");
        bean.setContent("这是增加内容");
        bean.setType(1);
        dataList.add(0, bean);
        break;
      case R.id.del_btn:
        //默认删除第一条数据
        dataList.remove(0);
        break;
    }
    adapter.notifyDataSetChanged();//刷新ListView数据
  }
}
//ListView对应Adapter
public class TestAdapter extends BaseAdapter {
  private Context mContext;
  private List<TestBean> listDatas;

  public TestAdapter(Context mContext, List<TestBean> listDatas) {
    this.mContext = mContext;
    this.listDatas = listDatas;
  }

  @Override
  public int getCount() {
    return listDatas.size();
  }

  @Override
  public Object getItem(int position) {
    return listDatas.get(position);
  }

  @Override
  public long getItemId(int position) {
    return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    if (convertView == null) {
      holder = new ViewHolder();
      convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null);
      holder.title = (TextView) convertView.findViewById(R.id.item_title);
      holder.content = (TextView) convertView.findViewById(R.id.item_content);
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder) convertView.getTag();
    }
    holder.content.setText(listDatas.get(position).getContent());
    holder.title.setText(listDatas.get(position).getTitle());
    return convertView;
  }

  final class ViewHolder {
    TextView title;
    TextView content;
  }
}

** 类似聊天界面,ListView中有多种item样式效果

//实现ListView中多种item样式
public class TypeActivity extends Activity {
  private ListView type_lv;
  private List<TestBean> dataList;
  private TypeAdapter adapter;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_type);
    initDatas();
    initViews();

  }

  private void initDatas() {
    dataList = new ArrayList<>();
    for (int i = 0; i < 9; i++) {
      TestBean bean = new TestBean();
      bean.setTitle("标题_" + i);
      bean.setContent("这是内容_" + i);
      bean.setType(i % 2 == 0 ? 1 : 2);
      dataList.add(bean);
    }
  }

  private void initViews() {
    this.type_lv = (ListView) findViewById(R.id.type_lv);
    adapter = new TypeAdapter(this, dataList);
    type_lv.setAdapter(adapter);

  }
}
//对应Adapter
public class TypeAdapter extends BaseAdapter {
  private Context mContext;
  private List<TestBean> listDatas;

  public TypeAdapter(Context mContext, List<TestBean> listDatas) {
    this.mContext = mContext;
    this.listDatas = listDatas;
  }

  @Override
  public int getCount() {
    return listDatas.size();
  }

  @Override
  public Object getItem(int position) {
    return listDatas.get(position);
  }

  @Override
  public long getItemId(int position) {
    return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    //根据样式设置不同的布局及数据展示
    int type = getItemViewType(position);
    if (convertView == null) {
      holder = new ViewHolder();
      if (type == 1) {
        convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null);
        holder.title = (TextView) convertView.findViewById(R.id.item_title);
        holder.content = (TextView) convertView.findViewById(R.id.item_content);
      } else {
        convertView = LayoutInflater.from(mContext).inflate(R.layout.type_item, null);
        holder.title = (TextView) convertView.findViewById(R.id.type_title);
        holder.content = (TextView) convertView.findViewById(R.id.type_title);
      }
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder) convertView.getTag();
    }
    holder.content.setText(listDatas.get(position).getContent());
    holder.title.setText(listDatas.get(position).getTitle());
    return convertView;
  }
//关键方法之getViewTypeCount:获取有多少种样式
  @Override
  public int getViewTypeCount() {
    return 2;
  }
//关键方法之getItemViewType:获取item类型
  @Override
  public int getItemViewType(int position) {
    return listDatas.get(position).getType();
  }

  final class ViewHolder {
    TextView title;
    TextView content;
  }
}

相关布局

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
  android:orientation="vertical">

  <LinearLayout
    android:id="@+id/operator_ll"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <Button
      android:id="@+id/add_btn"
      android:layout_width="0dp"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:gravity="center"
      android:text="添加" />

    <Button
      android:id="@+id/del_btn"
      android:layout_width="0dp"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:gravity="center"
      android:text="删除" />
  </LinearLayout>

  <ListView
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:divider="#d1d1d1"<!--分隔线颜色-->
    android:dividerHeight="1px"<!--分隔线高度-->
    android:listSelector="@android:color/transparent"<!--取消默认点击效果-->
    android:scrollbars="none"><!--隐藏滚动条-->
    </ListView>

  <ImageView
    android:id="@+id/empty_iv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_marginTop="100dp"
    android:src="@mipmap/empty"
    android:visibility="gone" />

</LinearLayout>

activity_type.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
  android:orientation="vertical">

  <ListView
    android:id="@+id/type_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    ></ListView>

</LinearLayout>

test_item.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="wrap_content"
 android:orientation="vertical"
 android:paddingLeft="15dp"
 android:layout_marginTop="5dp"
 android:layout_marginBottom="5dp">

 <TextView
  android:id="@+id/item_title"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:text="Hello World!" />

 <TextView
  android:id="@+id/item_content"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_marginTop="5dp"
  android:text="Hello World!" />
</LinearLayout>

以上就是搜集的Android ListView常用小技巧全部内容,希望对大家的学习有所帮助。

(0)

相关推荐

  • Android ListView物流获取追踪功能实现

    ListView 控件可使用四种不同视图显示项目.通过此控件,可将项目组成带有或不带有列标头的列,并显示伴随的图标和文本. 最近在网上看到时间轴的布局效果,尝试按照这个原理,实现物流跟踪的效果,目前已经实现了,效果如下图 该效果完全是使用ListView来实现了,下面我们来看一下是如何实现的 (一):布局ListView并编写Item布局 首先需要在布局上面编写ListView: <RelativeLayout xmlns:android="http://schemas.android.c

  • Android中ListView下拉刷新的实现方法

    ListView中的下拉刷新是非常常见的,也是经常使用的,看到有很多同学想要,那我就整理一下,供大家参考.那我就不解释,直接上代码了. 这里需要自己重写一下ListView,重写代码如下: package net.loonggg.listview; import java.util.Date; import android.content.Context; import android.util.AttributeSet; import android.view.LayoutInflater;

  • Android中ListView用法实例分析

    本文实例分析了Android中ListView用法.分享给大家供大家参考,具体如下: 通过在Layout中添加ListView Widget可以达到在页面布局具有列表效果的交互页面.在这里通过举例来说明怎样在Layout中添加ListView以及怎样应用. 配合设计了两个事件Listener:  OnItemSelectedListener事件为鼠标的滚轮转动时所选择的值:OnItemClickListener事件则为当鼠标单击时,所触发的事件.由此可以区别出list中的"选择"与&q

  • 详解Android应用中ListView列表选项栏的编写方法

    根据列表的适配器类型,列表分为三种,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter,这三种适配器的使用大家可学习下官网上面的使用或者自行百度谷歌,一堆DEMO!!!其中以ArrayAdapter最为简单,只能展示一行字.SimpleAdapter有最好的扩充性,可以自定义出各种效果.SimpleCursorAdapter可以认为是SimpleAdapter对数据库的简单结合,可以方便的把数据库的内容以列表的形式展示出来. 系统要绘制ListView了

  • Android编程实现动态更新ListView的方法

    本文实例讲述了Android编程实现动态更新ListView的方法.分享给大家供大家参考,具体如下: 有时候我们需要修改已经生成的列表,添加或者修改数据,notifyDataSetChanged()可以在修改适配器绑定的数组后,不用重新刷新Activity,通知Activity更新ListView.今天的例子就是通过Handler AsyncTask两种方式来动态更新ListView.从今天起,每次学习的源代码都会打包上传,方便各位同学学习,注册帐号即可下载. 布局main.xml: <?xml

  • Android listview多视图嵌套多视图

    首先给大家展示下效果图: public class HomeEduMoreAdapter extends BaseAdapter { private final String TAG = "HomeEduMoreAdapter"; private static final int TYPE_COMMON = ; private static final int TYPE_BL = ; private static final int TYPE_NONE = ; private stat

  • Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中

    我这里只是简单的用了两个listview来实现的,先上效果图.比较粗糙.预留了自定义的空间. 思路: 从上图应该可以看的出来.就是上下两个listview.点击下面的ltem.会动态的移动到上一个listview的最后.上面的listview 为listview1,下面的为listview2. 点击listview2,获取到view ,设置一个动画,移动到listview1 ,listview2中删除被点的item.listview1中新增一个. 上代码: Mainactivity.java 部

  • Android改变ExpandableListView的indicator图标实现方法

    本文实例讲述了Android改变ExpandableListView的indicator图标实现方法.分享给大家供大家参考,具体如下: 1)定义xml文件先,命名为expand_list_indicator.xml <?xml version="1.0" encoding="UTF-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"&

  • 详解Android中实现ListView左右滑动删除条目的方法

    使用Scroller实现绚丽的ListView左右滑动删除Item效果 这里来给大家带来使用Scroller的小例子,同时也能用来帮助初步解除的读者更加熟悉的掌握Scroller的使用,掌握好了Scroller的使用我们就能实现很多滑动的效果.例如侧滑菜单,launcher,ListView的下拉刷新等等效果,我今天实现的是ListView的item的左右滑动删除item的效果,现在很多朋友看到这个效果应该是在Android的通知栏下拉中看到这个滑动删除的效果吧,我看到这个效果是在我之前的三星手

  • Android App界面的ListView布局实战演练

    一.继承listActivity.使用arrayAdapter 使用ListView和arrayAdapter布局,是ListView布局中最为简单的一种,首先我们会建立一个组件用来显示数据,例如main.xml <?xml version="1.0" encoding="utf-8"?> <!-- 主界面本身就是一个显示组件 --> <TextView xmlns:android="http://schemas.androi

  • Android ListView异步加载图片方法详解

    本文实例讲述了Android ListView异步加载图片方法.分享给大家供大家参考,具体如下: 先说说这篇文章的优点把,开启线程异步加载图片,然后刷新UI显示图片,而且通过弱引用缓存网络加载的图片,节省了再次连接网络的开销. 这样做无疑是非常可取的方法,但是加载图片时仍然会感觉到轻微的卡屏现象,特别是listview里的item在进行快速滑动的时候. 我找了一下原因,可能是在listview快速滑动屏幕的时候划过的item太多 而且每次调用getView方法后就会异步的在过去某个时间内用han

  • Android应用中ListView利用OnScrollListener分页加载数据

    当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现. 首先,写一个xml文件,moredata.xml,该文件即定义了放在listview底部的视图: <?xml

  • Android应用中通过Layout_weight属性用ListView实现表格

    今天主要说的是对Layout_weight属性的完全解析,以及利用Layout_weight这个属性使用ListView来实现表格的效果,我们都知道Android里面专门有一个TableLayout来实现表格的,说实话,我平常开发中用TableLayout还是比较少的,几乎没有用到,我们完全可以用LinearLayout和RelativeLayout来代替TableLayout的使用,自己开发中主要使用LinearLayout,RelativeLayout这两种布局,不过刚开始我还是偏爱于Rel

  • 实例讲解Android app开发中ListView的基本使用及优化

    一.直接使用ListView组件创建 1.直接在XML中创建ListView用entries属性附上一个数组资源 其中divider属性是设置分割线可以使用颜色和drawable资源分割 <ListView android:id="@+id/listView1" android:layout_width="match_parent" android:layout_height="wrap_content" android:divider=&

  • Android实现简单的分批加载ListView

    每次滑动至底端,从数据库中获取10条数据,并加载于ListView中 数据库 package com.example.listviewbatchloading; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlit

随机推荐