首页
/ FABsMenu 开源项目教程

FABsMenu 开源项目教程

2026-01-19 10:15:16作者:戚魁泉Nursing

项目介绍

FABsMenu 是一个基于 Android 的浮动动作按钮(Floating Action Button, FAB)菜单库,由 Jahir Fiquitiva 开发。该库允许开发者轻松地在应用中集成一个可展开的 FAB 菜单,提供了一种直观且用户友好的方式来展示多个操作选项。FABsMenu 遵循 Material Design 指南,支持自定义图标、颜色和动画效果,使得应用界面更加丰富和动态。

项目快速启动

添加依赖

首先,在项目的 build.gradle 文件中添加以下依赖:

dependencies {
    implementation 'com.github.jahirfiquitiva:FABsMenu:1.1.3'
}

布局文件

在布局文件中添加 FABsMenu 组件:

<com.jahirfiquitiva.fabs.FABsMenuLayout
    android:id="@+id/fabs_menu_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.jahirfiquitiva.fabs.FABsMenu
        android:id="@+id/fabs_menu"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        fab:srcCompat="@drawable/ic_menu"
        fab:fabSize="normal"
        fab:backgroundTint="@color/colorAccent"
        fab:rippleColor="@color/colorAccent"/>

    <com.jahirfiquitiva.fabs.TitleFAB
        android:id="@+id/mini_fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        fab:srcCompat="@drawable/ic_heart"
        fab:fab_title="Mini fab with long text"
        fab:fabSize="mini"
        fab:backgroundTint="@color/blue_semi"
        fab:rippleColor="@color/blue_semi_pressed"/>

    <com.jahirfiquitiva.fabs.TitleFAB
        android:id="@+id/green_fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        fab:srcCompat="@drawable/ic_person"
        fab:fab_title="Fab with even longer text that might not even fit in all the screens"
        fab:fabSize="normal"
        fab:backgroundTint="@color/green"
        fab:rippleColor="@color/green_pressed"/>
</com.jahirfiquitiva.fabs.FABsMenuLayout>

代码实现

在 Activity 或 Fragment 中初始化和配置 FABsMenu:

import com.jahirfiquitiva.fabs.FABsMenu;
import com.jahirfiquitiva.fabs.TitleFAB;

public class MainActivity extends AppCompatActivity {
    private FABsMenu fabsMenu;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        fabsMenu = findViewById(R.id.fabs_menu);
        TitleFAB miniFab = findViewById(R.id.mini_fab);
        TitleFAB greenFab = findViewById(R.id.green_fab);

        fabsMenu.addButton(miniFab);
        fabsMenu.addButton(greenFab);
    }
}

应用案例和最佳实践

应用案例

FABsMenu 可以用于各种类型的应用,尤其是那些需要快速访问多个操作的场景。例如,在一个笔记应用中,可以使用 FABsMenu 来快速添加文本、图片或录音笔记。

最佳实践

  1. 限制菜单项数量:根据 Material Design 指南,FABsMenu 不应包含超过 6 个项目,以保持界面的简洁和易用性。
  2. 使用合适的图标:确保为 FABsMenu 和其子按钮选择合适的图标,这些图标在旋转状态下也应保持清晰可辨。
  3. 自定义颜色和动画:通过自定义背景颜色和动画效果,可以使 FABsMenu 更好地融入应用的整体设计风格。

典型生态项目

FABsMenu

登录后查看全文
热门项目推荐
相关项目推荐