首页 > 其他分享 >17. RecyclerView

17. RecyclerView

时间:2022-09-19 07:55:51浏览次数:66  
标签:layout 17 data import android RecyclerView public

Android基础开发——RecyclerView

17. RecyclerView

17.1 导包
implementation 'androidx.recyclerview:recyclerview:1.2.1'

在这里插入图片描述

17.2 Bean类与ListView相同

package com.dingjiaxiong.myrecyclerview;

public class Bean {

    String name;

    public String getName() {
        return name;
    }

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

17.3 主布局
<?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"
    >

    <androidx.recyclerview.widget.RecyclerView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/rv"
        />

</LinearLayout>

17.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="match_parent">

    <TextView
        android:id="@+id/tv"
        android:textSize="30sp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

</LinearLayout>

与ListView的item一样

17.5 生成数据

17.6 辅助类——Adapter
package com.dingjiaxiong.myrecyclerview;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import java.util.List;

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {

    //传入数据
    private List<Bean> data;
    private Context context;

    public MyAdapter(List<Bean> data, Context context) {
        this.data = data;
        this.context = context;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = View.inflate(context, R.layout.recyclerview_item, null);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        //绑定数据
        holder.tv.setText(data.get(position).getName());
    }

    @Override
    public int getItemCount() {
        return data == null ? 0 : data.size();
    }

    public class MyViewHolder extends RecyclerView.ViewHolder {

        private TextView tv;

        public MyViewHolder(@NonNull View itemView) {
            super(itemView);
            tv = itemView.findViewById(R.id.tv);
        }
    }
}


17.7 配置
package com.dingjiaxiong.myrecyclerview;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import android.os.Bundle;
import android.view.View;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    private List<Bean> data = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        for(int i = 0 ; i < 100 ; i++){
            Bean bean = new Bean();
            bean.setName("dingjiaxiong" + i);
            data.add(bean);
        }

        RecyclerView recyclerView = findViewById(R.id.rv);

        //设置布局
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(linearLayoutManager);

        MyAdapter myAdapter = new MyAdapter(data, this);

        recyclerView.setAdapter(myAdapter);

    }
}


运行


17.8 网格的Manager

GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 3);
recyclerView.setLayoutManager(gridLayoutManager);

在这里插入图片描述

17.9 瀑布流布局

StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(3, LinearLayout.VERTICAL);
recyclerView.setLayoutManager(staggeredGridLayoutManager);

改下数据

在这里插入图片描述

在这里插入图片描述

使用网格布局显示

在这里插入图片描述

17.10 item点击事件

默认没有提供

  1. 创建接口

设置监听

在这里插入图片描述

3.使用

myAdapter.setRecyclerItemClickListener(new MyAdapter.OnRecyclerItemClickListener() {
    @Override
    public void OnRecycleItemClick(int position) {
        Log.e("dingjiaxiong", "OnRecycleItemClick: " + position);
    }
});

 

  1. 在这里插入图片描述

运行

在这里插入图片描述

标签:layout,17,data,import,android,RecyclerView,public
From: https://www.cnblogs.com/55zjc/p/16706476.html

相关文章

  • android小项目-菜谱APP-首页面设计上(RecyclerView+OKHttp+GSON+Glide)
    在上一节中,已经搭建好了导航栏,现在开始完成首页内容的设计。任务描述:实现从网络HTTP接口获取菜谱数据,并完成菜谱App主页面的布局设计。设计思路:1.数据层面,使用showapi的......
  • 9.17
    dos命令打开命令提示符在任意文件夹下面,或者桌面按住shift+右击,选择打开powershell窗口在文件夹窗口中,选择路径栏位,在前面加上cmd和空格常用的dos命令切换盘符......
  • CVE-2017-12149 JBoss JMXInvokerServlet 反序列化漏洞
    一、漏洞概述     2017年8月30日,厂商Redhat发布了一个JBOSSAS5.x的反序列化远程代码执行漏洞通告。该漏洞位于JBoss的HttpInvoker组件中的ReadOnlyAccessFil......
  • [THUSCH2017] 大魔法师
    #include<bits/stdc++.h>usingnamespacestd;constintN=3e5+5,MOD=998244353;intn,m,opt,l,r,v;structMatrix{intn,m,h[2][5];inlinevoidprint(){......
  • 20201317-第10章学习笔记
    第十章shell编程程序设计语言必备的要素和技能程序设计语言的含义程序设计语言是用于书写计算机程序的语言。语言的基础是一组记号和一组规则。根据规则由记号构成的......
  • 2022.9.17 Java第二次课总结
    以下是本节课后的问题首先是关于静态变量在类中,使用static修饰符修饰的属性(成员变量)称为静态变量,也可以称为类变量,常量称为静态常量,方法称为静态方法或类方法,它们统称......
  • 2022-09-17 期货市场总结,总结三买的形成与失败
    沪铜主连9-15-20221.日线级别向上,但是有回踩(趋势)2.30分钟一笔下跌,开始出现阳线反抽,阴线假突破(结构)3.出现5分钟开始向上。但是开盘第一根和第二根,只看k线是不太确定,但......
  • CF1722G - Even-Odd XOR
    CF1722G-Even-OddXORG.Even-OddXORGivenaninteger\(n\),findanyarray\(a\)of\(n\)distinctnonnegativeintegerslessthan\(2^{31}\)suchthattheb......
  • 题解【CF1702G2 Passable Paths (hard version)】
    题目传送门。考虑建立虚树然后再上面搞树形DP。于是这道题就变成分讨题。设\(f_i\)表示\(i\)子树内的答案。若\(f_i=1\),表示\(i\)子树内的特殊点可以被一条链覆......
  • CF1718D 题解
    设\(k\)为\(a\)中的空位数量。首先咱们转化这个“相似”的条件,发现它其实是说,笛卡尔树的结构相同。那么我们把p建笛卡尔树然后把a的数往上填。如果此时有上面小于下......