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/zh-hant/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

發表回復

登錄後才能評論