IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> RecyclerView或是ListView(列表)点击某个条目保持选中【非常巧妙】 -> 正文阅读

[移动开发]RecyclerView或是ListView(列表)点击某个条目保持选中【非常巧妙】

在这里插入图片描述
背景:
本来想用选择器实现,结果各种不管用

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@color/holo_orange_dark" android:state_selected="true" />
    <item android:drawable="@color/holo_orange_dark" android:state_pressed="true" />
    <item android:drawable="@color/holo_orange_dark" android:state_checked="true" />
    <item android:drawable="@color/holo_orange_dark" android:state_focused="true" />
    <item android:drawable="@color/no_white" android:state_focused="false" />
    <item android:drawable="@color/no_white" android:state_selected="false" />

</selector>

实现思路:
在adapter中添加setThisPosition方法进行点击条目定位,并且调用 notifyDataSetChanged();自动执行一次adapter的getView方法,即进行按下状态的判断显示;执行点击监听时,执行一次adapter的setThisPosition(position)方法时把位置传进去,非常巧妙。

核心在Adapter实现
1dapter中添加setThisPosition方法

   //先声明一个int成员变量,若为0默认显示第一个
    private int thisPosition = -1;

    //再定义一个int类型的返回值方法
    public int getthisPosition() {
        return thisPosition;
    }

    //其次定义一个方法用来绑定当前参数值的方法
    //此方法是在调用此适配器的地方调用的,此适配器内不会被调用到
    public void setThisPosition(int thisPosition) {
        this.thisPosition = thisPosition;
//        执行构造器的getView方法
        notifyDataSetChanged();
    }

2 getView回调方法中进行点击与否状态判断

if (position == getthisPosition()) {
//            Log.e("wy", "onBindViewHolder: ");
//            viewHolder.itemView.setBackgroundResource(R.color.yellow_ui);
            viewHolder.itemView.setBackgroundResource(R.drawable.top_checked);
        } else {
            viewHolder.itemView.setBackgroundResource(R.drawable.top_normal);
        }

3 listview点击监听中执行mAdapter.setThisPosition(position);触发一切

 LvServiceCustomDetailAdapter lvServiceCustomDetailAdapter = new LvServiceCustomDetailAdapter(professionInfo.getData(), ServiceCustomDetailActivity.this);
                    lvServiceCustomDetail.setAdapter(lvServiceCustomDetailAdapter);
                    lvServiceCustomDetail.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                        @Override
                        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                            lvServiceCustomDetailAdapter.setThisPosition(position);
        }
                    });

Adapter全代码

package com.wintec.huashang.adapter;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;

import com.wintec.huashang.Constant;
import com.wintec.huashang.R;

import java.util.List;

import androidx.recyclerview.widget.RecyclerView;

public class GalleryAdapter extends
        RecyclerView.Adapter<GalleryAdapter.ViewHolder> {
    public interface OnItemClickLitener {
        void onItemClick(View view, int position);
    }

    private OnItemClickLitener mOnItemClickLitener;

    public void setOnItemClickLitener(OnItemClickLitener mOnItemClickLitener) {
        this.mOnItemClickLitener = mOnItemClickLitener;
    }

    ViewHolder viewHolder;
    private LayoutInflater mInflater;
    private List<String> mDatas;
    Context mContext;

    //    private int selectedPosition = -5; //默认一个参数
    public GalleryAdapter(Context context, List<String> datats) {
        mContext = context;
        mInflater = LayoutInflater.from(context);
        mDatas = datats;
    }

    //先声明一个int成员变量,若为0默认显示第一个
    private int thisPosition = -1;

    //再定义一个int类型的返回值方法
    public int getthisPosition() {
        return thisPosition;
    }

    //其次定义一个方法用来绑定当前参数值的方法
    //此方法是在调用此适配器的地方调用的,此适配器内不会被调用到
    public void setThisPosition(int thisPosition) {
        this.thisPosition = thisPosition;
        notifyDataSetChanged();
    }

//    int a = -1;
//    public void setSelectFlag(int flag){
//        if (flag==a) {
//            return;
//        }
//        a = flag;
//        notifyDataSetChanged();
//    }


    public static class ViewHolder extends RecyclerView.ViewHolder {
        public ViewHolder(View arg0) {
            super(arg0);
        }

        ImageView mImg;
        TextView mTxt;
        RelativeLayout mRecyclerRl;


    }


    public void setmDatas(List<String> datas) {
        //        清除ReclyclerView条目选中状态
        thisPosition = -1;
        if (mDatas != null) {
            mDatas.clear();
            this.notifyDataSetChanged();
        }
        mDatas.addAll(datas);
//        selectedPosition = -5;
        this.notifyDataSetChanged();
    }

    public void clearnChecked() {
        viewHolder.mRecyclerRl.setFocusable(false);
        viewHolder.mRecyclerRl.clearFocus();
        viewHolder.itemView.setBackgroundResource(R.color.white);
//        selectedPosition = -5;
//        清除ReclyclerView条目选中状态
        thisPosition = -1;
        this.notifyDataSetChanged();
    }


    @Override
    public int getItemCount() {
        return mDatas.size();
    }

    /**
     * 创建ViewHolder
     */
    @Override
    public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {
        View view = mInflater.inflate(R.layout.activity_index_gallery_item,
                viewGroup, false);
//        ViewHolder viewHolder = new ViewHolder(view);
        viewHolder = new ViewHolder(view);

//        if (!listItem.isSelect()){
//            viewHolder.relativeLayout.setBackgroundColor(Color.WHITE);
//        }else {
//            viewHolder.relativeLayout.setBackgroundColor(Color.parseColor("#ff00ff"));
//        }


//        viewHolder.mImg = (ImageView) view
//                .findViewById(R.id.id_index_gallery_item_image);
        viewHolder.mTxt = (TextView) view
                .findViewById(R.id.id_index_gallery_item_text);
        viewHolder.mRecyclerRl = (RelativeLayout) view.findViewById(R.id.recycler_rl);
        return viewHolder;
    }

    /**
     * 设置值
     */
    @Override
    public void onBindViewHolder(final ViewHolder viewHolder, final int position) {

//        Log.e("wy", "onBindViewHolder: " + position+"getthisPosition(): "+getthisPosition());
        if (position == getthisPosition()) {
//            Log.e("wy", "onBindViewHolder: ");
//            viewHolder.itemView.setBackgroundResource(R.color.yellow_ui);
            viewHolder.itemView.setBackgroundResource(R.drawable.top_checked);
        } else {
            viewHolder.itemView.setBackgroundResource(R.drawable.top_normal);
        }

//        viewHolder.mImg.setImageResource(mDatas.get(position));

//        viewHolder.itemView.setSelected(selectedPosition == position);
//        if (selectedPosition == position) {
//            viewHolder.mTxt.setVisibility(View.VISIBLE);
//        } else {
//            viewHolder.mTxt.setVisibility(View.INVISIBLE);
//        }

        viewHolder.mTxt.setText(mDatas.get(position) + "");
//        viewHolder.itemView.setOnClickListener(new View.OnClickListener() {
//            @Override
//            public void onClick(final View v) {
//                Toast.makeText(mContext, "点击的位置:"+position +"点击的内容: "+mDatas.get(position), Toast.LENGTH_SHORT).show();
//
//            }
//        });
        //如果设置了回调,则设置点击事件
        if (mOnItemClickLitener != null) {
//按下选中
//            viewHolder.itemView.setOnFocusChangeListener(new View.OnFocusChangeListener() {
//                @Override
//                public void onFocusChange(View v, boolean hasFocus) {
//                    // TODO: 20/4/26
//                    mOnItemClickLitener.onItemClick(viewHolder.itemView, position);
//                }
//            });

            viewHolder.itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    mOnItemClickLitener.onItemClick(viewHolder.itemView, position);
                    Log.e("wy", "run: " + "点击了ReclycerView条目");
                    Constant.isUpLoadErrorListReclyclerView = true;
//                    setSelectFlag(position);
//                    ListItem listItem = this.getData().get(position);

                }
            });


//            if(a != -1&& position == a){
                viewHolder.itemView.setSelected(true);
//
//                viewHolder.itemView.setBackgroundResource(R.color.yellow_ui);
//            }


        }


    }

}


调用

//得到控件
        mRecyclerView = (RecyclerView) findViewById(R.id.id_recyclerview_horizontal);
        //设置布局管理器
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
        mRecyclerView.setLayoutManager(linearLayoutManager);
        //设置适配器
        mAdapter = new GalleryAdapter(this, mDatas);
        mAdapter.setOnItemClickLitener(new GalleryAdapter.OnItemClickLitener() {
            @Override
            public void onItemClick(View view, int position) {
                mAdapter.setThisPosition(position);


            }
        });


        mRecyclerView.setAdapter(mAdapter);
  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:41:49  更:2022-03-15 22:43:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 17:18:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码