按钮在选择器中不会改变其形状

Posted

技术标签:

【中文标题】按钮在选择器中不会改变其形状【英文标题】:Button doesn't change its shape in selector 【发布时间】:2015-07-12 11:34:33 【问题描述】:

我正在尝试自定义按钮的外观。 问题是,那个按钮不想改变它的形状。这意味着它仍然是尖锐的而不是椭圆形的。

button_selector.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/green_bright">
        <shape xmlns:android="http://schemas.android.com/apk/res/android">
            <corners android:radius="8dp"/>
            <stroke android:color="@color/green_primary"/>
            <padding android:bottom="4dp" android:left="4dp" android:right="4dp" android:top="4dp"/>
        </shape>
    </item>
    <item android:drawable="@color/green">
        <shape xmlns:android="http://schemas.android.com/apk/res/android">
            <corners android:radius="8dp"/>
            <stroke android:color="@color/green_primary"/>
            <padding android:bottom="4dp" android:left="4dp" android:right="4dp" android:top="4dp"/>
        </shape>
    </item>
</selector>

my_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_
    android:layout_
    android:paddingLeft="8dp"
    android:paddingRight="8dp"
    android:paddingTop="8dp"
    android:paddingBottom="8dp"
    android:orientation="vertical">    
<Button android:id="@+id/button_id"
    android:layout_
    android:layout_
    android:layout_weight="1"
    android:text="@string/button_text"
    android:textColor="@color/grey_dark"
    android:background="@drawable/button_selector"/>
</LinearLayout>

已解决

问题是我在 item

中声明了 drawable
<item android:drawable="@color/..."/>

它设置了固定的背景,它使背景不可变,所以任何形状都不能改变按钮的属性。背景颜色在中设置。

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

重要!您可以使用可绘制来代替颜色,但所有您的纯色都需要可绘制

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

更正了下面的 button_selector.xml。

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

    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid
                android:color="@color/blue_bright"/>
            <corners
                android:radius="20dp"/>
            <stroke
                android:color="@color/blue_primary"
                android:/>
            <padding
                android:bottom="4dp" android:left="4dp" android:right="4dp" android:top="4dp"/>
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle">
            <solid
                android:color="@color/blue"/>
            <corners
                android:radius="20dp"/>
            <stroke
                android:color="@color/blue_primary"
                android:/>
            <padding
                android:bottom="4dp" android:left="4dp" android:right="4dp" android:top="4dp"/>
        </shape>
    </item>

</selector>

同样重要的是,您可以在 Button 中使用您的图片,而不仅仅是将其放入:

<Button>
  ...
  android:src="@drawable/myPicture"
</Button>

【问题讨论】:

【参考方案1】:

使用纯色填充颜色并为描边添加宽度。 像这样的:

<item>
    <shape android:shape="rectangle">
        <solid android:color="#ff22cc84"/>
        <corners android:radius="8dp"/>
        <stroke android: android:color="#ff800424"/>
        <padding android:bottom="4dp" android:left="4dp" android:right="4dp" android:top="4dp"/>
    </shape>
</item>

【讨论】:

没有任何改变。所以.. 背景颜色效果很好,但形状保持不变。我添加了&lt;shape android:shape:rectangle&gt;,但这改变了一切。我什至不知道银弹在哪里。 形状保持不变(没有圆角)是什么意思?将半径增加到更高的值,例如 20dp。 我的意思是形状保持锐利/矩形。增加半径不起作用。你认为错误是在 @drawable/button_selector 之外的地方吗?

以上是关于按钮在选择器中不会改变其形状的主要内容,如果未能解决你的问题,请参考以下文章

CircleImage 在选择器中选择一个选项并添加到列表后不断改变颜色

为啥日期选择器中的日期格式没有改变?

比较数据选择器中的值

传递在 Bootstrap 日期选择器中选择的日期的结果,并将其放在 URL 链接中

在 Iphone 的日期选择器中插入空白值

我如何在文本输入中显示从时间选择器中选择的时间?