Android Material Design 之 Floating Action Button

概述

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值