Android RecyclerView通过可聚焦的子布局使整个项目成为焦点



>我有一个RecyclerView看起来像下图。

在此处输入图像描述

圆圈位于具有 onClickListener 的 LinearLayout 中。当我单击圆圈器时,行为是我所期望的。

RecyclerView 的 convertView 设置了一个 onClickListener。当单击 RecyclerView 的项目时,行为是我所不希望的。外变的行为是整个项目都以亮点聚焦。但是圆圈周围的黑色并没有聚焦。

我已经搜索了很长时间,但一无所获。我怎样才能找到它?

这是回收器视图的项目布局。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:gravity="center"
    android:layout_marginBottom="1dp"
    android:orientation="horizontal"
    android:background="@drawable/action_color"
    android:layout_width="match_parent"
    android:layout_height="55dp">
    <TextView
        style="@style/FormFont"
        android:layout_weight="7"
        android:id="@+id/no"
        android:text="1"
        android:layout_width="0dp"
        android:layout_height="match_parent" />
    <LinearLayout
        android:id="@+id/parent_status"
        android:background="@drawable/action_color"
        android:layout_weight="7"
        android:gravity="center"
        android:padding="10dp"
        android:layout_width="0dp"
        android:layout_height="match_parent">
        <ImageView
            android:layout_centerInParent="true"
            android:id="@+id/status"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
        <ProgressBar
            android:id="@+id/status_progressbar"
            android:visibility="gone"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
        <Button
            android:id="@+id/switch_retry"
            android:text="@string/retry"
            android:visibility="gone"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </LinearLayout>
    <TextView
        style="@style/FormFont"
        android:id="@+id/temperature"
        android:layout_weight="8"
        android:text="20"
        android:layout_width="0dp"
        android:layout_height="match_parent" />
    <TextView
        style="@style/FormFont"
        android:id="@+id/humidity"
        android:layout_weight="8"
        android:text="15"
        android:layout_width="0dp"
        android:layout_height="match_parent" />
    <LinearLayout
        android:background="@drawable/action_color"
        android:id="@+id/parent_mode"
        android:layout_weight="10"
        android:orientation="vertical"
        android:gravity="center"
        android:layout_width="0dp"
        android:layout_height="match_parent">
        <ImageView
            android:id="@+id/mode"
            android:layout_width="33dp"
            android:layout_height="33dp"
            android:scaleType="fitXY"
            />
        <TextView
            android:text="定时模式"
            android:textSize="12dp"
            android:id="@+id/mode_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </LinearLayout>
    <LinearLayout
        android:visibility="gone"
        android:id="@+id/progressbar"
        android:layout_weight="10"
        android:orientation="vertical"
        android:gravity="center"
        android:layout_width="0dp"
        android:layout_height="match_parent">
        <ProgressBar
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </LinearLayout>
    <LinearLayout
        android:layout_weight="6"
        android:layout_width="0dp"
        android:gravity="center"
        android:layout_gravity="center"
        android:layout_height="match_parent">
        <CheckBox
            android:visibility="gone"
            android:focusableInTouchMode="false"
            android:focusable="false"
            android:id="@+id/checkbox"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
        <ImageView
            android:id="@+id/arrow"
            android:src="@mipmap/ic_right_arrow"
            android:layout_width="30dp"
            android:layout_height="30dp" />
    </LinearLayout>
</LinearLayout>
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View view = LayoutInflater.from(parent.getContext())
        .inflate(R.layout.item_spot,parent,false);
    ViewHolder viewHolder = new ViewHolder(view);
    return viewHolder;
}

@drawable/action_color.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:drawable="@color/colorLightGray"/>
    <item android:state_activated="true" android:drawable="@color/colorLightGray"/>
    <item android:state_selected="true" android:drawable="@color/colorLightGray"/>
    <item android:drawable="@android:color/white"/>
</selector>

当不设置 onClickListener for statusParent(线性布局包装圆形图像时,单击该项目时,状态父线性布局将突出显示。我认为这是状态父是可点击的,所以它不会突出显示。

//       viewHolder.statusParent is the LinearLayout of the Id R.id.status_parent.
//        viewHolder.statusParent.setOnClickListener(this);

只需创建 PressLinearLayout 扩展 LinearLayout 并覆盖 dispatchSetPressed 方法。好吧。

public class PressLinearLayout extends LinearLayout {
    public PressLinearLayout(Context context) {
        super(context);
    }
    public PressLinearLayout(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    public PressLinearLayout(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }
    @Override
    protected void dispatchSetPressed(boolean pressed) {
        for (int i = 0; i < getChildCount(); i++) {
            final View child = getChildAt(i);
                child.setPressed(pressed);
        }
    }
}

最新更新