概述
Floating Action Button 简称 FAB,是一个悬浮的圆形按钮,带有阴影(MD 的设计思想就是呈现真实世界的效果,是包含灯光和阴影的)。这个设计很棒!
FAB 的详细介绍可以参照 https://material.io/guidelines/components/buttons-floating-action-button.html 。
FAB 代码详解
首先需要引入 Design Support Library。
compile 'com.android.support:design:25.3.1'
Design Support Library 依赖于 v4 和 v7,所以不需要重复引入。
然后在 Layout 文件中加入 FAB。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.teletian.materialdesign.MainActivity"
tools:ignore="RtlHardcoded">
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab_add"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_marginBottom="20dp"
android:layout_marginRight="20dp"
android:src="@drawable/ic_add_white_24dp"
app:backgroundTint="@color/colorAccent"
app:elevation="6dp"
app:fabSize="normal"
app:pressedTranslationZ="12dp"
app:rippleColor="@color/colorPrimary" />
</RelativeLayout>
关于 FAB 的属性,这里解释一下
app:fabSize:FAB 的大小。
https://material.io/guidelines/components/buttons-floating-action-button.html# 这里面也有介绍,
Normal(Default): 56 x 56dp
Mini: 40 x 40dp
不管是 Normal(Default) 还是 Mini,内部的 icon 都一样大,24 x 24dp。
app:elevation:FAB 的海拔高度。
app:pressedTranslationZ:FAB 的按下状态的海拔高度。
按下状态的海拔高度是高于正常情况下的海拔高度的。
默认的 app:elevation 为 6dp。默认的 app:pressedTranslationZ 为 12dp。
各种默认的海拔高度可以参照 https://material.io/guidelines/material-design/elevation-shadows.html# 。
app:backgroundTint:FAB 的颜色。默认情况下使用强调色,可以更改为其他颜色。
app:rippleColor:FAB 的涟漪颜色。Material Design 要求按钮按下要有涟漪效果,默认的涟漪颜色是灰色的,可以更改为其他的颜色。
FAB 还可以设置显示和隐藏。例如有些应用要求滑动时显示和隐藏。
fab.show()
fab.hide()
设置显示和隐藏的时候监听结束,然后做相应的操作。
fab.show(new FloatingActionButton.OnVisibilityChangedListener() {
@Override
public void onShown(FloatingActionButton fab) {
super.onShown(fab);
}
});
fab.hide(new FloatingActionButton.OnVisibilityChangedListener() {
@Override
public void onHidden(FloatingActionButton fab) {
super.onHidden(fab);
}
});
阴影不显示的 Bug
在老版本的 Support Library 上,会有阴影不显示的 Bug。
具体可以参照 https://issuetracker.google.com/issues/37048580 。