布局可点击的选择器不起作用-为什么?

时间:2019-06-02 05:28:24

标签: android layout selector clickable

创建登录页面。但我不知道这段代码是什么问题 单击后,登录按钮不起作用更改颜色!

我想单击然后更改颜色按钮

为什么不更改“登录”按钮?

我该如何解决?

activity_login.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="16dp">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_marginBottom="16dp"
        android:background="@drawable/btn_login"
        android:clickable="true"
        android:gravity="center"
        android:paddingLeft="32dp"
        android:paddingRight="32dp">

        <ImageView
            android:layout_width="30dp"
            android:layout_height="30dp"
            android:src="@drawable/icon_user" />

        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:text="LOGIN"
            android:textColor="#fff"
            android:textSize="16dp" />

    </LinearLayout>

</LinearLayout>
  

选择器xml->    btn_login.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_enabled="true">
        <shape android:shape="rectangle">
            <solid android:color="#4DAEEA" />
            <corners android:radius="30dp" />
        </shape>
    </item>

    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="#00ff00" />
            <corners android:radius="30dp" />
        </shape>
    </item>

    <item android:state_enabled="false">
        <shape android:shape="rectangle">
            <solid android:color="#999" />
            <corners android:radius="30dp" />
        </shape>
    </item>

</selector>

2 个答案:

答案 0 :(得分:0)

您应该通过添加样式并删除背景来使LinearLayout像按钮一样工作,请按照以下步骤

<LinearLayout
......
style="@style/btn_stand"
.......
>

</LinearLayout>

我对按钮的样式定义:

<style name="btn_stand" parent="AppBaseTheme">
    <item name="android:background">@drawable/btn_stand_sel</item>
    <item name="android:textColor">@drawable/btn_stand_text_color</item>
    <item name="android:minHeight">48dp</item>
    <item name="android:paddingLeft">5dp</item>
    <item name="android:paddingRight">5dp</item>
</style>

我的@ drawable / btn_stan_sel文件:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <!-- disabled state -->
    <item android:drawable="@drawable/btn_stand_disabled" android:state_enabled="false"/>

    <!-- enabled and pressed state -->
    <item android:drawable="@drawable/btn_stand_pressed" android:state_enabled="true" android:state_pressed="true"/>

    <!-- enabled and focused state -->
    <item android:drawable="@drawable/btn_stand_focused" android:state_enabled="true" android:state_focused="true"/>

    <!-- enabled state -->
    <item android:drawable="@drawable/btn_stand_enabled" android:state_enabled="true"/>

</selector>

我的可绘制文件针对每种状态重复使用,每种状态使用不同的颜色:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <stroke
        android:width="1dp"
        android:color="@color/stroke" />

    <solid android:color="@color/blue" />

    <corners android:radius="6dp" />

</shape>

这是一个对我有用的示例,希望您使用它并选择所需的颜色

答案 1 :(得分:0)

在您的线性布局xml代码中添加android:focusable="true"

在无法正常运行的情况下,您可以尝试将android:background=@drawable/btn_login替换为android:foreground="?android:attr/selectableItemBackground"