Child ImageView捕获OnClickListener而不是父线性布局

问题描述 投票:0回答:1

在XML中,我已经实现了带有水平可滚动文本和可绘制矢量(复制到剪贴板矢量)的图像视图的线性布局,其中水平可滚动文本带有可滚动文本。

XML

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="30dp">


    <ImageView
        android:id="@+id/refresh"
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:layout_alignParentStart="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:background="?attr/selectableItemBackgroundBorderless"
        app:srcCompat="@drawable/ic_new"
        tools:ignore="VectorDrawableCompat" />

    <LinearLayout
        android:id="@+id/copy"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentEnd="true"
        android:layout_alignParentRight="true"
        android:background="?attr/selectableItemBackground"
        android:orientation="horizontal"
        android:paddingStart="-3dp"
        android:paddingLeft="-3dp"
        android:clickable="true"
        android:focusable="true">


        <HorizontalScrollView
            android:layout_width="290dp"
            android:layout_height="wrap_content"
            android:clickable="false">


            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal"
                android:clickable="false">


                <TextView
                    android:id="@+id/gen"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:gravity="start"
                    android:paddingStart="5dp"
                    android:paddingLeft="5dp"
                    android:text="Sample Text Sample Text Sample Text Sample Text Sample Text "
                    android:textSize="24sp"
                    android:clickable="false"/>

            </LinearLayout>
        </HorizontalScrollView>

        <ImageView
            android:id="@+id/pos"
            android:layout_width="32dp"
            android:layout_height="32dp"
            android:scaleX="-1"
            app:srcCompat="@drawable/ic_copy"
            tools:ignore="VectorDrawableCompat"
            android:clickable="false"/>


    </LinearLayout>

    <TextView
        android:id="@+id/Length"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_marginTop="44dp"
        android:text="Long Text Sample"
        android:textSize="13sp" />

    <SeekBar
        android:id="@+id/pwSeekBar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_marginTop="70dp"
        android:max="128"
        android:min="8"/>


</RelativeLayout>

在Java中,我为包含滚动视图和图像视图的父LinearLayout实现了onclicklistener。

Java

copyclipboard = (LinearLayout) view.findViewById(R.id.copy);


        copyclipboard.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                clipboard = (ClipboardManager) requireActivity().getSystemService(Context.CLIPBOARD_SERVICE);
                clip = ClipData.newPlainText("text", gen.getText());
                clipboard.setPrimaryClip(clip);
                Toast.makeText(getActivity(), "Copied", Toast.LENGTH_SHORT).show();
            }
        });

我面临的问题是,在点击超过90%的区域时,onclicklistener不会响应,并且仅在imageview(ID pos)覆盖的区域有效。我该如何解决这个问题?

在XML中,我已经实现了带有水平可滚动文本和可绘制矢量(复制到剪贴板矢量)的图像视图的线性布局,其中水平可滚动文本带有可滚动文本。 XML

android android-linearlayout android-imageview
1个回答
0
投票

您已经设置好它,以便只有LinearLayout才能响应单击事件,但是它被其他几个视图覆盖。

© www.soinside.com 2019 - 2024. All rights reserved.