Flutter UI增强与适配插件suitup的使用方法

Flutter UI增强与适配插件suitup的使用方法详解

示例代码

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:get_it/get_it.dart';
import 'package:suitup/suitup.dart';

const Color darkBlue = Color.fromARGB(255, 18, 32, 47);

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

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      theme: ThemeData.dark().copyWith(
        scaffoldBackgroundColor: darkBlue,
      ),
      debugShowCheckedModeBanner: false,
      home: const Scaffold(
        body: Center(
          child: SuitupObsExample(),
        ),
      ),
    );
  }
}

class SuitupObsExample extends StatefulWidget {
  const SuitupObsExample({super.key});

  @override
  State<SuitupObsExample> createState() => _SuitupObsExampleState();
}

class _SuitupObsExampleState extends State<SuitupObsExample> {
  final myName = SuitupNotifier<String?>(null);

  @override
  void initState() {
    super.initState();

    // 渲染 `loading` 状态
    Future.delayed(const Duration(seconds: 3), () => myName.setLoading());

    // 渲染 `data` 状态
    Future.delayed(const Duration(seconds: 6), () => myName.value = 'Marco Braghim');

    // 渲染 `error` 状态
    Future.delayed(const Duration(seconds: 9), () => myName.setError('The moon is not cool today'));
  }

  @override
  Widget build(BuildContext context) {
    return SuitupNotifierBuilder(
      observable: myName,
      init: (data) => const Text('Initializing...'),
      onLoading: const CupertinoActivityIndicator(),
      onData: (value) => Text('My name is: $value'),
      onError: (reason) => Text('Something went wrong: $reason'),
    );
  }
}

// 控制器
class SuitupObsExampleController extends SuitupController {
  final myName = ValueNotifier<String?>(null);

  /// 自动调用 `initState`
  @override
  Future<void> initialize() async {
    super.initialize();

    // 设置加载状态
    setStatus(SuitupStatus.loading);

    Future.delayed(const Duration(seconds: 3), () {
      myName.value = 'Marco Braghim';
      setStatus(SuitupStatus.finished);
    });
  }

  /// 自动调用 `dispose`
  @override
  dispose() {
    super.dispose();

    myName.dispose();
  }
}

// 使用 `SuitupState`
class SuitupObsExamplePage extends StatefulWidget {
  const SuitupObsExamplePage({super.key});

  @override
  State<SuitupObsExamplePage> createState() => _SuitupObsExamplePageState();
}

class _SuitupObsExamplePageState extends SuitupState<SuitupObsExampleController, SuitupObsExamplePage> {
  // 使用 `controller` 访问 `SuitupObsExampleController` 实例

  @override
  Widget build(BuildContext context) {
    return SuitupObserver(
      observables: [
        controller.myName,
        controller.status,
      ],
      builder: (context) {
        if (controller.status.value.isLoading) {
          return const CupertinoActivityIndicator();
        }

        return Text(controller.myName.value!);
      },
    );
  }
}

代码解释

  1. 引入依赖

    import 'package:get_it/get_it.dart';
    import 'package:suitup/suitup.dart';
    
  2. 初始化应用

    void main() {
      runApp(const MyApp());
    }
    
  3. 应用主题

    class MyApp extends StatelessWidget {
      const MyApp({super.key});
    
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          theme: ThemeData.dark().copyWith(
            scaffoldBackgroundColor: darkBlue,
          ),
          debugShowCheckedModeBanner: false,
          home: const Scaffold(
            body: Center(
              child: SuitupObsExample(),
            ),
          ),
        );
      }
    }
    
  4. 使用 SuitupNotifierSuitupNotifierBuilder

    class SuitupObsExample extends StatefulWidget {
      const SuitupObsExample({super.key});
    
      @override
      State<SuitupObsExample> createState() => _SuitupObsExampleState();
    }
    
    class _SuitupObsExampleState extends State<SuitupObsExample> {
      final myName = SuitupNotifier<String?>(null);
    
      @override
      void initState() {
        super.initState();
    
        Future.delayed(const Duration(seconds: 3), () => myName.setLoading());
        Future.delayed(const Duration(seconds: 6), () => myName.value = 'Marco Braghim');
        Future.delayed(const Duration(seconds: 9), () => myName.setError('The moon is not cool today'));
      }
    
      @override
      Widget build(BuildContext context) {
        return SuitupNotifierBuilder(
          observable: myName,
          init: (data) => const Text('Initializing...'),
          onLoading: const CupertinoActivityIndicator(),
          onData: (value) => Text('My name is: $value'),
          onError: (reason) => Text('Something went wrong: $reason'),
        );
      }
    }
    
  5. 使用 SuitupController

    class SuitupObsExampleController extends SuitupController {
      final myName = ValueNotifier<String?>(null);
    
      @override
      Future<void> initialize() async {
        super.initialize();
    
        setStatus(SuitupStatus.loading);
    
        Future.delayed(const Duration(seconds: 3), () {
          myName.value = 'Marco Braghim';
          setStatus(SuitupStatus.finished);
        });
      }
    
      @override
      dispose() {
        super.dispose();
    
        myName.dispose();
      }
    }
    
  6. 使用 SuitupState

    class SuitupObsExamplePage extends StatefulWidget {
      const SuitupObsExamplePage({super.key});
    
      @override
      State<SuitupObsExamplePage> createState() => _SuitupObsExamplePageState();
    }
    
    class _SuitupObsExamplePageState extends SuitupState<SuitupObsExampleController, SuitupObsExamplePage> {
      @override
      Widget build(BuildContext context) {
        return SuitupObserver(
          observables: [
            controller.myName,
            controller.status,
          ],
          builder: (context) {
            if (controller.status.value.isLoading) {
              return const CupertinoActivityIndicator();
            }
    
            return Text(controller.myName.value!);
          },
        );
      }
    }

更多关于Flutter UI增强与适配插件suitup的使用方法的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter UI增强与适配插件suitup的使用方法的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


假设 suitup 是一个用于增强和适配 Flutter UI 的插件,以下是如何使用它的假设性描述。请注意,由于 suitup 是一个假设的插件,以下内容是基于其名称和功能的合理推测。

1. 安装 suitup 插件

首先,你需要在 pubspec.yaml 文件中添加 suitup 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  suitup: ^1.0.0  # 假设版本号为 1.0.0

然后运行 flutter pub get 来安装插件。

2. 导入 suitup 插件

在你的 Dart 文件中导入 suitup 插件:

import 'package:suitup/suitup.dart';

3. 使用 suitup 插件进行 UI 增强与适配

假设 suitup 插件提供了一些工具和组件,用于简化 Flutter UI 的创建和适配。以下是一些假设的功能和使用示例:

3.1 响应式布局

suitup 可能提供了一些工具来帮助你创建响应式布局,以适应不同屏幕尺寸。

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

class ResponsiveLayoutExample extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Responsive Layout'),
      ),
      body: SuitupResponsiveBuilder(
        builder: (context, screenSize) {
          if (screenSize == ScreenSize.small) {
            return Center(child: Text('Small Screen'));
          } else if (screenSize == ScreenSize.medium) {
            return Center(child: Text('Medium Screen'));
          } else {
            return Center(child: Text('Large Screen'));
          }
        },
      ),
    );
  }
}

3.2 主题适配

suitup 可能提供了一些工具来帮助你根据用户偏好或系统设置动态切换主题。

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

class ThemeAdapterExample extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return SuitupThemeAdapter(
      lightTheme: ThemeData.light(),
      darkTheme: ThemeData.dark(),
      child: Scaffold(
        appBar: AppBar(
          title: Text('Theme Adapter'),
        ),
        body: Center(
          child: Text('Dynamic Theme Example'),
        ),
      ),
    );
  }
}

3.3 UI 组件增强

suitup 可能还提供了一些增强版的 Flutter UI 组件,例如更强大的按钮、卡片等。

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

class EnhancedUIExample extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Enhanced UI'),
      ),
      body: Center(
        child: SuitupEnhancedButton(
          onPressed: () {
            print('Enhanced Button Pressed');
          },
          child: Text('Click Me'),
        ),
      ),
    );
  }
}
回到顶部