繁体   English   中英

如何仅切换按钮的背景并保存 state(是否按下)

[英]How to toggle only the background of a button and save the state (pressed or not)

我正在尝试制作一个调查应用程序,了解一下 FragmentContainerView 和导航图。 当我使用现有的小部件(例如单选按钮或复选框)作为答案时,一切都很完美。

当我尝试制作自己的小部件或更改普通按钮的行为以使其行为如以下屏幕截图所示时出现问题:

在此处输入图像描述

该行为类似于 ToggleButton 但我不想更改文本(开/关文本)。 我需要的是,当我单击按钮时,它被标记为选中(更改背景),当然,我需要能够稍后询问按钮是否被选中。

使用按钮和自定义选择器,将按钮设置为可检查,我可以实现预期的行为。

选择器( btn_toggle_background.xml ):

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

    <!--When Button is not enabled -->
    <item android:state_checked="false" android:color="#eeeeee" />
    <!--When Button is in pressed state -->
    <item android:state_checked="true" android:color="@color/blue_electric" />
    <!--When Button is in selected state -->
    <!--Default Background Color -->
    <item android:color="#eeeeee" />

</selector>

而在 XML 布局中:

 <?xml version="1.0" encoding="utf-8"?>

 <Button
      android:id="@+id/button2"
      android:layout_width="match_parent"
      android:layout_height="60dp"
      android:backgroundTint="@drawable/btn_toggle_background" <!-- CUSTOM SELECTOR -->
      android:textColor="@drawable/btn_toggle_text" <!-- CUSTOM SELECTOR -->
      android:checkable="true" <!-- CHECKABLE HERE -->
      android:gravity="fill|fill_horizontal"
      android:text="A través de mi compañía de seguros"
      android:textAlignment="gravity"
      android:textAllCaps="false"
      app:icon="@android:drawable/btn_radio"
      app:iconTint="@drawable/btn_toggle_icon" <!-- CUSTOM SELECTOR --> />

但随后该按钮不再响应 OnClick 事件(我怀疑它是为了使其可检查)。 我假设它会响应 OnCheckedChange 事件,但它是一个不会触发普通按钮的事件。

我还尝试从 Button 扩展自定义视图并拦截 OnClick 并通过自定义侦听器(接口)发送事件。 在这种情况下,按钮行为不再起作用。 它变成一个普通按钮并忽略 styles 和 XML 中为选中的 state 指定的选择器。

是否有一个看起来像我需要的小部件? 从 ToggleButton 扩展会更合适吗?

您可以使用:

        <com.google.android.material.button.MaterialButton
            android:checkable="true"
            app:backgroundTint="@drawable/btn_toggle_background"
            .../>

和:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="false" android:color="#eeeeee" />
    <item android:state_checked="true" android:color="@color/...." android:alpha="xxx" />
</selector>

OnCheckedChangeListener

    button.addOnCheckedChangeListener { button, isChecked ->
        if (isChecked){
            //
        }
    }

使用方法isChecked了解状态:

button.isChecked

在此处输入图像描述

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM