在Android 原生库里,popupWindow 为我们提供很大的便利,自定义视图,自定义位置。我们可以实现新手引导等等。
但是在flutter 里,查过flutter 有showDialog,showMenu 方法。但是都不是我想要的popupWindow. 因为: showDialog 无法指定位置,永远有左右两边的padding;showMenu 无法自定义视图。所以需要我们自己动手写这部分代码。
灵感来源就是PopupMenuButton.
先做PopupMenuButton 源码分析:
在PopupMenuButton 中,最重要的是itemBuilder: 构造列表item 函数;child: 按钮的样式; 和offset: 点击按钮后出现窗口的位置。
itemBuilder
itemBuilder 返回的是List<PopupMenuEntry<T>> 由showMenu函数传入_PopupMenuRoute, 在_PopupMenuRoute 的buildPage 里面 构造出类型为_PopupMenu 的 Widget 对象,作为新page 的显示内容。
所以,我们要显示自定义视图,只要重写XXXRoute 以及Route 里面的buildPage 方法。-
offset:
offset 默认为Offset.zero.
_PopupMenuButtonState 在调用showMenu 之前,会计算 menu 显示位置:
overlay 是flutter 用于管理视图的widget。以上代码会计算在overlay 的范围里做offset 偏移,得出最终的显示位置。
要注意的是 _PopupMenuRouteLayout 里面,对RelativeRect 的处理,是从top 开始,并不是rect 的中心点。
所以在写offset 的时候,要注意需要从top 开始,比如需要显示在button 上面,那么y 的偏移就是整个menu的高度。
通过分析以上两个要点,来写popupWindow:
增加window 属性,显示 window 内容;
新建_PopupWindowRoute 重写buildPage 方法:
至于state 以及windowLayout 稍作修改就好了。
地址: 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,
) ,
),
)