· Joseph · AI & Machine Learning  · 4 min read

[Day 17] BMAD-Method - Accounting App Flutter - 1

今天開始的系列要來寫一個記帳APP,先前有安裝好Xcode,這次來玩Flutter。為什麼選Flutter不選ReactNative呢?因為考量Flutter比起ReactNative對Android/iPhone的更靠近原生一些,再者Google發展的,他也會對一些Google的展品線有比較好的支援度。相比之下對於Meta生態系的ReactNative太多玩具可以玩,所以這次用Vibe coding來玩一下Flutter,再把一切記錄下來。

今天開始的系列要來寫一個記帳APP,先前有安裝好Xcode,這次來玩Flutter。為什麼選Flutter不選ReactNative呢?因為考量Flutter比起ReactNative對Android/iPhone的更靠近原生一些,再者Google發展的,他也會對一些Google的展品線有比較好的支援度。相比之下對於Meta生態系的ReactNative太多玩具可以玩,所以這次用Vibe coding來玩一下Flutter,再把一切記錄下來。

TOC

安裝Flutter

ref: https://docs.flutter.dev/install/manual

我不是用VS code,所以不走VS code安裝那一套,這邊是用手動安裝。因為我是Macbook M3,這邊就直接選擇Apple Silicon (ARM64) 這個zip檔案下載、解壓縮。我習慣把專案放在~/development底下,這邊就跑官網建議的指令:

$ unzip ~/Downloads/flutter_macos_3.29.3-stable.zip -d ~/development/

然後剛好我也是用zsh環境,就直接在~/.zprofile加上PATH

export PATH="$HOME/development/flutter/bin:$PATH"

就這樣重開terminal以後,輸入指令,就可以看到flutter / Dart 版本了。

flutter-dart

安裝Android

ref: https://docs.flutter.dev/platform-integration/android/setup

為了跑起Android Emulator或者在實體Android裝置上執行APP,我們要先安裝Android Studio,只要下載Android Studio就好。

但接下來要安裝Android SDK跟tools,這邊就會跑比較久,也比較麻煩。 SDK-manager 打開Android Studio的起始畫面,旁邊有三個點點,點下去可以打開SDK Manager,然後去Languages & Frameworks -> Android SDK 找到對應的工具安裝:

  • SDK Platform
    • 找最新的API Level安裝,我安裝的是Android 16.0(Baklava) API Level 36.1,
  • SDK Tools
    • Android SDK Build-Tools
    • Android SDK Command-line Tools
    • Android Emulator
    • Android SDK Platform-Tools

一個一個Apply套用並安裝,可能要跑一陣子,安裝好以後要跑個docker,我們要accept licenses

$ flutter doctor --android-licenses

都Accept以後就完成這步驟了。

SDK-manager 接下來我們再回來這個畫面,這次選Virtual Device Manager,我開了一個Medium Phone,選Google APIs ARM 64 v8a System Image,最後在Additional settings裡的Emulated Performance選擇Hardware硬體加速。

這樣子模擬器就建立完成了。再跑一次 doctor看有Android的部分有沒有問題

$ flutter doctor

[✓] Android toolchain - develop for Android devices (Android SDK version 36.1.0)
[✓] Android Studio (version 2025.1)

這樣就好了,執行 flutter emulators && flutter devices 應該可以跑起Android模擬器。

安裝Xcode

ref: https://docs.flutter.dev/platform-integration/ios/setup

接下來安裝Xcode,但我們Day-5Day-6有跑過iOS案子,所以這邊不用特別安裝,不然也只是按照指令安裝而已。 不過這邊最後提到 Install CocoaPods 的步驟,我是用 asdf 跑Version Manager,所以裝ruby跟cocoapod是透過下面指令

$ asdf plugin add ruby
$ asdf install ruby latest
$ asdf global ruby 3.4.6
$ gem install cocoapod

都要等一下,跑完以後就差不多了。執行 open -a Simulator 有看到模擬器就成功了。 最後來看一下doctor!

flutter-doctor

Conclusion

大功告成,今天只是安裝,沒有什麼太難的內容,就是要等、要下載而已。明天就來讓BMad-method開跑新的案子吧。 今天到這邊就結束囉,喜歡我文章的再幫忙推廣一下喔!

Back to Blog

Related Posts

View All Posts »
[Day 15] BMAD-Method - Party mode

[Day 15] BMAD-Method - Party mode

昨天講到orchestrator,他有個重要的指令我沒特別說,今天就來好好玩玩這個Party mode。 orchestrator發起的party就是叫大家來開會的意思,我們把議題丟出來,orchestrator會找需要的人去提意見。 一起來看看怎麼玩。

[Day 14] BMAD-Method - Orchestrator

[Day 14] BMAD-Method - Orchestrator

另外一個meta agent: Orchestrator 指揮家,他不像昨天的Master什麼都會做,但他什麼都會叫人家做。 從opencode問他 summary what you can do 他也很坦率地回答我: As the BMad Orchestrator, I am your central hub for managing and coordinating a team of specialized AI agents and structured workflows. 好的老闆。

[Day 13] BMAD-Method - Master

[Day 13] BMAD-Method - Master

燒了好幾天專案的腦袋,今天明天讓腦子冷靜一下,我們來介紹兩個比較特殊、更高層次、負責管理或協調角色的 Agent:meta agent 先來認識一下他們的差異 (from Gemini) | 類型 | 職責 | 例子 | | ---------- | ----------------------------------------------------------------------- | ----------------------------------------- | | 專門 Agent | 在單一領域擁有深厚的專業知識和技能,負責具體的執行工作。 | dev(寫代碼)、qa(做測試)、pm(寫 PRD) | | Meta Agent | 負責管理、協調其他 Agent 或具備跨領域的通用能力,專注於流程和宏觀控制。 | bmad-orchestrator, bmad-master | TOC Master Agent Master Agent是一個什麼都會的角色,他全面且通用,精通所有專門Agent會執行的任務,如果不知道要做什麼,找他就對了。 這樣講有點玄,來看看他到底有什麼用途: BMad-Method的所有事他都懂 Task: 他知道所有的任務(create-story, document-project) Template: 他了解跟熟悉所有樣板(prd, architecture) Checklist: 他也會所有的檢查清單(story-checklist, architect-checklist) 可以請他做任何事 因為他上面的都懂,所以你請他建立需求文件,他就會幫你create-doc, 產生prd 找他就對了 你可以想像他是一個搞過技術、寫過測試、管過專案、建過架構、還畫過設計的人。 也就因為他會BMad-Method的所有東西,所以他有一個KB (Knowledge Base)開關,當我們輸入 KB 把它打開時,他會替我們解答所有BMad-Method的問題。 master 看看Gemini給的總結: BMad Master Agent 是 BMAD-METHOD 的大腦和指揮中心。它的設計目標是自動化和簡化軟體開發流程,將複雜的、多步驟的工作流(Workflows)轉化為您可以通過簡單命令來驅動的自動化任務。它通過協調一系列專業化的資源,確保了開發過程的一致性、標準化和高效率。 Knowledge Base (KB 知識庫) 相信我,打開bmad-master.md看了半天還是看不懂他的 KB 到底是什麼,要來去bmad-core/data/bmad-kb.md才找得到。他像是一本操作手冊,裡面記錄了大大小小BMad-Method的所有事。先請Gemini給個總結: 就是所、有、事。Master懂這些,把BMad-Method的這些倒背如流,才能以一擋百。 想看project的可以來這邊:https://github.com/josephMG/bmad-method-projects Conclusion 先介紹一個meta agent Master Agent,一個對於BMad-Method什麼都懂的人,不像我之前要換來換去,下次可以來試試靠他一人搞定全部(! 今天到這邊就結束囉,喜歡我文章的再幫忙推廣一下喔!