flutter实现底部抽屉效果

 更新时间:2022年03月23日 11:35:27   作者:齐安郡晚秋  
这篇文章主要为大家详细介绍了flutter实现底部抽屉效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了flutter实现底部抽屉效果的具体代码,供大家参考,具体内容如下

安卓:showModalBottomSheet
IOS:showCupertinoModalPopup

效果图

完整代码

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';

///@作者: Q.L
///@创建日期: 2021-09-09 10:55
///@描述: {底部抽屉}
class ActionSheetPage extends StatefulWidget {
  const ActionSheetPage({Key? key}) : super(key: key);

  @override
  _ActionSheetPageState createState() => _ActionSheetPageState();
}

class _ActionSheetPageState extends State<ActionSheetPage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('底部抽屉弹出'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            ElevatedButton(
                onPressed: () {
                  _showModalBottomSheet();
                },
                child: Text('安卓弹出')),
            ElevatedButton(
                onPressed: () {
                  _showCupertinoModalPopup();
                },
                child: Text('IOS弹出')),
          ],
        ),
      ),
    );
  }

  _showModalBottomSheet() async {
    var _result = await showModalBottomSheet(
        context: context,
        backgroundColor: Colors.greenAccent, //背景颜色
        // elevation: 500, //阴影
        shape: RoundedRectangleBorder(
            // borderRadius: BorderRadius.all(Radius.circular(10)),//所有圆角边框
            borderRadius:
                BorderRadius.only(topLeft: Radius.circular(10), topRight: Radius.circular(10))),
        isScrollControlled: false, //是否是全屏还是半屏,true全屏,默认false半屏
        isDismissible: true, //外部是否可以点击,false不可以点击,true可以点击,点击后消失
        builder: (BuildContext context) {
          return Column(
            mainAxisSize: MainAxisSize.min, // 设置最小的弹出
            children: [
              ListTile(
                leading: Icon(Icons.photo_camera),
                title: Text("拍照"),
                onTap: () {
                  Navigator.of(context).pop('拍照');
                },
              ),
              ListTile(
                leading: Icon(Icons.photo_library),
                title: Text("相册"),
                onTap: () {
                  Navigator.of(context).pop('相册');
                },
              ),
            ],
          );
        });
    print('选择了安卓==>>${_result ?? '点击了屏幕取消'}');
  }

  _showCupertinoModalPopup() async {
    var result = await showCupertinoModalPopup(
        context: context,
        builder: (context) {
          return CupertinoActionSheet(
            title: Text('提示'),
            message: Text('是否要编辑当前项?'),
            actions: [
              CupertinoActionSheetAction(
                child: Text('编辑'),
                onPressed: () {
                  Navigator.of(context).pop('编辑');
                },
                isDefaultAction: true,
              ),
              CupertinoActionSheetAction(
                child: Text('删除'),
                onPressed: () {
                  Navigator.of(context).pop('删除');
                },
                isDestructiveAction: true,
              ),
            ],
            cancelButton: CupertinoActionSheetAction(
              child: Text('取消'),
              onPressed: () {
                Navigator.of(context).pop('取消');
              },
            ),
          );
        });
    print('选择了IOS==>>${result ?? '点击了屏幕取消'}');
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android AlertDialog六种创建方式案例详解

    Android AlertDialog六种创建方式案例详解

    这篇文章主要介绍了Android AlertDialog六种创建方式案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Android开发简单实现摇动动画的方法

    Android开发简单实现摇动动画的方法

    这篇文章主要介绍了Android开发简单实现摇动动画的方法,结合实例形式分析了Android摇动动画的布局与功能简单实现方法,需要的朋友可以参考下
    2017-10-10
  • Android编程开发中的正则匹配操作示例

    Android编程开发中的正则匹配操作示例

    这篇文章主要介绍了Android编程开发中的正则匹配操作,结合具体实例形式分析了Android针对手机号、邮箱及IP的正则匹配操作相关实现技巧,需要的朋友可以参考下
    2017-06-06
  • Android通过记住密码功能学习数据存储类SharedPreferences详解及实例

    Android通过记住密码功能学习数据存储类SharedPreferences详解及实例

    这篇文章主要通过“记住密码”实例功能学习为大家介绍了Android数据存储类SharedPreferences,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • Android系统添加自己写的工具

    Android系统添加自己写的工具

    今天小编就为大家分享一篇关于Android系统添加自己写的工具的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • so加载Linker跟NameSpace机制详解

    so加载Linker跟NameSpace机制详解

    这篇文章主要为大家介绍了so加载Linker跟NameSpace机制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • Android轮播图点击图片放大效果的实现方法

    Android轮播图点击图片放大效果的实现方法

    这篇文章主要给大家介绍了关于Android轮播图点击图片放大效果的实现方法,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • Android 进阶实现性能优化之OOM与Leakcanary详解原理

    Android 进阶实现性能优化之OOM与Leakcanary详解原理

    LeakCanary 是大名鼎鼎的 square 公司开源的内存泄漏检测工具。目前上大部分App在开发测试阶段都会接入此工具用于检测潜在的内存泄漏问题,做的好一点的可能会搭建一个服务器用于保存各个设备上的内存泄漏问题再集中处理
    2021-11-11
  • Flutter实现视频压缩功能的示例代码

    Flutter实现视频压缩功能的示例代码

    移动应用程序中,视频占用了大量的存储空间和带宽,这在一定程度上影响了应用程序的性能和用户体验,所以本文为大家准备了Flutter实现视频压缩的方法,需要的可以参考一下
    2023-06-06
  • Android实现图片自动轮播并且支持手势左右无限滑动

    Android实现图片自动轮播并且支持手势左右无限滑动

    这篇文章给大家介绍android实现图片自动轮播并且支持手势左右无限滑动,代码简单易懂,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-10-10

最新评论