如何为按钮添加模糊的阴影?

新手上路,请多包涵

我需要为我的按钮添加模糊的阴影:

在此处输入图像描述

我尝试使用 layer-list xml drawable 创建背景,但它看起来不像模糊。

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

    <!-- Drop Shadow Stack -->
    <item>
        <shape>
            <corners android:radius="45dp" />
            <padding
                android:bottom="2dp"
                android:left="1dp"
                android:right="1dp"
                android:top="1dp" />

            <stroke
                android:width="6dp"
                android:color="#007879E8" />

        </shape>
    </item>
    //////   10 more items
        <item>
        <shape>
            <corners android:radius="45dp" />
            <padding
                android:bottom="2dp"
                android:left="1dp"
                android:right="1dp"
                android:top="1dp" />

            <stroke
                android:width="6dp"
                android:color="#177879E8" />

        </shape>
    </item>

    <!-- Background -->
    <item>
        <shape>
            <corners android:radius="45dp" />
            <stroke
                android:width="2dp"
                android:color="@color/main_purple_text_color" />
        </shape>
    </item>

</layer-list>

我还尝试使用带有模糊 png 的按钮后面的背景元素,但它使用了很多资源,我无法创建选择器来更改鼠标悬停或单击时的背景。

我需要为按钮设置单个背景文件,并使用选择器在悬停/单击时更改模糊和渐变。任何想法如何使用 Android SDK 实现这种效果?

更新 1

谢谢大家的回答,但我不是在问如何创建渐变。我已经这样做了。我需要创建模糊的阴影。

原文由 Vlad Morzhanov 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 673
2 个回答

好吧,我找到了解决方案:我们需要通过此 生成器 创建带有模糊阴影的 9.png,并将其传递给包含按钮背景渐变的可绘制图层列表:

 <?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:drawable="@drawable/blurred_9_path_png" />
    <item>
        <shape android:shape="rectangle" android:padding="10dp">
            <corners android:radius="45dp" />
            <gradient
                android:angle="45"
                android:endColor="@color/facebook_btn_fill_grad2"
                android:startColor="@color/facebook_btn_fill_grad1"
                android:type="linear" />
            <padding
                android:bottom="0dp"
                android:left="0dp"
                android:right="0dp"
                android:top="0dp" />
        </shape>
    </item>

</layer-list>

之后我们可以使用具有不同 9.path 模糊阴影的可绘制对象来创建选择器。

原文由 Vlad Morzhanov 发布,翻译遵循 CC BY-SA 3.0 许可协议

我将其添加为可绘制背景(灰色投影):

 <!-- Drop Shadow Stack -->
<item>
    <shape>
        <padding
            android:bottom="1dp"
            android:left="1dp"
            android:right="1dp"
            android:top="1dp" />
        <solid android:color="#1f000000" />
        <corners android:radius="30dp" />
    </shape>
</item>
<item>
    <shape>
        <padding
            android:bottom="1dp"
            android:left="1dp"
            android:right="1dp"
            android:top="1dp" />
        <solid android:color="#2f000000" />
        <corners android:radius="30dp" />
    </shape>
</item>
<item>
    <shape>
        <padding
            android:bottom="1dp"
            android:left="1dp"
            android:right="1dp"
            android:top="1dp" />
        <solid android:color="#3f000000" />
        <corners android:radius="30dp" />
    </shape>
</item>

<!-- Background -->
<item>
    <shape>
        <solid android:color="@android:color/white" />
        <corners android:radius="30dp" />
    </shape>
</item>

确保 textview 的高度/宽度/填充足够大以包含阴影 3dp 以上(1dp+1dp+1dp 对于从#3f000000 到#1f000000 的所有颜色)。

原文由 Stackoverflow 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏