ListView自定义Adapter实现仿QQ界面

源码下载:http://download.csdn.net/download/jjhahage/10039034  

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())。








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值