赞
踩
为了提高这个开发效率突然想到可以在应用上增加一个悬浮窗组件然后实现主题切换和语言切换的功能,这样在任意一个页面就可以快速的查看效果。不用来回切换到设置页面内去进行切换了。
悬浮窗组件也可以随意进行拖动,打开一个新的页面悬浮窗也始终是在最顶部的
DeveloperWidget
继承StatefulWidget
组件即可Overlay
组件///省略部分代码
@override
Widget build(BuildContext context) {
return Directionality(
textDirection: TextDirection.ltr,
child: Overlay(
initialEntries: [
OverlayEntry(
builder: (c) {
return widget.child;
},
),
OverlayEntry(
builder: (c) {
return Positioned(
left: _offset.dx,
top: _offset.dy,
child: Draggable(
childWhenDragging: Container(),
feedback: _developerWidget(),
child: _developerWidget(),
onDragEnd: (DraggableDetails detail) {
setState(() {
_offset = detail.offset;
});
},
),
);
},
),
],
),
);
}
///悬浮窗组件内具体自己要实现的功能组件,此处省略
Widget _developerWidget(){
}
Directionality
组件,这个是必须要的;因为我们这个组件最终是如下使用的,让MaterialApp
成为这个DeveloperWidget
组件的子元素DeveloperWidget(
child: MaterialApp(
localizationsDelegates: const [
GlobalMaterialLocalizations.delegate,
GlobalCupertinoLocalizations.delegate,
GlobalWidgetsLocalizations.delegate
],
home: MainPage(),
),
);
MaterialApp
成为子元素,那么在跳转一个新的页面时;我们的悬浮窗就不能在最顶层了Draggable
组件来进行处理 非常的方便Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。