ListView高级控件的使用

activity_main.xml 文件(配置文件)

<?xml version="1.0" encoding="utf-8"?>
    <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Hello World!"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" />


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

    </android.support.constraint.ConstraintLayout>

listview_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="horizontal" >

    <ImageView
        android:id="@+id/iv_listviewitem_image"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="3"
        android:padding="10dp"
        android:scaleType="fitXY"
        android:src="@drawable/book1" />

    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="6"
        android:orientation="vertical"
        android:padding="10dp" >

        <TextView
            android:id="@+id/tv_listviewitme_title"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="狂人摄影日记"
            android:textColor="@color/red"
            android:textSize="20sp" />

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="书本作者:"
                android:textColor="@color/black" />

            <TextView
                android:id="@+id/tv_listviewitme_author"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="阿刘" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="书本价格:"
                android:textColor="@color/black" />

            <TextView
                android:id="@+id/tv_listviewitme_price"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="$123"
                android:textColor="@color/black" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="    出版社:"
                android:textColor="@color/black" />

            <TextView
                android:id="@+id/tv_listviewitme_publish"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="电子出版社"
                android:textColor="@color/black" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >

            <TextView
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="书本简介:"
                android:textColor="@color/black" />

            <TextView
                android:id="@+id/tv_listviewitme_remark"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:ellipsize="end"
                android:maxLines="2"
                android:text="很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天很冷的一个冬天"
                android:textColor="@color/black" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="20dp"
            android:orientation="horizontal" >

            <ImageButton
                android:id="@+id/bt_listviewitme_btn1"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginLeft="5dp"
                android:layout_marginRight="5dp"
                android:layout_weight="1"
                android:src="@drawable/btn_shopping" />

            <ImageButton
                android:id="@+id/bt_listviewitme_btn2"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginLeft="5dp"
                android:layout_marginRight="5dp"
                android:layout_weight="1"
                android:src="@drawable/btn_accounts" />
        </LinearLayout>
    </LinearLayout>

大致步骤如下:

1.在程序入口定义好ListView控件 分析器(BaseAdapter适配器需要解析项资源) 适配器(Adapter) 数据源(数据源这里使用固定数据)
2.在 onCreate方法中获取控件
3.进行适配器三部曲

  • 第一步获取数据源
  • 第二部初始化适配器(这里我们写了一个内部类名为MyBaseAdapter中写了一个有参构造器负责加载解析器)
  • 第三步绑定高级控件

下面有详情代码:

package com.example.baseadapter;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.List;

public class MainActivity extends AppCompatActivity {

    /**
     * 定义  控件   数据    解析器    自定义适配器
     * @param savedInstanceState
     */

    private ListView  lv_main_lv1;
    private List<Book> data;
    private LayoutInflater layoutInflater;
    private myBaseAdapter myBaseAdapter;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lv_main_lv1=this.findViewById(R.id.lv_main_lv1);
        data=new BookDao().list();
        layoutInflater = (LayoutInflater) getSystemService(this.LAYOUT_INFLATER_SERVICE);//获取解析器
        myBaseAdapter = new myBaseAdapter(layoutInflater);//内部初始化
        lv_main_lv1.setAdapter(myBaseAdapter);//绑定高级控件
    }

    /**
     * 自定义适配器
     */
    public class myBaseAdapter extends BaseAdapter{
        //提供有参构造实例化时获取解析器
        private LayoutInflater layoutInflater;
        public myBaseAdapter(LayoutInflater layoutInflater) {
            this.layoutInflater=layoutInflater;
        }

        @Override
        public int getCount() {
            return data.size();//决定你展示多少数据
        }

        @Override
        public Object getItem(int position) {
            return data.get(position);//当前第几条数据
        }

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

        /**
         * 定义内部类   简化获取组件
         *
         * @return
         */
        public class viewHold{
            private ImageView iv_listviewitem_image;
            private TextView  tv_listviewitme_title;
            private TextView  tv_listviewitme_author;
            private TextView  tv_listviewitme_price;
            private TextView  tv_listviewitme_publish;
            private TextView  tv_listviewitme_remark;

        }
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            //性能优化
            View view = convertView;
            if(view==null){
                viewHold viewHold = new viewHold();
                //页面展示几个则会加载几次这里错一个判断,当进行下一次循环则会采用上一次视图
                view=layoutInflater.inflate(R.layout.listview_item,null);//将项资源解析成可读的view
                viewHold.iv_listviewitem_image=view.findViewById(R.id.iv_listviewitem_image);//获取view中的控件
                viewHold.tv_listviewitme_title=view.findViewById(R.id.tv_listviewitme_title);
                viewHold.tv_listviewitme_author=view.findViewById(R.id.tv_listviewitme_author);
                viewHold.tv_listviewitme_price=view.findViewById(R.id.tv_listviewitme_price);
                viewHold.tv_listviewitme_publish=view.findViewById(R.id.tv_listviewitme_publish);
                viewHold.tv_listviewitme_remark=view.findViewById(R.id.tv_listviewitme_remark);
                view.setTag(viewHold);//保存上一次的控件
            }
                viewHold viewHold= (viewHold) view.getTag();
            //此时控件并没有值所以要给他赋值
            Book book = data.get(position);
            viewHold.iv_listviewitem_image.setImageResource(book.getImage());
            viewHold.tv_listviewitme_title.setText(book.getTitle());
            viewHold.tv_listviewitme_author.setText(book.getAuthor());
            viewHold.tv_listviewitme_price.setText(book.getPrice()+"");
            viewHold.tv_listviewitme_publish.setText(book.getPublish());
            viewHold.tv_listviewitme_remark.setText(book.getRemark());
            return view;
        }
    }
}

BaseAdapter:是所有适配器类的父类,可以对列表项进行最大限度的定制

1.1 自定义适配器中的方法
getCount
getView
getItem
getItemId
1.2 LayoutInflater(布局解析器)
–LayoutInflater有三种获得方式,资料中有详细介绍
用来把layout布局文件解析成一个View对象,不可以new,需要使用系统服务获得
inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);

效果图:

ListView配合BaseAdapter

猜你喜欢

转载自blog.csdn.net/INori_2023/article/details/82728633