Flutter 底部向上动画弹出的菜单选项

题记

—— 优美的应用体验 来自于细节的处理,更源自于码农的自我要求与努力,当然也需要码农年轻灵活的思维。


Flutter是谷歌推出的最新的移动开发框架。

【x1】微信公众号的每日提醒 随时随记 每日积累 随心而过 文章底部扫码关注

【x2】各种系列的视频教程 免费开源 关注 你不会迷路

【x3】系列文章 百万 Demo 随时 复制粘贴 使用

【x4】一目了然的源码

【x5】简短的视频不一样的体验


本文章实现Demo运行效果 如下:
在这里插入图片描述

小编以将这个效果写成了一个依赖库,大家可以直接调用使用pub

dependencies:
  shake_animation_widget: ^2.1.2

然后如上图的Demo实现,首先是构建一个页面,代码如下:

class HomePage extends StatefulWidget {
  @override
  _TestPageState createState() => _TestPageState();
}

class _TestPageState extends State<HomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("测试"),
      ),
      body: Container(
        //填充
        constraints: BoxConstraints.expand(),
        //层叠布局
        child: Stack(
          children: [
            //页面中的其他布局
            //右侧向上弹出的动画菜单
            buildContainer(),
          ],
        ),
      ),
    );
  }
 }

然后就是通过 RoteFlowButtonMenu 来构建实现,代码如下:

  Container buildContainer() {
    return Container(
      child: RoteFlowButtonMenu(
        //菜单图标组
        iconList: [
          Icon(
            Icons.backup_table_sharp,
            color: Colors.white,
          ),
          Icon(Icons.aspect_ratio, color: Colors.white),
          Icon(Icons.medical_services, color: Colors.white),
          Icon(Icons.add, color: Colors.white),
        ],
        //菜单项所使用的背景颜色
        iconBackgroundColorList: [
          Colors.deepOrangeAccent,
          Colors.deepPurple,
          Colors.blueGrey,
          Colors.blueAccent,
        ],
        //点击事件回调
        clickCallBack: (int index) {},
      ),
    );
  }

本文章提供的效果如果能满足你的开发需求,直接使用就可以,如果还需要其他效果也以联系小编进行扩展,当然你也可以下载下来依赖库源码参考小编的实现,举一反三实现你想要的效果。

不局限于思维,不局限语言限制,才是编程的最高境界。

以小编的性格,肯定是要录制一套视频的,点击这里查看详情

有兴趣 你可以关注一下 西瓜视频 — 早起的年轻人

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

早起的年轻人

创作源于分享

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值