Future<T> showDialog<T>({
@required BuildContext context,
bool barrierDismissible = true,
@Deprecated(
'Instead of using the "child" argument, return the child from a closure '
'provided to the "builder" argument. This will ensure that the BuildContext '
'is appropriate for widgets built in the dialog.'
) Widget child,
WidgetBuilder builder,
})
複製代碼
'context' : 這個是必須傳遞的參數,也是能夠顯示出視圖的關鍵
'barrierDismissible':這個是安卓中觸摸dialog外部自動取消Dialog
'builder':用於建立Widget
複製代碼
RaisedButton(
child: Text("showDialog"),
onPressed: () {
showDialog(
context: context,
barrierDismissible: true,
builder: (BuildContext context) {
return Center(
child: Text("data"),
);
});
},
)
複製代碼
####而後你會發現顯示出來的Dialog回事這個樣子的 git
####你tm在逗我,這是個什麼鬼,別慌,咱們改一下showDialog(
context: context,
barrierDismissible: true,
builder: (BuildContext context) {
return Scaffold(
body: Center(
child: Text("data"),
),
);
});
複製代碼
####而後就變成了這個樣子 github
####這種東西也不能用啊,咱們繼續看Dialog.dart文件而後發現了熟悉的AlterDialog,而且上面還有demo###AlterDialog類bash
class AlertDialog extends StatelessWidget
複製代碼
###顯示AlterDialog的示例代碼app
/// Future<void> _neverSatisfied() async {
/// return showDialog<void>(
/// context: context,
/// barrierDismissible: false, // user must tap button!
/// builder: (BuildContext context) {
/// return AlertDialog(
/// title: Text('Rewind and remember'),
/// content: SingleChildScrollView(
/// child: ListBody(
/// children: <Widget>[
/// Text('You will never be satisfied.'),
/// Text('You\’re like me. I’m never satisfied.'),
/// ],
/// ),
/// ),
/// actions: <Widget>[
/// FlatButton(
/// child: Text('Regret'),
/// onPressed: () {
/// Navigator.of(context).pop();
/// },
/// ),
/// ],
/// );
/// },
/// );
/// }
複製代碼
####咱們試一下官方示例 less
####1. 先看下AlterDialog構造async
const AlertDialog({
Key key,
this.title,
this.titlePadding,
this.titleTextStyle,
this.content,
this.contentPadding = const EdgeInsets.fromLTRB(24.0, 20.0, 24.0, 24.0),
this.contentTextStyle,
this.actions,
this.backgroundColor,
this.elevation,
this.semanticLabel,
this.shape,
}) : assert(contentPadding != null),
super(key: key);
複製代碼
######咱們看到一些基本屬性定義,而後咱們只關心content,而content是一個widget類ide
/// The (optional) content of the dialog is displayed in the center of the
/// dialog in a lighter font.
///
/// Typically this is a [SingleChildScrollView] that contains the dialog's /// message. As noted in the [AlertDialog] documentation, it's important
/// to use a [SingleChildScrollView] if there's any risk that the content /// will not fit. final Widget content; 複製代碼
######那正好,咱們直接定義widget傳進去就ojbk了 ####2. 咱們定義一個類,好比MyDialog。按照AlterDaialog構造再搞一遍ui
import "package:flutter/material.dart";
class MyDailog extends StatelessWidget {
final Widget content;
final List<Widget> actions;
final Color backgroundColor;
final double elevation;
final String semanticLabel;
final ShapeBorder shape;
const MyDailog({
Key key,
this.content,
this.actions,
this.backgroundColor,
this.elevation,
this.semanticLabel,
this.shape,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return AlertDialog(
content: content,
actions: actions,
backgroundColor: backgroundColor,
elevation: elevation,
shape: shape,
);
}
}
複製代碼
####3.效果和以前顯示的同樣,只是咱們把標題去掉了。咱們作了簡單的封裝,就實現了本身的Dialog。 ####4.咱們看到使用showDialog要寫很長的代碼,若是咱們自定義那豈不是更長,能不能把showDialog簡化一下,ojbk,接着搞!this
import "package:flutter/material.dart";
void showMyDialog({
@required Widget content,
TextStyle contentTextStyle,
List<Widget> actions,
Color backgroundColor,
double elevation,
String semanticLabel,
ShapeBorder shape,
bool barrierDismissible = true,
@required BuildContext context,
}) {
assert(context != null);
assert(content != null);
showDialog<void>(
context: context,
barrierDismissible: barrierDismissible,
builder: (BuildContext context) {
return MyDailog(
content: content,
backgroundColor: backgroundColor,
elevation: elevation,
semanticLabel: semanticLabel,
shape: shape,
actions: actions,
);
},
);
}
class MyDailog extends StatelessWidget {
final Widget content;
此處省略,參照前........
複製代碼
####4.咱們使用一下spa
RaisedButton(
child: Text("showDialog"),
onPressed: () {
showMyDialog(
content: SingleChildScrollView(
child: ListBody(
children: <Widget>[
Text('You will never be satisfied.'),
Text('You\’re like me. I’m never satisfied.'),
],
),
),
actions: <Widget>[
FlatButton(
child: Text('Regret'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
context: context,
);
},
複製代碼
######搞定,和上面的顯示如出一轍。 ##以上就是今天自定義的Dialog的所有內容。順便在這兒推廣一下的個人Dialog庫 ,後續還在添加中。。。。。
ultiple_dialog: ^0.1.5
import 'package:multiple_dialog/multiple_dialog.dart';
複製代碼