FlutterStack详解

Flutter是一款由Google开发的UI工具包,可以创建高性能、高保真度的移动应用程序。当然,Flutter也有自己的社区生态,FlutterStack就是其中之一。本文将从不同的方面对FlutterStack做详细的阐述。

一、点击穿透

点击穿透指的是用户在点击了一个可交互的widget但其下方还有一个位于相同位置并且可交互的widget,此时会出现优先响应下层widget的现象。在Flutter开发中,为了解决这个问题,我们可以使用IgnorePointer或AbsorbPointer widget。IgnorePointer会忽略所有的用户事件,AbsorbPointer会拦截所有的用户事件。

  @override
  Widget build(BuildContext context) {
    return Stack(
      children: [
        // 下方widget
        Positioned(
          top: 0,
          left: 0,
          right: 0,
          bottom: 0,
          child: GestureDetector(
            onTap: () {
              print("click bottom widget");
            },
          ),
        ),
        // 上方widget
        Positioned(
          top: 0,
          left: 0,
          right: 0,
          bottom: 0,
          child: IgnorePointer(
            child: GestureDetector(
              onTap: () {
                print("click top widget");
              },
            ),
          ),
        ),
      ],
    );
  }

二、路由传参

在Flutter中,路由管理是非常重要的,通过路由可以实现页面之间的跳转。在路由的跳转过程中需要传递参数,这时可以使用FlutterStack库中的ArgumentWidget和ArgumentExtractor。ArgumentWidget用来传递参数,ArgumentExtractor用来提取参数。例如:

  class SecondPage extends StatelessWidget with ArgumentWidget {
    final String name;

    SecondPage(this.name);

    @override
    Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(
          title: Text("SecondPage"),
        ),
        body: Center(
          child: RaisedButton(
            onPressed: () {
              Navigator.pop(context, "Hello, $name!");
            },
            child: Text("返回并传递参数"),
          ),
        ),
      );
    }

    @override
    Map argument() {
      return {"name": name};
    }
  }

  class FirstPage extends StatelessWidget {
    @override
    Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(
          title: Text("FirstPage"),
        ),
        body: Center(
          child: RaisedButton(
            onPressed: () async {
              final result = await Navigator.push(context, MaterialPageRoute(builder: (ctx) => SecondPage("FlutterStack")));
              print(result);
              final argument = ArgumentExtractor.extract(result);
              print(argument["name"]);
            },
            child: Text("跳转到SecondPage"),
          ),
        ),
      );
    }
  }

三、网络请求

FlutterStack中提供了一个便捷的网络请求工具类,可以方便的进行网络请求。例如:

  static Future get(String url, {Map params, Map headers}) async {
    var client = new http.Client();
    try {
      var response = await client.get(_buildUrl(url, params), headers: headers);
      return _handleResponse(response);
    } catch (e) {
      return {"code": -1, "msg": e.toString()};
    } finally {
      client.close();
    }
  }

  static Future post(String url, {Map params, Map headers}) async {
    var client = new http.Client();
    try {
      var response = await client.post(url, body: params, headers: headers);
      return _handleResponse(response);
    } catch (e) {
      return {"code": -1, "msg": e.toString()};
    } finally {
      client.close();
    }
  }

使用方法也非常简单:

  void _getData() async {
    final result = await HttpManager.get("https://www.baidu.com");
    print(result);
  }

四、国际化

在开发中,有时需要我们的应用支持多语言,FlutterStack提供了一个简单易用的国际化工具。通过以下步骤,可以在应用中实现多语言:

1. 在pubspec.yaml文件中添加依赖项:

  dependencies:
    flutter_localizations:
      sdk: flutter

2. 在main函数中添加如下代码:

  void main() {
    runApp(
      MaterialApp(
        localizationsDelegates: [
          GlobalMaterialLocalizations.delegate,
          GlobalWidgetsLocalizations.delegate,
          FallbackCupertinoLocalisationsDelegate(),
        ],
        supportedLocales: [const Locale('en', ''), const Locale('zh', '')],
        home: MyApp(),
      ),
    );
  }

3. 在lib目录下创建一个l10n目录,用于存放多语言文件,例如lib/l10n/messages_en.dart和lib/l10n/messages_zh.dart。

4. 在消息文件中添加多语言翻译:

  class Messages {
    static const String appTitle = "FlutterStack";
    static const String welcomeMessage = "Welcome";
    static const String language = "Language";
    static const String english = "English";
    static const String chinese = "中文";

    static String localeMessage(String language) {
      return "你选择了${language}";
    }
  }

5. 在需要使用的widget中使用FlutterStack提供的TranslationWidget,例如:

  class MyApp extends StatelessWidget {
    @override
    Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(
          title: Text(Messages.appTitle),
        ),
        body: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            Text(Messages.welcomeMessage),
            SizedBox(height: 20),
            TranslationWidget(
              builder: (BuildContext context, String value) {
                return Text(value);
              },
              translation: Messages.language,
            ),
            SizedBox(height: 20),
            TranslationWidget(
              builder: (BuildContext context, String value) {
                return Text(value);
              },
              translation: Messages.localeMessage("FlutterStack"),
            ),
          ],
        ),
      );
    }
  }

五、动画效果

Flutter的动画效果非常丰富,通过FlutterStack中提供的AnimatedWidget和AnimationController可以实现各种复杂的动画效果。例如:

  class AnimatedLogo extends AnimatedWidget {
    AnimatedLogo({Key key, Animation animation}) : super(key: key, listenable: animation);

    @override
    Widget build(BuildContext context) {
      final Animation animation = listenable;
      return Center(
        child: Container(
          margin: EdgeInsets.symmetric(vertical: 10),
          height: animation.value,
          width: animation.value,
          child: FlutterLogo(),
        ),
      );
    }
  }

  class LogoApp extends StatefulWidget {
    @override
    _LogoAppState createState() => _LogoAppState();
  }

  class _LogoAppState extends State with TickerProviderStateMixin {
    AnimationController controller;
    Animation animation;

    @override
    void initState() {
      super.initState();
      controller = AnimationController(vsync: this, duration: Duration(seconds: 2));
      animation = Tween(begin: 0.0, end: 200.0).animate(controller);
      controller.forward();
    }

    @override
    Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(
          title: Text("AnimatedLogo"),
        ),
        body: AnimatedLogo(
          animation: animation,
        ),
      );
    }

    @override
    void dispose() {
      controller.dispose();
      super.dispose();
    }
  }

六、总结

本文从多个方面对FlutterStack做了详细的阐述,包括点击穿透、路由传参、网络请求、国际化以及动画效果等。通过对FlutterStack的了解,可以更加方便地进行Flutter开发,提高开发效率。

原创文章,作者:UOGAO,如若转载,请注明出处:https://www.506064.com/n/334274.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
UOGAO的头像UOGAO
上一篇 2025-02-05 13:05
下一篇 2025-02-05 13:05

相关推荐

  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • C语言贪吃蛇详解

    一、数据结构和算法 C语言贪吃蛇主要运用了以下数据结构和算法: 1. 链表 typedef struct body { int x; int y; struct body *nex…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25

发表回复

登录后才能评论