flutter:教你自定義Dialog

首先信咱們來看一下flutter中有沒有實現Dialog,而後Dialog.dart中發現了下面的方法

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

dialog.jpg
####你tm在逗我,這是個什麼鬼,別慌,咱們改一下

showDialog(
             context: context,
             barrierDismissible: true,
             builder: (BuildContext context) {
                   return Scaffold(
                          body: Center(
                            child: Text("data"),
                          ),
                        );
                      });
複製代碼

####而後就變成了這個樣子 github

Jietu20190701-171215@2x.jpg
####這種東西也不能用啊,咱們繼續看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

j3.jpg

ojbk官方的dialog已經搞定。如今咱們開始自定義一個Dialog

####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庫 ,後續還在添加中。。。。。

github.com/Lans/multip…

簡單使用

ultiple_dialog: ^0.1.5

import 'package:multiple_dialog/multiple_dialog.dart';
複製代碼

歡迎start

若是這個文章對你有用,請點個贊哦

相關文章
相關標籤/搜索