Android ListView自定义Adapter实现仿QQ界面

PS:listview中有一些简单使用的适配器,如:SimpleAdapter:构造方法SimpleAdapter(Context context,List<Map<String,?>> data,reString [] from,int [] to),但这种适配器过于单调,往往不能达到用户想要的效果,想要随心所欲,就用到了BaseAdapter,自定义适配器。

如图:

1、首先写布局文件

activity_layout.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">
  <ListView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/id_lv"> 

  </ListView> 

</LinearLayout>

没一个item的样式:itemstyle_layout.xml  其中的图片自己随便找个即可。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:orientation="horizontal"
  android:layout_height="match_parent"> 

  <ImageView
    android:layout_width="70dp"
    android:layout_height="80dp"
    android:src="@drawable/tou"/>
  <LinearLayout
    android:layout_width="0dp"
    android:layout_weight="0.9"
    android:layout_height="80dp"
    android:orientation="vertical">
    <TextView
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:textSize="35dp"
      android:text="11111"
      android:id="@+id/id_item_tv"/>
    <TextView
      android:layout_marginTop="5dp"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:textSize="20dp"
      android:text="11111"
      android:id="@+id/id_item_tv2"/> 

  </LinearLayout>
  <LinearLayout
    android:layout_width="0dp"
    android:layout_height="80dp"
    android:layout_weight="0.1"
    android:orientation="vertical">
   <ImageView
     android:layout_width="match_parent"
     android:layout_height="50dp"
     android:src="@drawable/xin1"/> 

  </LinearLayout> 

</LinearLayout>

2、创建适配器MyAdapter.java   (已优化)

申明一点,适配中有优化方法,如果不优化的话,有时也可以加载出来,但有时就会加载错乱,没调用一次就会多浪费创建一个view对象,如:

 View item = LayoutInflater.from(context).inflate(R.layout.itemstyle_layout, null);
// TextView info = (TextView)item.findViewById(R.id.id_item_tv);
// info.setText(list.get(position)+"");

优化后(加入了Viewholder)

public class MyAdapter extends BaseAdapter{ 

  //
  public List<Map<String,String>> list;
  public Context context; 

  public MyAdapter (Context context,List<Map<String,String>> list){
    this.context=context;
    this.list=list; 

  }
@Override
  public int getCount() {
    return list.size();//返回个数
  } 

  @Override
  public Object getItem(int position) {
    return list.get(position);//返回项
  } 

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

  @Override
  public View getView(int position, View convertView, ViewGroup parent) { 

//    View item = LayoutInflater.from(context).inflate(R.layout.itemstyle_layout, null);
//    TextView info = (TextView)item.findViewById(R.id.id_item_tv);
//    info.setText(list.get(position)+""); 

    ViewHolder viewHolder;
    if(convertView ==null){
      viewHolder= new ViewHolder();
      convertView=LayoutInflater.from(context).inflate(R.layout.itemstyle_layout,null);//加载布局 

      viewHolder.tv1= (TextView) convertView.findViewById(R.id.id_item_tv);
      viewHolder.tv2= (TextView) convertView.findViewById(R.id.id_item_tv2);
      convertView.setTag(viewHolder);
    }else{
      viewHolder= (ViewHolder) convertView.getTag();
    } 

    viewHolder.tv1.setText(list.get(position).get("tv1")+"");
    viewHolder.tv2.setText(list.get(position).get("tv2")+""); 

    return convertView;
  } 

  static class ViewHolder
  {
    ImageView iv;
     TextView tv1;
     TextView tv2;
  }

3、在MainActivity.java中加载listview控件并把list赋值。

public class MainActivity extends AppCompatActivity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main); 

    ListView lv= (ListView) findViewById(R.id.id_lv);
    List<Map<String,String>> list=new ArrayList<Map<String,String>> (); 

    for(int i=0;i<10;i++){
      Map<String,String> map=new HashMap<>();
      map.put("tv1","111111");
      map.put("tv2","222222");
      list.add(map);
    }
    MyAdapter ma=new MyAdapter(this,list);
    lv.setAdapter(ma); 

  } 

}

完事。

总结:代码优化加入Viewholder的好处:(官方翻译)

重用缓存convertView传递给getView()方法来避免填充不必要的视图
使用ViewHolder模式来避免没有必要的调用findViewById():因为太多的findViewById也会影响性能
ViewHolder模式通过getView()方法返回的视图的标签(Tag)中存储一个数据结构,这个数据结构包含了指向我们要绑定数据的视图的引用,从而避免每次调用getView()的时候调用findViewById())。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android开发中ListView与Adapter使用要点介绍

    1. Adapter.getView() public View getView(int position, View convertView , ViewGroup parent){...} 这个方法就是用来获得指定位置要显示的View.官网解释如下: Get a View that displays the data at the specified position in the data set. You can either create a View manually or infl

  • Adapter实现ListView带多选框等状态的自定义控件的注意事项

    Android本身为ListView提供了几个方便的Adapter,比如ArrayAdapter.SimpleCurrentAdapter等等.但是为了实现更复杂的列表视图和控制,一般都要继承BaseAdapter来实现自己的Adapter. 我需要的ListView是如图一样的实现SD卡资源文件浏览列表,每个列表项由一个ImageView.TextView.CheckBox组成,并且要求当整个列表中有一个或一个以上的Checkbox被选中时,右上角的搜索按钮就显示出来,否则就隐藏,因此需要对每

  • ListView的Adapter使用(绑定数据) 之 自定义每一项的布局去绑定数据

    大家先看第一个例子显示: 这个界面相信大家都看到过的,这次比上一个例子多的是ListView 的每一项绑定的是不再是单纯的一个字符串了,ListView 的每一个条目我们需要显示两个信息,编号和姓名.可以看到,我们绑定了十条数据,用了一个for 循环,每一条绑定的时候创建一个HashMap,然后往里面放数据,放的数据有相对应的key, 即id,name,到时候我们取数据的时候就根据这个key 找到我们放进去的数据,有点类似与键值对的意思,不知道这样解释大家明白不明白. 贴上源代码,然后接下来讲解

  • ListView的Adapter使用 之 初学ArrayAdapter String

    ListView是Android中经常会使用的东西,绑定数据对于初学者来说,尤其是刚接触编程的人来说,往往会觉得很难理解,我上大二的时候学的java,但是基本上相当于没有学,什么都没写过,真正接触编程就是开始上手学android,把这些记录下来,自己可以回头看下,也可以让新手更好的理解.高手绕过.... Android中Adapter我是这么理解的,是数据和视图之间的桥梁,数据在adapter中做处理,然后显示到视图上面. Adapter有很多种,有ArrayAdapter<T>, BaseA

  • Android ListView适配器(Adapter)优化方法详解

    Android ListView的优化,在做Android项目的时候,在用到ListView 界面及数据显示,这个时候如果资源过大,对项目来说,用户体验肯定是不好的,这里就对如何优化做了详细介绍: Adapter的作用就是ListView界面与数据之间的桥梁,当列表里的每一项显示到页面时,都会调用Adapter的getView方法返回一个View.想过没有? 在我们的列表有1000000项时会是什么样的?是不是会占用极大的系统资源? ListView的Adapter的作用如下图所示: 先看看下面

  • Android开发中ListView自定义adapter的封装

    [引入] 我们一般编写listView的时候顺序是这样的:  •需要展示的数据集List<T>  •为这个数据集编写一个ListView  •为这个ListView编写一个Adapter,一般继承自BaseAdapter  •在BaseAdapter内部编写一个ViewHolder类,对应ListView里面的item控件,提高控件的查询效率 分析: List<T>:ListView --> Adapter extends BaseAdapter --> ViewHol

  • Android自定义Adapter的ListView的思路及代码

    在开发中,我们经常使用到ListView这个控件.Android的API也提供了许多创建ListView适配器的快捷方式.例如ArrayAdapter.SimpleAdapter和SimpleCursorAdapter等.但你是否发现,如果采用这些系统自带的适配器,对于事件的响应只能局限在一个行单位.假设一行里面有一个按钮和一个图片控件,它们之间的响应操作是不一样的.若采用系统自带的适配器,就不能精确到每个控件的响应事件.这时,我们一般采取自定义适配器来实现这个比较精确地请求. ListView

  • 揭秘在ListView等AdapterView上动态添加删除项的陷阱

    如何避开在ListView等AdapterView上动态添加删除项的陷阱,下面就为大家分享,具体内容如下 首先,定义如下array资源,作为列表的加载内容: <resources> <string name="app_name">MyListView</string> <string-array name="language"> <item>Java</item> <item>C&l

  • ListView Adapter优化 实例

    复制代码 代码如下: //方案一 - adapter优化public class listviewAdapterDemo1 extends BaseAdapter { private String[] mArrData;    private ListView listView;    private AsyncImageLoader asyncImageLoader;    private final LayoutInflater inflater; public listviewAdapte

  • Android listview与adapter详解及实例代码

    一个ListView通常有两个职责. (1)将数据填充到布局. (2)处理用户的选择点击等操作. 第一点很好理解,ListView就是实现这个功能的.第二点也不难做到,在后面的学习中读者会发现,这非常简单. 一个ListView的创建需要3个元素. (1)ListView中的每一列的View. (2)填入View的数据或者图片等. (3)连接数据与ListView的适配器. 也就是说,要使用ListView,首先要了解什么是适配器.适配器是一个连接数据和AdapterView(ListView就

随机推荐