Flutter美观对话框插件aesthetic_dialogs的使用

发布于 1周前 作者 sinazl 来自 Flutter

Flutter美观对话框插件aesthetic_dialogs的使用

AestheticDialogs 是一个受 Laravel Notify 启发的 Flutter 插件,允许你在应用中显示美观的自定义对话框。尽管目前仅支持 Android 平台,但其提供的多种风格和动画效果使其成为一个非常吸引人的选择。

安装

依赖配置

首先,在你的 pubspec.yaml 文件中添加 AestheticDialogs 的依赖:

dependencies:
  flutter:
    sdk: flutter
  aesthetic_dialogs: ^0.0.15  # 确保版本号为最新

然后运行 flutter pub get 来安装依赖。

配置项目

确保你的项目使用 AppCompat 主题,并按照以下步骤进行配置:

  1. 下载 colors.xml 文件并将其粘贴到项目的 /android/app/src/main/res/values/ 目录下。
  2. 下载 styles.xml 文件并替换项目的 /android/app/src/main/res/values/ 目录下的同名文件。

build.gradle 中确保 Kotlin 版本至少为 1.3.40,并且添加对 AppCompat 的依赖:

dependencies {
    ...
    implementation 'androidx.appcompat:appcompat:1.2.0'
}

如何使用?

基础示例

下面是一个简单的示例,展示了如何调用 AestheticDialogs 显示一个对话框:

import 'package:aesthetic_dialogs/aesthetic_dialogs.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {

  Future<void> buildDialog() async {
    AestheticDialogs.showDialog(
        title: "My Dialog",
        message: "Hello!!!",
        cancelable: true,
        darkMode: false,
        dialogAnimation: DialogAnimation.IN_OUT,
        dialogGravity: DialogGravity.CENTER,
        dialogStyle: DialogStyle.FLASH,
        dialogType: DialogType.SUCCESS,
        duration: 3000);
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Scaffold(
        appBar: AppBar(
          title: const Text('AestheticDialogs Flutter'),
        ),
        body: Center(
          child: ElevatedButton(
            onPressed: buildDialog,
            child: Text("Open Dialog"),
          ),
        ),
      ),
    );
  }
}

对话框类型与样式

AestheticDialogs 提供了多种对话框样式和类型,包括 FLASH、CONNECTIFY、TOASTER 等。你还可以选择不同的动画效果和主题(如暗黑模式)来定制你的对话框。

示例:展示不同类型的对话框

Future<void> showDifferentDialogs() async {
  AestheticDialogs.showDialog(
      title: "Success Dialog",
      message: "Operation completed successfully!",
      cancelable: true,
      darkMode: false,
      dialogAnimation: DialogAnimation.SPIN,
      dialogGravity: DialogGravity.BOTTOM,
      dialogStyle: DialogStyle.EMOJI,
      dialogType: DialogType.SUCCESS,
      duration: 3000);

  await Future.delayed(Duration(seconds: 4)); // 等待前一个对话框关闭

  AestheticDialogs.showDialog(
      title: "Error Dialog",
      message: "An error occurred!",
      cancelable: true,
      darkMode: true,
      dialogAnimation: DialogAnimation.ZOOM,
      dialogGravity: DialogGravity.TOP,
      dialogStyle: DialogStyle.RAINBOW,
      dialogType: DialogType.ERROR,
      duration: 3000);
}

更多关于Flutter美观对话框插件aesthetic_dialogs的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter美观对话框插件aesthetic_dialogs的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter项目中使用aesthetic_dialogs插件来创建美观对话框的代码示例。aesthetic_dialogs是一个流行的Flutter插件,它提供了一系列美观且易于使用的对话框组件。

首先,确保你已经在pubspec.yaml文件中添加了aesthetic_dialogs依赖:

dependencies:
  flutter:
    sdk: flutter
  aesthetic_dialogs: ^x.y.z  # 请替换为最新版本号

然后,运行flutter pub get来安装依赖。

接下来是一个完整的代码示例,展示如何使用aesthetic_dialogs创建几种不同类型的对话框:

import 'package:flutter/material.dart';
import 'package:aesthetic_dialogs/aesthetic_dialogs.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Aesthetic Dialogs Example',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {

  void showAlertDialog() {
    AestheticDialog.alert(
      context: context,
      title: 'Alert Dialog',
      description: 'This is an alert dialog.',
      positiveActionText: 'OK',
      onPositiveAction: () {
        // Handle positive action
      },
    );
  }

  void showConfirmDialog() {
    AestheticDialog.confirm(
      context: context,
      title: 'Confirm Dialog',
      description: 'Are you sure you want to proceed?',
      positiveActionText: 'Yes',
      negativeActionText: 'No',
      onPositiveAction: () {
        // Handle positive action
      },
      onNegativeAction: () {
        // Handle negative action
      },
    );
  }

  void showLoadingDialog() {
    final dialog = AestheticDialog.loading(
      context: context,
      title: 'Loading...',
    );

    // Simulate a loading process with Future.delayed
    Future.delayed(Duration(seconds: 3), () {
      dialog.dismiss();
    });
  }

  void showCustomDialog() {
    AestheticDialog.custom(
      context: context,
      title: 'Custom Dialog',
      builder: (BuildContext context) {
        return Container(
          height: 200,
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
              Text('This is a custom dialog content.'),
              SizedBox(height: 20),
              ElevatedButton(
                onPressed: () {
                  AestheticDialog.of(context).dismiss();
                },
                child: Text('Close'),
              ),
            ],
          ),
        );
      },
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Aesthetic Dialogs Example'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            ElevatedButton(
              onPressed: showAlertDialog,
              child: Text('Show Alert Dialog'),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: showConfirmDialog,
              child: Text('Show Confirm Dialog'),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: showLoadingDialog,
              child: Text('Show Loading Dialog'),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: showCustomDialog,
              child: Text('Show Custom Dialog'),
            ),
          ],
        ),
      ),
    );
  }
}

在这个示例中,我们展示了如何使用AestheticDialog的几种主要方法:

  1. AestheticDialog.alert:显示一个简单的警告对话框。
  2. AestheticDialog.confirm:显示一个确认对话框,包含正面和负面操作按钮。
  3. AestheticDialog.loading:显示一个加载对话框,模拟了一个加载过程。
  4. AestheticDialog.custom:显示一个自定义对话框,允许你提供自己的对话框内容。

你可以根据项目的需求对这些对话框进行进一步的自定义和扩展。

回到顶部