如何使用AppCompat v21在android中创建浮动操作按钮(FAB)?

时间:2014-11-16 23:14:48

标签: android xml

我想创建一个浮动操作按钮(将项目添加到列表视图中),如谷歌日历,保持与棒棒糖前Android版本的兼容性(5.0之前)。

我创建了这个布局:

活动main_activity.xml:

<LinearLayout ... >

     <include
         layout="@layout/toolbar"/>

     <RelativeLayout ... >

     <!-- My rest of the layout -->

          <!-- Floating action button -->
          <ImageButton style="@style/AppTheme"
                     android:layout_width="60dp"
                     android:layout_height="60dp"
                     android:text="New Button"
                     android:id="@+id/button"
                     android:src="@drawable/ic_fab"
                     android:background="@drawable/fab"
                     android:layout_alignParentBottom="true"
                     android:layout_alignParentRight="true"
                     android:layout_marginBottom="24dp"
                     android:layout_marginRight="24dp"/>

     </RelativeLayout>

 </LinearLayout>

Drawable fab.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
       android:shape="oval">
    <solid android:color="#ffa48bc0"/>
</shape>

Style styles.xml

<resources>
    <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">#ff1d79b1</item>
        <item name="colorPrimaryDark">#ff084d95</item>
    </style>
</resources>

结果相似,但没有阴影,这是材料设计的一个特征:

日历的浮动操作按钮:

Calendar's floating action button

我的应用程序的浮动操作按钮:

My app's floating action button

如何将阴影添加到我的按钮?

我已经使用了属性提升,但无效

7 个答案:

答案 0 :(得分:99)

不再需要创建自己的FAB或使用第三方库,它包含在AppCompat 22中。

https://developer.android.com/reference/android/support/design/widget/FloatingActionButton.html

只需在gradle文件中添加名为design in的新支持库:

compile 'com.android.support:design:22.2.0'

......你很高兴:

<android.support.design.widget.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom"
        android:layout_margin="16dp"
        android:clickable="true"
        android:src="@drawable/ic_happy_image" />

答案 1 :(得分:43)

我通常使用xml drawables在pre-lollipop小部件上创建阴影/高程。例如,这里是一个xml drawable,可以在棒棒糖前设备上用来模拟浮动动作按钮的高度。

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:top="8px">
    <layer-list>
        <item>
            <shape android:shape="oval">
                <solid android:color="#08000000"/>
                <padding
                    android:bottom="3px"
                    android:left="3px"
                    android:right="3px"
                    android:top="3px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#09000000"/>
                <padding
                    android:bottom="2px"
                    android:left="2px"
                    android:right="2px"
                    android:top="2px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#10000000"/>
                <padding
                    android:bottom="2px"
                    android:left="2px"
                    android:right="2px"
                    android:top="2px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#11000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#12000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#13000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#14000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#15000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#16000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
        <item>
            <shape android:shape="oval">
                <solid android:color="#17000000"/>
                <padding
                    android:bottom="1px"
                    android:left="1px"
                    android:right="1px"
                    android:top="1px"
                    />
            </shape>
        </item>
    </layer-list>
</item>
<item>
    <shape android:shape="oval">
        <solid android:color="?attr/colorPrimary"/>
    </shape>
</item>
</layer-list>

代替?attr/colorPrimary,您可以选择任何颜色。以下是结果的屏幕截图:

enter image description here

答案 2 :(得分:20)

有很多库在你的应用程序中添加了一个FAB(浮动操作按钮),以下是我知道的一些。

makovkastar's FAB

futuersimple's Composite FAB

Material Design library which includes FAB too

前棒棒糖设备支持所有这些库,最小值为api 8

答案 3 :(得分:8)

这是一个额外的免费Floating Action Button library for Android 它有许多自定义项,需要SDK版本9及更高版本

enter image description here

Full Demo Video

答案 4 :(得分:4)

@Justin Pollard xml代码工作得非常好。作为旁注,您可以使用以下xml行添加涟漪效果。

    <item>
    <ripple
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:color="?android:colorControlHighlight" >
        <item android:id="@android:id/mask">
            <shape android:shape="oval" >
                <solid android:color="#FFBB00" />
            </shape>
        </item>
        <item>
            <shape android:shape="oval" >
                <solid android:color="@color/ColorPrimary" />
            </shape>
        </item>
    </ripple>
</item>

答案 5 :(得分:2)

尝试this library,它支持阴影,minSdkVersion=7并且还隐式支持android:elevation的{​​{1}}属性。

原帖是here

答案 6 :(得分:0)

添加填充和高程:

 android:elevation="10dp"
 android:padding="10dp"