Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页

2019-10-2217:10:18APP与小程序开发Comments7,663 views字数 3384阅读模式

学习 Flutter 过程中需要处理一个类似 Android 中 PopupWindow 效果的分享弹框页。看似很简单的页面,里面却有很多值得尝试的地方。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

小菜测试时主要用 GridView 和 BottomSheet 来实现的,当然也可以不用 GridView,小菜简单介绍一下这两组 Widget。
Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

GridView

GridView 我们都很熟悉了,是日常中最常用到的控件之一,小菜前段时间学习了一下 ListView 的基本用法,GridView 的用法基本相同,小菜不再多说,只提醒一个属性,用来设置 GridView item 基本属性。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

const SliverGridDelegateWithFixedCrossAxisCount({
   @required this.crossAxisCount, // 每行 item 个数
   this.mainAxisSpacing = 0.0,    // 列间距,即 item 左右间距
   this.crossAxisSpacing = 0.0,   // 行间距,即 item 上下间距
   this.childAspectRatio = 1.0,   // item 宽高比,默认1:1
})

Tips:注意设置 item 个数与列间距的配合,如果太大可能会造成页面展示不全等异常情况。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

BottomSheet

BottomSheet 小菜理解为是从底部向上弹的工作表,主要分为两种:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

式工作表:类似于一个全新的页面,完全展示 ;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

@override
Widget build(BuildContext context) {
return new Scaffold(
    appBar: new AppBar(
      title: new Text("分享页面"),
    ),
    body: new Center(
      child: new Builder(builder: (BuildContext context) {
        return new FlatButton(
            onPressed: () {
              showBottomSheet(
                  context: context,
                  builder: (BuildContext context) {
                    return _showNomalWid(context);
                  });
            },
            child: new Text("我要分享"),
            color: );
      }),
    ));
}

Widget _showNomalWid(BuildContext context) {
    return new Container(
//      height: 320.0,
//      color: Colors.greenAccent,
      child: new GridView.builder(
        gridDelegate: new SliverGridDelegateWithFixedCrossAxisCount(
            crossAxisCount: 4, mainAxisSpacing: 5.0, childAspectRatio: 1.0),
        itemBuilder: (BuildContext context, int index) {
          return new Column(
            children: <Widget>[
              new Padding(
                padding: (0.0, 6.0, 0.0, 6.0),
                child: new Image.asset(
                  'images/${urlItems[index]}', width: 50.0, height: 50.0, fit: BoxFit.fill,
                ),
              ),
              new Text(nameItems[index])
            ],
          );
        },
        itemCount: ,
      ),
    );
}

若用 showBottomSheet 方式开启工作表,同时内容 Widget 不限制宽高,效果为新打开一个页面,点击空白区不会消失,如图:Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

若此时设置内容 Widget 宽高,会发现依旧是重新打开一个页面,高度从底向上占据所设置高度,且点击空白区不会消失,如图:
Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

式工作表:是一个半透明的页面,默认占据屏幕一半 。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

@override
Widget build(BuildContext context) {
return new Scaffold(
    appBar: new AppBar(
      title: new Text("分享页面"),
    ),
    body: new Center(
      child: new Builder(builder: (BuildContext context) {
        return new FlatButton(
            onPressed: () {
              showModalBottomSheet(
                  context: context,
                  builder: (BuildContext context) {
                    return _showNomalWid(context);
                  });
            },
            child: new Text("我要分享"),
            color: );
      }),
    ));
}

若用 showModalBottomSheet 方式开启工作表,同时内容 Widget 不限制宽高,效果为打开一个半透明页面,默认占据屏幕一半,点击空白区工作表消失,如图:
Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

若此时设置内容 Widget 宽高,会发现依旧是打开一个半透明页面,高度从底向上占据所设置高度,且点击空白区会消失,如图:
Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

若此时设置内容 Widget 数据量很多,效果如何呢,这就是小菜选择用 GridView 的原因,在现有宽高内进行可滑动操作即可,如图:
Flutter开发类似 Android 中 PopupWindow 效果的分享弹框页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

核心源码
小菜稍稍修饰了一下页面效果,主要源码如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html

import 'package:flutter/';

class SharePopup extends StatelessWidget {
  List<String> nameItems = <String>[
    '微信', '朋友圈', 'QQ', 'QQ空间', '微博', 'FaceBook', '邮件', '链接'
  ];
  List<String> urlItems = <String>[
    '', '', '', '',
    '', '', '', ''
  ];

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
        appBar: new AppBar(
          title: new Text("分享页面"),
        ),
        body: new Center(
          child: new Builder(builder: (BuildContext context) {
            return new FlatButton(
                onPressed: () {
                  showModalBottomSheet(
                      context: context,
                      builder: (BuildContext context) {
                        return _shareWidget(context);
                      });
                },
                child: new Text("我要分享"),
                color: );
          }),
        ));
  }

  Widget _shareWidget(BuildContext context) {
    return new Container(
      height: 250.0,
      child: new Column(
        children: <Widget>[
          new Padding(
            padding: (0.0, 10.0, 0.0, 0.0),
            child: new Container(
              height: 190.0,
              child: new GridView.builder(
                gridDelegate: new SliverGridDelegateWithFixedCrossAxisCount(
                    crossAxisCount: 4,
                    mainAxisSpacing: 5.0,
                    childAspectRatio: 1.0),
                itemBuilder: (BuildContext context, int index) {
                  return new Column(
                    children: <Widget>[
                      new Padding(
                        padding: (0.0, 6.0, 0.0, 6.0),
                        child: new Image.asset( 'images/${urlItems[index]}', width: 50.0, height: 50.0, fit: BoxFit.fill, ) ),
                      new Text(nameItems[index])
                    ],
                  );
                },
                itemCount: ,
              ),
            ),
          ),
          new Container( height: 0.5, color: Grey, ),
          new Center( child: new Padding(
              padding: (0.0, 8.0, 0.0, 8.0),
              child: new Text( '取  消', style: new TextStyle(fontSize: 18.0, color: Grey), ) ), )
        ],
      ),
    );
  }
}
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/xcx/16928.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/xcx/16928.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定