安卓 Day 22 :适配器

本文介绍了如何在Android应用中创建一个ListView,展示产品列表。通过编写XML布局文件定义列表项,创建Product类存储数据,使用自定义的ProductAdapter将数据绑定到ListView,并实现点击监听以显示产品详情。
摘要由CSDN通过智能技术生成

基本内容

  • 如果有列表视图,就要用适配器(要记住)
    在这里插入图片描述

用实训案例来了解

1.创建一个安卓项目

在这里插入图片描述

2.主布局资源文件activity_main.xml

  • 列表控件,<ListView>
  • 以纵向列表的方式显示文本内容,实现纵向滚动效果
  • 单击列表视图中选中的选项,弹出Toast提示
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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">

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

</LinearLayout>

3.准备好图片资源

在这里插入图片描述

4.建立一个item 小项

<?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/product_picture"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:src="@mipmap/caomei"
        />
    <LinearLayout
        android:layout_marginTop="5dp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
        <TextView
            android:id="@+id/product_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:textSize="25dp"
            android:text="丹东草莓"/>


        <LinearLayout
            android:layout_marginTop="15dp"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
            <TextView
                android:id="@+id/product_price"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textSize="25dp"
                android:textColor="#ff2121"
                android:text="¥20"/>
            <TextView
                android:layout_marginStart="70dp"
                android:id="@+id/product_stocks"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="5dp"
                android:textSize="25dp"
                android:text="库存量"/>
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

5.类文件MainActivity.java 代码

package net.yuanjing.adapter;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    //控件
    private ListView listViewProduct ;
    //数据
    List<Product> listProduct ;
    //自定义适配器
    ProductAdapter productAdapter ;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //获取控件
        getView() ;
        //准备数据
        listProduct = makeData();
        //实例化适配器
        productAdapter = new ProductAdapter(this , listProduct);
        //绑定适配器
        listViewProduct.setAdapter(productAdapter);
        listViewProduct.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            //parent 适配器,View适配器里面视图,position点击的位置,id点击的id
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Product product = (Product) parent.getItemAtPosition(position);
                Toast.makeText(MainActivity.this,"点击了" + product.getName()+";库存还有:" + product.getStocks(),Toast.LENGTH_LONG).show();
            }
        });
    }

    }
    
    private List<Product> makeData() {
        List<Product> productList = new ArrayList<>() ;
        Product caomei = new Product(R.mipmap.caomei , "草莓","21.5",11 ) ;
        productList.add(caomei) ;
        Product dagao = new Product(R.mipmap.dagao , "打糕" ,"9.5",15 ) ;
        productList.add(dagao) ;
        Product xiaobei = new Product(R.mipmap.xiaobei , "肉松小贝" ,"25" ,61 ) ;
        productList.add(xiaobei) ;
        Product zhishi = new Product(R.mipmap.zhishi , "芝士饼干" , "19" , 12 ) ;
        productList.add(zhishi) ;
        return productList ;
    }

    private void getView() {
        listViewProduct = findViewById(R.id.lv_product) ;
    }
}

6.建立一个Product

在这里插入图片描述

package net.yuanjing.adapter;
public class Product {
    private int picture;//图片
    private String name ;//名字
    private String price ;//价钱
    private int stocks ;//库存量
    public Product(int picture, String name, String price, int stocks) {
        this.picture = picture;
        this.name = name;
        this.price = price;
        this.stocks = stocks;
    }

    public int getPicture() {
        return picture;
    }

    public void setPicture(int picture) {
        this.picture = picture;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPrice() {
        return price;
    }

    public void setPrice(String price) {
        this.price = price;
    }

    public int getStocks() {
        return stocks;
    }

    public void setStocks(int stocks) {
        this.stocks = stocks;
    }

    @Override
    public String toString() {
        return "Product{" +
                "picture=" + picture +
                ", name='" + name + '\'' +
                ", price='" + price + '\'' +
                ", stocks=" + stocks +
                '}';
    }
}


7.建立一个ProductAdapter文件

在这里插入图片描述

package net.yuanjing.adapter;
import android.content.Context;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import java.util.List;

public class ProductAdapter extends BaseAdapter {
    //上下文环境
    private Context mcontext ;
    //数据源
    private List<Product> listProduct ;
    //子控件
    private int layout ;
    //构造方法传入数据

    public ProductAdapter(Context mcontext, List<Product> listProduct) {
        this.mcontext = mcontext;
        this.listProduct = listProduct;
        this.layout = layout;
    }

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

    @Override
    public Object getItem(int i) {
        return listProduct.get(i);
    }

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

    @Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        if(null == view) {
            //获取item控件
            LayoutInflater inflater = LayoutInflater.from(mcontext) ;
            view = inflater.inflate(R.layout.item , null) ;

        }
        //获取子布局中控件
        ImageView picture = view.findViewById(R.id.product_picture) ;
        TextView name = view.findViewById(R.id.product_name) ;
        TextView price = view.findViewById(R.id.product_price) ;
        TextView stocks = view.findViewById(R.id.product_stocks) ;
        //获取当前的元素
        Product product = listProduct.get(i) ;
        //绑定数据
        picture.setImageResource(product.getPicture());
        name.setText(product.getName());
        price.setText("¥" + product.getPrice());
        stocks.setText("库存量" + product.getStocks());
        return view;
    }
}


8.运行一下,看哈效果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值