簡體   English   中英

選擇 RecyclerView 的列表項后啟用按鈕

[英]Enable Button after list Item of RecyclerView was selected

我有一個帶有 RecyclerView 的活動和一個最初被禁用的按鈕。 RV 的元素是可選擇的,我希望只有在選擇元素后才能啟用按鈕。 我試圖在 recyclerview 上設置 addOnItemTouchListener,問題是它在滾動列表時也被調用。

這是我的適配器:

public class CLusterListAdapter extends RecyclerView.Adapter<CLusterListAdapter.ClusterListViewHolder> {


private ArrayList<ClusterItem> mListOfClusters;
private OnItemClickListener mListener;
//index
int row_index = -1; //Default no row chosen

public interface OnItemClickListener{
    //delete
    void onDeleteCluster(int position);
    //edit
    void onEditCluster(int position);
    //select
    void onClick(View view, int position);

}

public void setOnItemClickListener(OnItemClickListener listener){mListener = listener;}


    public static class ClusterListViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener{


        public TextView mClusterName;
        public TextView mClusterMembers;
        public ImageView mDeleteCluster;
        public ImageView mEditCluster;

        //This
        private OnItemClickListener itemClickListener;
        public void setItemClickListener(OnItemClickListener listener){
            this.itemClickListener = listener;
        }

        public ClusterListViewHolder(@NonNull View itemView, final OnItemClickListener listener) {
            super(itemView);

            mClusterName = itemView.findViewById(R.id.tv_clusters_name_cluster_list);
            mClusterMembers = itemView.findViewById(R.id.tv_clusters_members_cluster_list);
            mDeleteCluster = itemView.findViewById(R.id.iv_delete_cluster);
            mEditCluster = itemView.findViewById(R.id.iv_edit_cluster);

            mDeleteCluster.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if(listener != null){
                        int position = getAdapterPosition();
                        if(position != RecyclerView.NO_POSITION){
                            listener.onDeleteCluster(position);
                        }
                    }
                }
            });

            mEditCluster.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if(listener != null){
                        int position = getAdapterPosition();
                        if(position != RecyclerView.NO_POSITION){
                            listener.onEditCluster(position);
                        }
                    }
                }
            });
            //used for highlighting item
            itemView.setOnClickListener(this);

        }
        //This
        @Override
        public void onClick(View v) {
           itemClickListener.onClick(v, getAdapterPosition());
        }
    }

    public CLusterListAdapter(ArrayList<ClusterItem> listOfClusters ){ mListOfClusters = listOfClusters;}


@NonNull
@Override
public ClusterListViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
    View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.chose_your_cluster_list_item, viewGroup, false);
    ClusterListViewHolder clusterListViewHolder =  new ClusterListViewHolder(view, mListener);
    return clusterListViewHolder;
}

@Override
public void onBindViewHolder(@NonNull ClusterListViewHolder clusterListViewHolder, int i) {
    ClusterItem currentCluster = mListOfClusters.get(i);

    clusterListViewHolder.mClusterName.setText(currentCluster.getClustersName());
    clusterListViewHolder.mClusterMembers.setText(currentCluster.getClustersMembers());
    clusterListViewHolder.mClusterMembers.setSelected(true);

    clusterListViewHolder.setItemClickListener(new OnItemClickListener() {
        @Override
        public void onDeleteCluster(int position) {
            //nothing here
        }

        @Override
        public void onEditCluster(int position) {
            //nothing here
        }

        @Override
        public void onClick(View view, int position) {
            //Select a certain item
            row_index = position; //Set row index to selected position
            SpTAGs.currentItem = mListOfClusters.get(position); //Set current item is item selection
            notifyDataSetChanged(); //Made effect on RecyclerView's Adapter

            SpTAGs.selectedClusterPosition = position;
        }

    });

    //Set highlight color
    if(row_index == i) {
        clusterListViewHolder.itemView.setBackgroundColor(Color.parseColor("#E64A19"));
    }else {
        clusterListViewHolder.itemView.setBackgroundColor(Color.parseColor("#FFFFFF"));
    }
}

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

}

這是我如何應用 addOnItemTouch

clusterRecyclerView.addOnItemTouchListener(new RecyclerView.OnItemTouchListener() {
        @Override
        public boolean onInterceptTouchEvent(@NonNull RecyclerView recyclerView, @NonNull MotionEvent motionEvent) {
                selectButton.setEnabled(true);
                Log.v("MyTAG", "Touch");

            return false;
        }

        @Override
        public void onTouchEvent(@NonNull RecyclerView recyclerView, @NonNull MotionEvent motionEvent) {

        }

        @Override
        public void onRequestDisallowInterceptTouchEvent(boolean b) {

        }
    });

知道如何獲得這個嗎? 謝謝!

有一個從適配器到活動的回調。 在那里啟用您的按鈕。

public class CLusterListAdapter extends RecyclerView.Adapter<CLusterListAdapter.ClusterListViewHolder> {
         ...

         interface Listener {
              void onItemClick(int position);
         }
}

在項目點擊時調用它

clusterListViewHolder.setItemClickListener(new OnItemClickListener() {
        @Override
        public void onDeleteCluster(int position) {
            //nothing here
        }

        @Override
        public void onEditCluster(int position) {
            //nothing here
        }

        @Override
        public void onClick(View view, int position) {
            //Select a certain item
            row_index = position; //Set row index to selected position
            SpTAGs.currentItem = mListOfClusters.get(position); //Set current item is item selection
            notifyDataSetChanged(); //Made effect on RecyclerView's Adapter
            listener.onItemClick(position); // notify the listener (activity) of the click

            SpTAGs.selectedClusterPosition = position;
        }

    });

在活動中:

clusterRecyclerView.addOnItemTouchListener( ... );
clusterRecyclerView.setListener((int position) -> { 
    // logic to enable button goes here
});

你不需要在這里使用 addOnItemTouchListener 。 只需在這樣的活動中創建一個方法

public void VisibleButton(){

yourButton.setVisibility(View.VISIBLE);
/**....*/

}

只需調用方法

可見按鈕()

從你的適配器,從你希望你的按鈕可見的地方,就像這樣

((YourActivityName)your_ACtivity_Context).VisibleButton(); 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM