Flutter FloatingActionButton 从核心用法到高级定制

news2025/3/17 7:20:39

目录

1. 引言

2. FloatingActionButton 的基本用法

3. 主要属性

4. 进阶定制技巧

4.1 扩展型 FAB

4.2 动态变形动画

4.3 多个 FAB 协同

5. 主题与动效集成

5.1 全局主题配置

5.2 平台适配方案

5.3 高级动画控制器

6. 最佳实践

6.1 布局规范

6.2 性能优化

6.3 无障碍支持

7. 小技巧

7.1 如何调整 FAB 位置?

7.2 点击区域过小怎么办?

7.3 键盘弹出时遮挡 FAB?

7.4 动态更新扩展型 FAB 内容?

相关推荐


1. 引言

    FloatingActionButton(FAB)是 Material Design 中的核心交互组件,具有以下特征:

  • 悬浮在内容层之上的圆形按钮

  • 通常用于应用的主操作(如创建、分享)

  • 支持图标、文字及组合内容

  • 默认位置在屏幕右下角

设计规范对比

类型直径适用场景
标准 FAB56×56 dp主操作(单个核心功能)
小型 FAB40×40 dp屏幕空间有限时使用
扩展型 FAB可变宽高需要文字说明的复杂操作

2. FloatingActionButton 的基本用法

    FloatingActionButton 主要通过 onPressed 绑定点击事件,并可添加 child 作为按钮内容。

FloatingActionButton(
  onPressed: () {
    print('FAB 被点击');
  },
  child: Icon(Icons.add),
)

        如果 onPressed 设为 null,按钮会变为不可点击状态,跟其他按钮一样。

3. 主要属性

属性类型说明
onPressedVoidCallback点击回调(设为 null 时禁用)
childWidget内容组件(通常为 Icon 或 Text
backgroundColorColor按钮背景色
foregroundColorColor图标/文字颜色
shapeShapeBorder按钮形状(圆形/圆角矩形等)
heroTagObject唯一标识(多个 FAB 时必须设置)
minibool是否为小型 FAB(默认 false
tooltipString长按提示文字(无障碍支持)

4. 进阶定制技巧

4.1 扩展型 FAB

FloatingActionButton.extended(
  icon: Icon(Icons.share),
  label: Text("分享到CSDN平台"),
  onPressed: () {},
)

4.2 动态变形动画

bool _isExpanded = false;

FloatingActionButton(
  onPressed: () {
    setState(() => _isExpanded = !_isExpanded);
  },
  child: AnimatedSwitcher(
    duration: Duration(milliseconds: 300),
    child: _isExpanded 
        ? Icon(Icons.check)
        : Icon(Icons.add),
  ),
)

4.3 多个 FAB 协同

Scaffold(
  floatingActionButton: Column(
    mainAxisSize: MainAxisSize.min,
    children: [
      FloatingActionButton(
        heroTag: "fab1",
        child: Icon(Icons.camera),
        onPressed: () {},
      ),
      SizedBox(height: 16),
      FloatingActionButton(
        heroTag: "fab2",
        child: Icon(Icons.mic),
        onPressed: () {},
      ),
    ],
  ),
)

5. 主题与动效集成

5.1 全局主题配置

MaterialApp(
  theme: ThemeData(
    floatingActionButtonTheme: FloatingActionButtonThemeData(
      backgroundColor: Colors.deepOrange,
      foregroundColor: Colors.white,
      shape: RoundedRectangleBorder(
        borderRadius: BorderRadius.circular(16),
      ),
    ),
  ),
)

5.2 平台适配方案

dart

复制

FloatingActionButton(
  shape: Platform.isIOS 
      ? CircleBorder()
      : RoundedRectangleBorder(
          borderRadius: BorderRadius.circular(8),
        ),
)

5.3 高级动画控制器

AnimationController _animationController;

@override
void initState() {
  _animationController = AnimationController(
    vsync: this,
    duration: Duration(seconds: 1),
  )..repeat(reverse: true);
}

FloatingActionButton(
  backgroundColor: ColorTween(
    begin: Colors.blue,
    end: Colors.purple,
  ).animate(_animationController).value,
)

6. 最佳实践

6.1 布局规范

  • 优先使用标准尺寸(56dp)

  • 与底部导航栏保持至少 16dp 间距

  • 在滚动视图中自动隐藏(通过 ScaffoldMessenger

6.2 性能优化

// 避免不必要的重建
const FloatingActionButton(
  // ...
);

// 分离动画控制器
late final AnimationController _controller = AnimationController(
  duration: Duration(seconds: 1),
  vsync: this,
);

6.3 无障碍支持

FloatingActionButton(
  tooltip: '创建新文档',
  onPressed: () {},
  child: Icon(Icons.add),
)

7. 小技巧

7.1 如何调整 FAB 位置?

Scaffold(
  floatingActionButtonLocation: 
      FloatingActionButtonLocation.miniCenterTop,
)

7.2 点击区域过小怎么办?

FloatingActionButton(
  mini: false, // 确保非小型模式
  shape: CircleBorder(),
  materialTapTargetSize: MaterialTapTargetSize.padded,
)

7.3 键盘弹出时遮挡 FAB?

Scaffold(
  resizeToAvoidBottomInset: false, // 禁止调整布局
  floatingActionButton: Padding(
    padding: EdgeInsets.only(
        bottom: MediaQuery.of(context).viewInsets.bottom),
    child: FloatingActionButton(...),
  ),
)

7.4 动态更新扩展型 FAB 内容?

ValueListenableBuilder<bool>(
  valueListenable: _isUploading,
  builder: (context, value, child) {
    return FloatingActionButton.extended(
      label: value ? Text("上传中...") : Text("开始上传"),
      icon: value 
          ? CircularProgressIndicator(color: Colors.white)
          : Icon(Icons.cloud_upload),
    );
  },
)

相关推荐

Flutter 按钮组件 TextButton 详解-CSDN博客文章浏览阅读1.8k次,点赞60次,收藏62次。TextButton 适用于不需要强调的按钮操作,如取消、返回或辅助功能。通过 style 属性可以自定义颜色、形状、背景等。掌握 TextButton 的使用,可以帮助开发者创建更加灵活和简洁的 UI 交互体验。 https://shuaici.blog.csdn.net/article/details/146068020Flutter 按钮组件 ElevatedButton 详解-CSDN博客文章浏览阅读844次,点赞20次,收藏21次。本文详细描述 ElevatedButton 是 Flutter 中常见的按钮组件,适用于强调操作。通过 style 属性可以灵活地修改背景色、形状、大小等。掌握 ElevatedButton 的使用可以帮助开发者创建更美观的交互界面。 https://shuaici.blog.csdn.net/article/details/146067694

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2316484.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【恒流源cc与恒压源cv典型电路解析】

在电子电路设计中&#xff0c;恒流源和恒压源是两种至关重要的电源类型&#xff0c;它们分别能为负载提供稳定的电流和电压。以下将详细解析这两种电源的典型电路。 ## 一、恒压源 ### &#xff08;一&#xff09;采用线性稳压器的恒压源电路 1. **电路组成** - 以常见的 78…

Anaconda conda常用命令:从入门到精通

1 创建虚拟环境 conda create -n env_name python3.8 2 创建虚拟环境的同时安装必要的包 conda create -n env_name numpy matplotlib python3.8 3 查看有哪些虚拟环境 以下三条命令都可以。注意最后一个是”--”&#xff0c;而不是“-”. conda env list conda info -e c…

Topo2Seq:突破DETR局限,车道拓扑推理新高度

本篇针对先前DETR类框架远距离感知较弱且车道端点不对齐问题&#xff0c;提出了一种通过拓扑序列学习来增强拓扑推理的新方法Topo2Seq。在OpenLane-V2数据集上的实验结果表明&#xff0c;Topo2Seq在拓扑推理方面实现了最先进的性能。 ©️【深蓝AI】编译 论文标题&#xf…

程序地址空间:深度解析其结构,原理与在计算机系统中的应用价值

目录 1. 程序地址空间回顾 1.1 虚拟地址 2.进程地址空间 分页&虚拟地址空间 引入新概念 解释上述关于同样的地址不同的变量值问题 回答一个历史遗留问题 ​编辑 3.虚拟内存管理 虚拟内存是什么 虚拟地址空间区域划分 为什么要有虚拟地址空间 1. 程序地址空间回…

火语言RPA--列表项内容设置

【组件功能】&#xff1a;设置列表项内容 配置预览 配置说明 索引项位置支持T或# 列表对象待修改内容的索引位置。 内容值 支持T或# 默认FLOW输入项 修改的内容值。 示例 对象修改 描述 列表对象索引为0的数据修改为A字符串&#xff0c;并打印修改结果。 配置 输出结…

1.Qt SDK 的下载和安装

1Qt 下载官⽹&#xff1a; http://download.qt.io/archive/qt/ 2版本自行选择 3下载对应版本的.exe文件 4下载包下载完成 5双击.exe文件&#xff0c;默认下一步&#xff0c;要注册一个qt的账户 6记住程序安装的位置&#xff0c;后面要配置环境变量 7勾3个&#xff08;组件自行…

嵌入式系统中的Board Support Package (BSP)详解:以Xilinx Zynq为例

嵌入式系统中的Board Support Package (BSP)详解&#xff1a;以Xilinx Zynq为例 引言 在嵌入式系统开发中&#xff0c;硬件与软件的无缝集成至关重要。Board Support Package (BSP) 作为连接硬件和操作系统的桥梁&#xff0c;在这一过程中扮演着核心角色。本文将深入探讨BSP的…

Vue 生命周期详解:从创建到销毁的全过程

Vue.js 是一个流行的前端框架&#xff0c;它通过组件化的方式帮助开发者构建用户界面。在 Vue 中&#xff0c;每个组件实例都有其生命周期&#xff0c;从创建、挂载、更新到销毁&#xff0c;Vue 提供了一系列的生命周期钩子函数&#xff0c;允许我们在组件的不同阶段执行自定义…

计算机基础:二进制基础12,十进制数转换为十六进制

专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏&#xff0c;故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 &#xff08;一&#xff09;WIn32 专栏导航 上一篇&#xff1a;计算机基础&#xff1a;二进制基础11&#xff0c;十六进制的位基…

SpringCloud系列教程(十四):Sentinel持久化

Sentinel之前已经搭建和应用成功了&#xff0c;但是它有一个很大的缺点就是官方没有提供持久化的方案&#xff0c;从项目源码上看感觉这款工具也没有完成的太好&#xff0c;所以需要我们去对它进行二次开发。要补充的功能大概如下&#xff1a; 1、将Sentinel接入nacos中&#…

Slider,InputField,Scroll View,Scrollbar及Layout组件

Slider组件 Fill Rect:填充滑动条选中区域的背景图部分 Handle Rect:滑动条的球 Direction:滑动条的滑动方向 Min Value:起始位置的数值&#xff08;浮点数&#xff09; Max Value:结束位置的数值&#xff08;浮点数&#xff09; Whole Numbers:必须为整数&#xff08;布尔…

ollama注册自定义模型(GGUF格式)

文章目录 ollama注册自定义模型&#xff08;GGUF格式&#xff09;下载模型注册模型(GGUF格式) ollama注册自定义模型&#xff08;GGUF格式&#xff09; 需要全程开启ollama nohup ollama serve > ollama.log 2>&1 &需要注意&#xff0c;尽管手动下载的GGUF格式模…

HarmonyOS NEXT 声明式UI语法学习笔记-创建自定义组件

基础语法概述 ArkTS的基本组成 装饰器&#xff1a;用于装饰类、结构、方法以及变量&#xff0c;并赋予其特殊含义。如上图都是装饰器&#xff0c;Component表示自定义组件&#xff0c;Entry表示表示自定义组件的入口组件&#xff0c;State表示组件中的状态变量&#xff0c;当状…

97.HarmonyOS NEXT跑马灯组件教程:基础概念与架构设计

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT跑马灯组件教程&#xff1a;基础概念与架构设计 1. 跑马灯组件概述 跑马灯&#xff08;Marquee&#xff09;是一种常见的UI组件&a…

81.HarmonyOS NEXT 状态管理与响应式编程:@Observed深度解析

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT 状态管理与响应式编程&#xff1a;Observed深度解析 文章目录 HarmonyOS NEXT 状态管理与响应式编程&#xff1a;Observed深度解析…

股指期货有卖不出去的时候吗?

在股指期货的交易世界里&#xff0c;很多人都有这样的疑问&#xff1a;股指期货会不会有卖不出去的时候呢&#xff1f;答案是会的&#xff0c;下面咱们就来详细唠唠为啥会出现这种情况。 市场极端行情下难以卖出 1.跌停限制&#xff1a;股指期货和股票一样&#xff0c;也有涨…

开发、科研、日常办公工具汇总(自用,持续更新)

主要记录汇总一下自己平常会用到的网站工具&#xff0c;方便查阅。 update&#xff1a;2025/2/11&#xff08;开发网站补一下&#xff09; update&#xff1a;2025/2/21&#xff08;补充一些AI工具&#xff0c;刚好在做AI视频相关工作&#xff09; update&#xff1a;2025/3/7&…

HTML5 drag API实现列表拖拽排序

拖拽API&#xff08;Drag and Drop API&#xff09;是HTML5提供的一组功能&#xff0c;使得在网页上实现拖放操作变得更加简单和强大。这个API允许开发者为网页元素添加拖拽功能&#xff0c;用户可以通过鼠标将元素拖动并放置到指定的目标区域。 事件类型 dragstart&#xff1…

改变一生的思维模型【11】升维

升维思维模型&#xff1a;突破认知局限的破局法则 一、定义与核心逻辑 升维思维是通过增加分析维度&#xff0c;将问题投射到更高认知层次寻找解决方案的思考方式。其本质是跳出原有竞争维度&#xff0c;在更广阔的空间重构游戏规则。核心逻辑在于&#xff1a;当低维战场陷入…

【动手学深度学习】#2线性神经网络

主要参考学习资料&#xff1a; 《动手学深度学习》阿斯顿张 等 著 【动手学深度学习 PyTorch版】哔哩哔哩跟李牧学AI 目录 2.1 线性回归2.1.1 线性回归的基本元素线性模型损失函数解析解随机梯度下降 2.1.3 最大似然估计 2.2 线性回归从零开始实现2.2.1 生成数据集2.2.2 读取数…