Android RecyclerView 实现 GridView ,并实现点击效果及方向位置的显示

news/2024/9/24 5:42:21/

效果图


一、引入

 implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.30'

二、使用步骤

1.Adapter

public class UnAdapter extends BaseQuickAdapter<UnBean.ResultBean, BaseViewHolder> {private int selectedPosition = RecyclerView.NO_POSITION; // 用于记录当前选中的位置private int lastSelectedPosition = RecyclerView.NO_POSITION; // 上一次选中的位置private int spanCount = 4; // 每行显示的列数// 处理item点击事件的方法public void onItemClick(int position) {// 如果点击的是当前选中的item,则不执行任何操作(或者执行特定的操作)if (position == selectedPosition) {return;}// 更新选中状态if (selectedPosition != RecyclerView.NO_POSITION) {// 如果之前有选中的item,先通知适配器刷新它,以恢复默认背景notifyItemChanged(selectedPosition);}// 更新选中位置lastSelectedPosition = selectedPosition;selectedPosition = position;// 通知适配器刷新新选中的itemnotifyItemChanged(selectedPosition);}// (可选)如果需要,可以添加一个方法来处理取消选中item的情况private void deselectItem(int position) {if (position == selectedPosition) {selectedPosition = RecyclerView.NO_POSITION;}}public  UnAdapter(int layoutResId, @Nullable List<UnBean.ResultBean> data) {super(layoutResId, data);}@SuppressLint("ResourceAsColor")@Overrideprotected void convert(BaseViewHolder helper, UnBean.ResultBean item) {ImageView fx_rightImg = helper.getView(R.id.fx_right_img);ImageView fx_leftImg = helper.getView(R.id.fx_left_img);LinearLayout fx_upLayout = helper.getView(R.id.fx_up_layout);LinearLayout bgLayout = helper.getView(R.id.bg_layout);// 根据是否选中来设置背景if (helper.getLayoutPosition() == selectedPosition) {bgLayout.setBackgroundResource(R.drawable.shape_blue_8);helper.setTextColor(R.id.cd_tv, mContext.getColor(R.color.white));} else if (helper.getLayoutPosition() == lastSelectedPosition && lastSelectedPosition != RecyclerView.NO_POSITION) {bgLayout.setBackgroundResource(R.drawable.shape_bg_position_sel);helper.setTextColor(R.id.cd_tv, mContext.getColor(R.color.blue_text));} else {bgLayout.setBackgroundResource(R.drawable.shape_bg_position_sel);helper.setTextColor(R.id.cd_tv, mContext.getColor(R.color.blue_text));}// 设置点击监听器(注意:这里应该在ViewHolder的构造函数中设置,以避免重复设置)// 但为了简化示例,这里直接在convert中设置(不推荐)bgLayout.setOnClickListener(v -> {onItemClick(helper.getPosition());});// 计算当前项位于哪一行int position = helper.getAdapterPosition(); // 获取当前项的索引int row = position / spanCount; // 整数除法得到当前行号(注意:这里假设没有头部或脚部项)// 计算当前项在当前行的列索引(从0开始)int column = position % spanCount;// 判断是否是每行的首项boolean isFirstItemInRow = column == 0;// 判断是否是每行的尾项// 注意:这里的判断需要考虑是否是最后一行且不是整除spanCount的情况boolean isLastItemInRow = (position + 1) % spanCount == 0 || position == getItemCount() - 1;// 或者更精确地判断尾项(仅当当前项不是最后一行的唯一项时才需要额外检查)boolean isLastItemInRowPrecise = (position + 1) % spanCount == 0 ||(position == getItemCount() - 1 && position % spanCount != spanCount - 1);// 判断当前项是否为列表中的最后一位boolean isLastItemInList = position == getItemCount() - 1;// 判断行数的奇偶性if (row % 2 == 0) {fx_rightImg.setVisibility(View.VISIBLE);if (isFirstItemInRow) {fx_upLayout.setVisibility(View.GONE);}if (isLastItemInRowPrecise) {fx_upLayout.setVisibility(View.VISIBLE);fx_rightImg.setVisibility(View.GONE);}} else {fx_leftImg.setVisibility(View.GONE);fx_rightImg.setVisibility(View.VISIBLE);fx_upLayout.setVisibility(View.GONE);if (isFirstItemInRow) {fx_upLayout.setVisibility(View.VISIBLE);}if (isLastItemInRowPrecise) {fx_upLayout.setVisibility(View.GONE);fx_leftImg.setVisibility(View.GONE);}}// 根据是否为最后一位的逻辑来设置UIif (isLastItemInList) {fx_upLayout.setVisibility(View.GONE);fx_rightImg.setVisibility(View.GONE);}helper.setText(R.id.cd_tv, item.getTrain());}}

2. item_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="@dimen/dimen_120"android:layout_height="@dimen/dimen_80"android:layout_marginLeft="@dimen/dimen_15"android:orientation="vertical"android:padding="@dimen/dimen_5"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="@dimen/dp_40"android:orientation="horizontal"><LinearLayoutandroid:id="@+id/bg_layout"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"><TextViewandroid:id="@+id/cd_tv"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="G2519"android:textColor="@color/c_3681ff" /></LinearLayout><LinearLayoutandroid:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"><ImageViewandroid:id="@+id/fx_right_img"android:layout_width="@dimen/dimen_15"android:layout_height="@dimen/dimen_15"android:background="@drawable/icon_fx_right"android:visibility="gone" /><ImageViewandroid:id="@+id/fx_left_img"android:layout_width="@dimen/dimen_15"android:layout_height="@dimen/dimen_15"android:background="@drawable/icon_fx_left"android:visibility="gone" /></LinearLayout></LinearLayout><LinearLayoutandroid:id="@+id/fx_up_layout"android:layout_width="match_parent"android:layout_height="@dimen/dp_40"android:gravity="center_vertical"android:visibility="gone"><ImageViewandroid:layout_width="@dimen/dimen_15"android:layout_height="@dimen/dimen_15"android:layout_marginLeft="@dimen/dimen_25"android:background="@drawable/icon_fx_up" /></LinearLayout></LinearLayout>

3.应用

 fromAssets = ReadAsUtil.getFromAssets(this, "UnList.json");unBean = new Gson().fromJson(fromAssets, UnBean.class);unList = unBean.getResult();gridLayoutManager = new GridLayoutManager(this, 4);cdLv.setLayoutManager(gridLayoutManager);unAdapter = new UnAdapter(R.layout.item_layout, unList);cdLv.setAdapter(unAdapter);unAdapter.notifyDataSetChanged();

总结

如果对你有所帮助的话,不妨 点赞收藏
如果你有什么疑问的话,不妨 评论私信
青山不改,绿水长流 ,有缘江湖再见 ~


http://www.ppmy.cn/news/1529669.html

相关文章

Spring MVC参数接收 总结

1. 简介 Spring MVC可以简化从前端接收参数的步骤。 2. Param传参 通过设定函数入参和添加标记来简化接受&#xff1a; //参数接收 RequestMapping("product") ResponseBody //接受/product?productgoods&id123 //1.名称必须相同&#xff0c;2.不传值不会不…

HarmonyOS鸿蒙开发实战(5.0)悬浮窗拖拽和吸附动画实践

鸿蒙HarmonyOS NEXT开发实战往期文章必看&#xff08;持续更新......&#xff09; HarmonyOS NEXT应用开发性能实践总结 HarmonyOS NEXT应用开发案例实践总结合集 最新版&#xff01;“非常详细的” 鸿蒙HarmonyOS Next应用开发学习路线&#xff01;&#xff08;从零基础入门…

网安新声 | 黎巴嫩BP机爆炸事件带来的安全新挑战与反思

网安加社区【网安新声】栏目&#xff0c;汇聚网络安全领域的权威专家与资深学者&#xff0c;紧跟当下热点安全事件、剖析前沿技术动态及政策导向&#xff0c;以专业视野和前瞻洞察&#xff0c;引领行业共同探讨并应对新挑战的策略与可行路径。 9月17日&#xff0c;黎巴嫩境内发…

鸿蒙开发(NEXT/API 12)【使用head发送网络请求 (C/C++)】远场通信服务

场景介绍 发送一个带有默认HTTP参数的HTTP HEAD请求&#xff0c;并返回来自服务器的HTTP响应。使用异步回调。类似GET请求&#xff0c;但只返回相应头&#xff0c;不返回实体内容。可以获取资源的元信息&#xff0c;如文件大小、修改日期等。 使用示例 CPP侧导入模块。 #incl…

Python3网络爬虫开发实战(16)分布式爬虫(第一版)

文章目录 一、分布式爬虫原理1.1 分布式爬虫架构1.2 维护爬取队列1.3 怎样来去重1.4 防止中断1.5 架构实现 二、Scrapy-Redis 源码解析2.1 获取源码2.2 爬取队列2.3 去重过滤2.4 调度器 三、Scrapy 分布式实现3.1 准备工作3.2 搭建 Redis 服务器3.3 部署代理池和 Cookies 池3.4…

OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【LMS调测】

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ 持续更新中…… 基本概念 LMS全称为Lite Memory Sanitizer&#xff0c;是一种实时…

OpenAI GPT-3 API: What is the difference between davinci and text-davinci-003?

题意&#xff1a;OpenAI GPT-3 API&#xff1a;davinci 和 text-davinci-003 有什么区别 问题背景&#xff1a; Im testing the different models for OpenAI, and I noticed that not all of them are developed or trained enough to give a reliable response. 我正在测试…

解决Vue 3中Element Plus el-color-picker 组件消失的问题

概述 在使用Vue 3和Element Plus框架构建应用程序时&#xff0c;你可能会遇到el-color-picker组件无法正常显示的情况。这可能是由于多种原因造成的&#xff0c;包括但不限于CSS加载问题、JavaScript错误、版本兼容性等。本文将指导你如何排查并解决这个问题。 在 el-color-p…