Flutter 实现popup window

在Android 原生库里,popupWindow 为我们提供很大的便利,自定义视图,自定义位置。我们可以实现新手引导等等。
但是在flutter 里,查过flutter 有showDialog,showMenu 方法。但是都不是我想要的popupWindow. 因为: showDialog 无法指定位置,永远有左右两边的padding;showMenu 无法自定义视图。所以需要我们自己动手写这部分代码。
灵感来源就是PopupMenuButton.
先做PopupMenuButton 源码分析:

Flutter 实现popup window_第1张图片
image.png

在PopupMenuButton 中,最重要的是itemBuilder: 构造列表item 函数;child: 按钮的样式; 和offset: 点击按钮后出现窗口的位置。

  1. itemBuilder
    itemBuilder 返回的是List> 由showMenu函数传入_PopupMenuRoute, 在_PopupMenuRoute 的buildPage 里面 构造出类型为_PopupMenu 的 Widget 对象,作为新page 的显示内容。
    所以,我们要显示自定义视图,只要重写XXXRoute 以及Route 里面的buildPage 方法。

  2. offset:
    offset 默认为Offset.zero.
    _PopupMenuButtonState 在调用showMenu 之前,会计算 menu 显示位置:


    Flutter 实现popup window_第2张图片
    image.png

    overlay 是flutter 用于管理视图的widget。以上代码会计算在overlay 的范围里做offset 偏移,得出最终的显示位置。
    要注意的是 _PopupMenuRouteLayout 里面,对RelativeRect 的处理,是从top 开始,并不是rect 的中心点。


    Flutter 实现popup window_第3张图片
    image.png

    所以在写offset 的时候,要注意需要从top 开始,比如需要显示在button 上面,那么y 的偏移就是整个menu的高度。

通过分析以上两个要点,来写popupWindow:


Flutter 实现popup window_第4张图片
image.png

增加window 属性,显示 window 内容;
新建_PopupWindowRoute 重写buildPage 方法:


Flutter 实现popup window_第5张图片
image.png

至于state 以及windowLayout 稍作修改就好了。
20190316_160029.gif

地址: https://github.com/wilin52/popup_window

Getting Started

1.Install

dependencies:
  popup_window: ^1.0.0+3

2.Import

import 'package:popup_window/popup_window.dart';

3.Usage

PopupWindowButton(
    offset: Offset(0, 200),
        child: Image(image: AssetImage("images/ic_share.png")),
        window: Container(
            padding: EdgeInsets.all(50),
            alignment: Alignment.center,
            color: Colors.greenAccent,
            height: 200,
            child: Container(
                color: Colors.white,
                height: 50,
            ) ,
        ),
)

你可能感兴趣的:(Flutter 实现popup window)