介紹
data:image/s3,"s3://crabby-images/152c8/152c8a6b438fa56c6c3182c222a1d8cb303b85f8" alt="快讓Flutter應用跑PC上"
今天介紹一個能讓Flutter應用執行在Mac OS和Windows上的平臺:Feather Platform
官網地址:feather-apps.com/
官網的介紹如下:
The Feather platform will run Flutter apps on MacOS and Windows. So you can write a single app that runs on all major desktop and mobile devices.
基本可以說寫一次flutter app,可以在全平臺執行了。
那具體要怎麼操作呢?
實踐
1.在官網首頁點選按鈕 Build an App Now,會下載程式安裝包。
data:image/s3,"s3://crabby-images/d6ad6/d6ad63890b73936209486c0bfeb88947137d00b7" alt="快讓Flutter應用跑PC上"
2.下載之後開啟安裝應用,就進入瞭如下的應用介面。
data:image/s3,"s3://crabby-images/61413/614131192390ebb7212ca017fd90fd6c7914692c" alt="快讓Flutter應用跑PC上"
3.用谷歌賬號登入(需要科學上網)。
data:image/s3,"s3://crabby-images/ef27a/ef27a138948b8c9682f3d10b56efe73141f04c24" alt="快讓Flutter應用跑PC上"
4.點選右下角“新增”按鈕。
data:image/s3,"s3://crabby-images/182ea/182ea63a0050ded779380a5128f555fc226ed216" alt="快讓Flutter應用跑PC上"
5.點選"BROWSE"選擇一個已經開發完成的Flutter專案。
這裡我們用MusesWeather專案做實驗。
6.增加程式碼
data:image/s3,"s3://crabby-images/6848e/6848e913ab305e2c80620c7e2c7d75ab82420707" alt="快讓Flutter應用跑PC上"
按照提示需要增加兩處程式碼,在專案的main.dart檔案新增import 'package:flutter/foundation.dart';
,
在main方法裡新增debugDefaultTargetPlatformOverride = TargetPlatform.iOS;
。
7.新增App Name並點選Continue
data:image/s3,"s3://crabby-images/c3901/c39017050b0d40d32f1670a0f20be97fcb273531" alt="快讓Flutter應用跑PC上"
這樣就得到了一個新增好了的App專案,點選進去會看到
data:image/s3,"s3://crabby-images/4e670/4e670d3f7ce5a513d05c58fa9a2d7b40036eb62f" alt="快讓Flutter應用跑PC上"
點選TEST就會提示你開啟Xcode,然後在Xcode裡面run 工程。
data:image/s3,"s3://crabby-images/74a11/74a11a089a36ca69704e185c3b8d396dd514fb24" alt="快讓Flutter應用跑PC上"
產品
最後我們就成功將寫好的Flutter 專案執行在了Mac OS上,感興趣的同學可以立馬嘗試下。
data:image/s3,"s3://crabby-images/f50bd/f50bd6579c54837a9e89407d4af08df689ab0ef3" alt="快讓Flutter應用跑PC上"
解釋
How is this different to the flutter-desktop-embedding project?
Feather is actually based on the flutter-desktop-embedding project. Currently for Mac it offers the same features plus:
(a) More functionality like copy and paste, mouse wheel and escape key
(b) More supported plugins like shared_preferences, url_launcher, google_sign_in
(c) An easy way to publish your app and push updates to end users
其實Feather Platform就是在Google開源專案flutter-desktop-embedding的基礎上開發的,並提供了更多的特性:
- 鍵盤和滑鼠等輸入裝置
- 支援更多外掛如持久化,google登入等
- 可以釋出app到Feather商店並且更新。