gpt4 book ai didi

layout - flutter |如何在任何叠加层之上显示 AlertDialog?

转载 作者:行者123 更新时间:2023-12-03 03:05:33 34 4
gpt4 key购买 nike

如何始终在屏幕上的任何内容上方显示 AlertDialog?

enter image description here

代码:

import 'package:flutter/material.dart';

class CountriesField extends StatefulWidget {
@override
_CountriesFieldState createState() => _CountriesFieldState();
}

class _CountriesFieldState extends State<CountriesField> {
final FocusNode _focusNode = FocusNode();

OverlayEntry _overlayEntry;

final LayerLink _layerLink = LayerLink();

@override
void initState() {
_focusNode.addListener(() {
if (_focusNode.hasFocus) {
this._overlayEntry = this._createOverlayEntry();
Overlay.of(context).insert(this._overlayEntry);
} else {
// this._overlayEntry.remove();
}
});
}

OverlayEntry _createOverlayEntry() {
RenderBox renderBox = context.findRenderObject();
var size = renderBox.size;

return OverlayEntry(
builder: (context) => Positioned(
width: size.width,
child: CompositedTransformFollower(
link: this._layerLink,
showWhenUnlinked: false,
offset: Offset(0.0, size.height + 5.0),
child: Material(
elevation: 4.0,
child: ListView(
padding: EdgeInsets.zero,
shrinkWrap: true,
children: <Widget>[
ListTile(
title: Text('Syria'),
onTap: () {
print('Syria Tapped');
},
),
ListTile(
title: Text('Lebanon'),
onTap: () {
print('Lebanon Tapped');
},
)
],
),
),
),
));
}

@override
Widget build(BuildContext context) {
return CompositedTransformTarget(
link: this._layerLink,
child: Material(
child: TextFormField(
focusNode: this._focusNode,
decoration: InputDecoration(labelText: 'Country'),
),
),
);
}
}


class FormPage extends StatefulWidget {
@override
_FormPageState createState() => _FormPageState();
}

class _FormPageState extends State<FormPage> {
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: <Widget>[
Material(elevation: 4.0, child: CountriesField()),
RaisedButton(
child: Text('Help dialog'),
onPressed: () {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: Text("Help"),
content: Text("This should show on top of any overlay"),
actions: <Widget>[
FlatButton(
child: Text("Close"),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
});
},
)
],
),
);
}
}

最佳答案

没有简单的方法可以让对话框出现在叠加层之上。取决于您的用例,您可以将两者都转换为 Overlay ,或将两者都转换为 Dialog .
这是使用 showDialog 将两者都转换为对话框的示例方法:
demo
您不必返回 AlertDialog显示对话框时的小部件,例如,这里我返回一个 Container带有白色填充物,并包含一个 ListView对于后面的“菜单 A”对话框。
使用时showDialog ,您将获得自动功能,例如调暗背景并单击外部任意位置以关闭。如果您不想要这些或任何其他对话框内容,并且找不到轻松禁用它们的方法,您可以随时转而将两者都转换为 Overlay反而。
对于叠加层,以最新插入的为准,显示在顶部。

关于layout - flutter |如何在任何叠加层之上显示 AlertDialog?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54568180/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com