Android开发入门组件(七)——ListView

隔了好几天,今天来讲一下ListView列表视图的使用。其实日常中也很少用到ListView,主要讲一下它的使用步骤。

估计会讲的不是很好,感觉大家会用即可,以后如果要写ListView了,可以套着这个去写,具体可以多看看一些代码的注释

 

1.ListView的文件activity_listview用来声明组件

<?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"
    android:orientation="vertical">

    <ListView //listview组件的声明
        android:id="@+id/lv1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:listSelector="@drawable/listitem"  //进行选择操作,点击listitem的变化
        android:divider="@color/colorGray"  //listitem的分割线
        android:dividerHeight="5dp"></ListView>
</LinearLayout>

entries:设置显示数组数据
divider:设置每项的分割条背景
dividerHeight:设置分割条的高度

2.对应的Activity的文件ListViewActivity,设置点击事件的响应以及Adapter的应用

package com.example.androidstudy1;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.Toast;
import com.example.androidstudy1.R;

public class ListViewActivity extends AppCompatActivity {
    ListView lv1; //用来声明组件ListView
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_listview);
        lv1=findViewById(R.id.lv1);  //找出对应的组件Id
        lv1.setAdapter(new MyListAdapter(ListViewActivity.this)); //在组件上设置Adapter
        lv1.setOnItemClickListener(new AdapterView.OnItemClickListener(){
            @Override //在组件上设置监听事件
    public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {              Toast.makeText(ListViewActivity.this,"position"+i,Toast.LENGTH_SHORT).show();
                //当点击listitem的时候响应函数
            }
        });
        lv1.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener(){

            @Override
  public boolean onItemLongClick(AdapterView<?> adapterView, View view, int i, long l) {
             Toast.makeText(ListViewActivity.this,"长按position"+i,Toast.LENGTH_SHORT).show(); //当长按listitem的时候响应函数
                return  false;
            }
        });
    }
}

3.layout_list_item创建数据模型,用来定义ListView中一个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="match_parent"
    android:orientation="horizontal"
    android:padding="15dp">
    <ImageView
        android:id="@+id/iv"
        android:layout_width="200dp"
        android:layout_height="180dp"
        android:scaleType="centerCrop"
        android:background="#000"/>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:layout_marginLeft="10dp">
        <TextView
            android:id="@+id/tv_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="HelloDemo"
            android:textSize="20sp"
            android:textColor="#000"
            />
        <TextView
            android:id="@+id/tv_time"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="15dp"
            android:text="2019-07-14"
            android:textSize="20sp"
            android:textColor="@color/colorAccent"
            />
        <TextView
            android:id="@+id/tv_content"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="15dp"
            android:text="这是内容"
            android:textSize="20sp"
            android:textColor="@color/colorAccent"
            />
    </LinearLayout>
</LinearLayout>

4.定义MyListAdapter,用来创建adapter适配器

package com.example.androidstudy1;
import android.content.Context;
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 com.bumptech.glide.Glide;
import com.example.androidstudy1.R;

public class MyListAdapter extends BaseAdapter {
    Context context;
    LayoutInflater layoutInflater;
    public MyListAdapter(Context context){
        this.context=context;
        layoutInflater=LayoutInflater.from(context);
    }
    @Override
    //定义listview中listitem的数量
    public int getCount() {
        return 10;
    }
    @Override
    public Object getItem(int i) {
        return null;
    }
    @Override
    public long getItemId(int i) {
        return 0;
    }
    static class ViewHolder{
        public ImageView imageView;
        public TextView tv_title,tv_time,tv_content;
    } //定义一个类,一个结构体来提取一个item中的组件
    @Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        ViewHolder holder=null;
        if (view==null){
            view=layoutInflater.inflate(R.layout.layout_list_item,null);
//找出对应的view文件
            holder=new ViewHolder();
//新建一个结构体,下边给结构体的属性进行赋值
            holder.imageView=view.findViewById(R.id.iv);
            holder.tv_title=view.findViewById(R.id.tv_title);
            holder.tv_time=view.findViewById(R.id.tv_time);
            holder.tv_content=view.findViewById(R.id.tv_content);
            view.setTag(holder); //设置view的holder
        }
        else {
            holder=(ViewHolder)view.getTag(); //用来获取holder
        }
        holder.tv_title.setText("Demo修改"); //修改holder中的属性
        holder.tv_time.setText("2019-7-15");
        holder.tv_content.setText("我就是内容");                    Glide.with(context).load("http://img.redocn.com/sheying/20150213/mulanweichangcaoyuanfengjing_3951976.jpg").into(holder.imageView);
        return view;
    }
}

5.样式文件listitem,用来设置点击状态的显示

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true" android:drawable="@color/colorAccent"></item>
    //选择状态时候
    <item android:state_focused="true" android:drawable="@color/colorAccent"></item>
    //选择聚焦时候
    <item android:state_pressed="true" android:drawable="@color/colorAccent"></item>
    //选择按压时候
    <item android:drawable="@color/colorGray"></item>
    //其他情况
</selector>

看一下效果图吧

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Demo.demo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值