简体   繁体   English

带阴影的圆形按钮,如 5.0 FAB

[英]Circular button with shadow like 5.0 FAB

I want a button in circular shape with shadow.我想要一个带阴影的圆形按钮。 Shadow must be like FAB.影子一定像FAB。 Currently I'm using a png to implement the button.目前我正在使用 png 来实现按钮。

在此处输入图片说明

But when I use this image I can't give correct pressed state changes.但是当我使用这个图像时,我无法给出正确的按下状态变化。 Is there any way to impleament this by using xml有没有办法通过使用xml来实现这一点

you can try it你可以试试看

 <?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android" > <!-- Drop Shadow Stack --> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#00CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#10CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#20CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#30CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#50CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <!-- Background --> <item> <shape android:shape="oval"> <solid android:color="@android:color/white" /> <corners android:radius="3dp" /> </shape> </item> </layer-list>

 <Button android:id="@+id/btn" android:layout_width="80dp" android:layout_height="80dp" android:layout_centerInParent="true" android:background="@drawable/shadow_circle" android:text="0" android:textColor="#fff" />

在此处输入图片说明

Following code will help to design different size and shape or colorfull control in android used following code以下代码将有助于在 android 中使用以下代码设计不同的大小和形状或彩色控件

<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >       <corners android:radius="14dp"/>
        <gradient android:angle="45"
            android:centerX="35%"
            android:centerColor="#7995A8"
            android:startColor="#E8E8E8"
            android:endColor="#000000"
            android:type="linear"/>
        <padding android:left="0dp"
                android:top="0dp"
                android:right="0dp"
                android:bottom="0dp"/>
        <size android:width="270dp"
        android:height="60dp"
        />
        <stroke
        android:width="3dp"
        android:color="#878787"
        />

First, you create a file name round_shape.xml in layout folder with content as首先,您在布局文件夹中创建一个文件名为round_shape.xml内容为

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="oval">
            <size android:width="100dp"
                android:height="100dp"/>
            <solid android:color="#59d5fe"/>
        </shape>
    </item>
</selector>

Then in your activity_main.xml (where you want to put the button) adds the code然后在您的activity_main.xml(您要放置按钮的位置)中添加代码

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true"
    android:background="@layout/round_shape"
    android:textColor="#f8fdf9" />

Create circle.xml under drawable folderdrawable文件夹下创建 circle.xml

<shape xmlns:android="http://schemas.android.com/apk/res/android"
       android:shape="oval">
    <solid android:color="#03ae3c"/>
</shape> 

set this as background for layout or view.将此设置为布局或视图的背景。 then assign elevation attribute to your view.然后将elevation属性分配给您的视图。 that will give you visual appearance of its shadow.这会给你它的阴影的视觉外观。

<LinearLayout
            android:layout_width="250dp"
            android:layout_height="250dp"
            android:background="@drawable/circle"
            android:elevation="14dp"
            android:orientation="vertical"/>

Fix size in view layout ex: if you are using this for linearlayout background set say height = 100sp and widht = 100sp修复视图布局中的大小,例如:如果您将其用于线性布局背景设置,请说 height = 100sp 和 widht = 100sp

 <?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android" > <!-- Drop Shadow Stack --> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#00CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#10CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#20CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#30CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <item> <shape android:shape="oval"> <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <solid android:color="#50CCCCCC" /> <corners android:radius="3dp" /> </shape> </item> <!-- Background --> <item> <shape android:shape="oval"> <solid android:color="@android:color/white" /> <corners android:radius="3dp" /> </shape> </item> </layer-list>

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

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