如何创建带有高程的Android按钮背景SVG?

7
我一直在尝试实现附图中的按钮,为此我创建了带有阴影的渐变SVG,以便它看起来像高程,但是当将此SVG应用于按钮作为背景可绘制时,它显得很平坦,并且涟漪效果也消失了。
我想要实现与下面图片相同的按钮: enter image description here 这是我的代码:
<Button
            android:id="@+id/btn_login"
            android:layout_width="match_parent"
            android:layout_height="52dp"
            android:layout_gravity="center_horizontal"
            android:layout_marginTop="35dp"
            android:enabled="false"
            android:elevation="10dp"
            android:translationZ="10dp"
            android:stateListAnimator="@null"
            android:background="@drawable/bg_gradient"
            android:text="@string/btn_txt_login"
            android:textColor="@android:color/white"
            android:textSize="18sp" />

我正在使用SVG文件创建带圆角边框的背景渐变。欢迎提供任何帮助。

你可以尝试使用带有涟漪效果的ImageButton [Image button with ripple](https://dev59.com/0l0Z5IYBdhLWcg3w4jhy),或将渐变用作android:foreground,?android:attr/selectableItemBackground 用作背景。 - Shripad Jadhav
3个回答

3
我可以为您提供帮助。

我有一个解决方案。

将以下内容添加到您的 build.gradle(Module:app) 的 dependency 中:

implementation 'com.android.support:cardview-v7:27.1.1'

现在使用 CardView 布局替换 Button:
<android.support.v7.widget.CardView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="10dp"
    android:foreground="?android:attr/selectableItemBackground"
    android:clickable="true"
    card_view:cardCornerRadius="10dp"
    card_view:cardElevation="4dp">

<TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:padding="10dp"
    android:gravity="center_vertical|center_horizontal"
    android:textSize="18sp"
    android:text="LOGIN"
    android:textColor="@android:color/white"
    android:textStyle="bold"
    android:background="@drawable/gradient"/>

</android.support.v7.widget.CardView>

在drawable文件夹中创建gradient.xml文件:

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

    <gradient
        android:startColor="#8b0ab7"
        android:endColor="#0b85d0"
        android:angle="0"/>

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

</shape>

1
如果还不起作用,请添加这些属性,如果仍然不行,请使用cardview。
android:clipChildren="false"
        android:clipToPadding="false"

这里是您的代码

    <Button     android:id="@+id/btn_login"
                android:layout_width="match_parent"
                android:layout_height="52dp"
                android:layout_gravity="center_horizontal"
                android:layout_marginTop="35dp"
                android:enabled="false"
                android:elevation="10dp"
                android:translationZ="10dp"
                android:stateListAnimator="@null"
                android:clipChildren="false"
                android:clipToPadding="false"
                android:background="@drawable/bg_gradient"
                android:text="@string/btn_txt_login"
                android:textColor="@android:color/white"
                android:textSize="18sp" />

0

请尝试使用以下可绘制内容。

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/colorDefaultButtonRipple">
    <item>
        <layer-list>
            <item>
                <shape android:shape="rectangle">
                    <solid android:color="@android:color/darker_gray" />
                    <corners android:radius="15dp" />
                </shape>
            </item>
            <item android:bottom="2dp" android:left="2dp">
                <shape>
                    <gradient android:angle="0" android:endColor="#5789bc" android:startColor="#8e6fa6" />
                    <corners android:radius="15dp" />
                    <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />
                </shape>
            </item>
        </layer-list>
    </item>
</ripple>


仍然是带有灰色边框的扁平按钮,是的,涟漪效果有效。 - Deep Shah

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接