谷歌發佈Flutter Alpha:支持Windows
老孟導讀:Windows來了,Mac、Linux、Web還遠嗎?
本文翻譯自//medium.com/flutter/announcing-flutter-windows-alpha-33982cd0f433
我們的使命是為開發人員提供一個開源,高生產率的框架,以便在任何平台上構建漂亮的本機應用程序。到目前為止,我們已經為Android和iOS提供了正式版本(stable releases),僅Google Play商店就提供了8個穩定版本和100,000多個應用。我們將繼續擴大關注範圍,包括Web,macOS和Linux等其他平台。今天,我們很高興地宣布Flutter的另一個目標,即Flutter對Windows的Alpha版本的支持。
Windows仍然是台式機和筆記本電腦設備的流行選擇,Microsoft報告了超過十億台運行Windows 10的活動設備。我們自己的統計數據顯示,所有Flutter開發人員中有超過一半使用Windows,因此,它自然Flutter是的目標。本地桌面支持為Flutter開闢了許多激動人心的可能性,包括改進的開發人員工具,減少了新用戶的負擔,當然,應用程序可以通過單個代碼庫訪問用戶可能擁有的任何設備。
將Windows添加到Flutter
如我們的架構概述中所述Flutter是一種跨平台的UI工具包,旨在允許在iOS和Android等操作系統之間重複使用代碼,同時還允許應用程序直接與基礎平台服務交互。目的是使開發人員能夠交付在不同平台上感覺自然的高性能應用程序,在存在儘可能多的代碼的同時,擁抱它們存在的差異。Flutter的核心是引擎,它支持所有Flutter應用程序所必需的。每當需要繪製新框架時,引擎負責對合成場景進行柵格化。它提供Flutter核心API的低級實現,包括圖形,文本布局,文件和網絡I / O,可訪問性支持,插件體系結構以及Dart運行時和編譯工具鏈。
我們添加到Flutter的每個新平台都會通過新服務擴展核心框架,使其能夠在該平台上發光。我們從使用Material Design以及基於觸摸的,以移動設備為中心的用戶界面開始在Android和iOS上開始,該界面旨在在兩個移動平台上都達到像素完美。通過Web,Windows,macOS和Linux添加對台式機外形的支持,帶來了一整套全新的服務,其中包括對輸入側的鍵盤,鼠標,鼠標滾輪和控制器的強大支持,以及在這些方面適應甚至工作得最好的小部件。 Web和桌面應用程序隨附的更大的屏幕尺寸。
此外,每個新平台不僅會影響Flutter框架和引擎,還會影響很多其他方面:
- 工具鏈更新:向CLI和IDE工具添加新目標(在本例中為Windows)
- Shell:支持通過
WM_*
消息處理Windows的輸入和通過ANGLE的輸出,使用斯基亞(Skia)以本機速度渲染到底層DirectX表面 - Runner:每個項目都會獲得針對受支持目標的Shell應用程序。對於Windows,這是一個Win32 / C ++程序,可加載Flutter代碼並在運行時執行它。如果需要,可以在此處嚮應用程序添加本機代碼。
- 插件:插件是Dart代碼和該插件支持的每個平台的本機代碼的混合。需要為在Windows上Flutter應用程序中編譯的每個插件添加該本地代碼。
此Alpha版本提供了堅實的基礎,我們將在未來幾個月中穩定該基礎。藉助對Windows 7及更高版本的支持,我們希望這可以為喜歡冒險的開發人員提供一些入門知識。
探索一些示例應用
要查看Flutter對Windows的支持,您可能想嘗試一些我們創建的示例應用程序,這些應用程序在Windows上使用我們新增的支持可以很好地運行。第一個是Flokk應用程序,它是與gskinner.com的設計師和開發人員共同創建的。目的是通過創建創新的,精美的Flutter桌面應用程序來證明Flutter已準備好用於桌面。Flokk是一款可與您的真實Google Contacts數據配合使用並在GitHub和Twitter上顯示聯繫人活動的應用程序。
如果您想在Windows機器上使用Flokk應用程序,則可以在GitHub上下載最新版本。如果您想了解gskinner如何構建此應用程序,請參閱其出色的博客文章:Flokk-我們如何使用Flutter構建桌面應用程序。
此外,Flutter Gallery應用程序(我們用於Flutter的所有事物的展示應用程序)最近已完全重寫,以增加對台式機尺寸的支持。這使我們能夠檢查它是否可以在Web以及Windows,macOS和Linux上正常運行。
庫中的許多研究都展示了在使用Flutter設計自己的Windows應用程序時建議使用的不同應用程序風格的想法。當您找到自己喜歡的東西時,該代碼可在GitHub上找到。
Flutter for Windows入門
根據Windows安裝說明開始安裝Flutter SDK 。要定位Windows桌面,首先需要安裝Desktop docs中描述的工具。默認情況下,Flutter假定您正在構建生產軟件,並且未配置為開發Windows應用程序。但是,可以從命令行輕鬆解決:
$ flutter channel dev
$ flutter upgrade
$ flutter config --enable-windows-desktop
第一條命令將Flutter設置為使用實驗質量的「 dev」通道(而不是默認的「 stable」通道)。這樣,您就可以使用仍在Alpha中的平台支持,例如Windows。第二條命令下拉該通道上的最新位。第三個命令可在您的PC上進行Windows應用開發。
設置好之後,每次使用Android Studio或Visual Studio Code的擴展支持,或者從命令行創建新的Flutter應用程序時,它都會創建一個Windows子文件夾。
如果您感到好奇,請在Windows上運行默認應用程序,如下所示:
最後,一旦創建了應用程序,構建該應用程序將創建一個發佈模式的本機EXE文件以及必要的支持DLL。到那時,如果您想嘗試在任何Windows 10計算機上運行新的Windows應用程序,即使沒有安裝Flutter的計算機,也可以按照以下步驟壓縮必要的文件並運行。
Windows插件
即使我們剛剛發佈Alpha版,Flutter社區也已經在為Windows插件進行開發。這裡有一些:
- url_launcher:從您的應用程序在瀏覽器中啟動URL
- path_provider:在用戶的機器上找到指向特殊方向的路徑,例如Document或temp
- shared_preferences:保持用戶首選項在應用程序會話之間的磁盤上序列化
- biometric_storage:通過生物識別技術加密的存儲
- flutter_audio_desktop:從桌面應用播放音頻
使用這些插件的好處是它們中的大多數還支持其他Flutter平台,這使您可以將應用定位到Android,iOS,Web等以及Windows。此外,雖然pub.dev(Dart和Flutter的軟件包管理器)上約有三分之一的可用軟件包是具有特定於平台的代碼的插件,但大多數不是。例如,許多最高質量和最常用的軟件包是Flutter Favorite程序的一部分,並且大多數都在Windows上運行。如果要查看在Windows上運行的軟件包的完整列表,可以在pub.dev上運行此查詢。
與Windows互操作
如果您想為Windows構建自己的插件,則可以。進入開發人員通道並為計算機啟用Windows後,可以使用以下命令開始:
$ flutter create --template plugin --platforms Windows hello_plugin
屆時,您將能夠在插件項目中將Flutter代碼添加到lib
子文件夾中,並將Windows代碼添加到windows
子文件夾中。您將使用Platform Channels在兩個堆棧之間進行通信,這實際上是Dart和C ++代碼之間傳遞的消息。有關此示例的精心製作,請參見url_launcher實現。
但是,平台通道並不是與Windows互操作的唯一選擇。如果願意,可以使用Dart FFI(外部功能接口)加載庫並調用C樣式的API,例如Win32 API。與使用平台通道的url_launcher不同,path_provider插件是使用FFI實現的,如您在GitHub repo中所見。FFI無需在Dart和C ++之間來回切換,而是允許您編寫代碼以直接導入所需的API。例如,以下是用於調用MessageBox API的代碼:
typedef MessageBoxNative = Int32 Function(
IntPtr hWnd,
Pointer<Utf16> lpText,
Pointer<Utf16> lpCaption,
Int32 uType
);
typedef MessageBoxDart = int Function(
int hWnd,
Pointer<Utf16> lpText,
Pointer<Utf16> lpCaption,
int uType
);
final user32 = DynamicLibrary.open('user32.dll');
final win32MessageBox =
user32.lookupFunction<MessageBoxNative, MessageBoxDart>('MessageBoxW');
void showMessageBox(String message, String caption) =>
win32MessageBox(
0, // No owner window
Utf16.toUtf16(message), // Message
Utf16.toUtf16(caption), // Window title
0 // OK button only
);
...
// call just like any other Dart function
showMessageBox('Test Message', 'Window Caption');
view rawmbox.dart hosted with ❤ by GitHub
此代碼不會產生在平台通道之類的兩個線程之間進行轉換的開銷。FFI包括對許多不同種類的API的支持,包括Win32,WinRT和COM。但是,在運行並包裝整個基於C的Windows API之前,請檢查win32插件,該插件已經可以很好地做到這一點。實際上,path_provider插件本身是使用win32插件實現的。有關win32插件如何開發以及如何工作的詳細信息,請查看博客文章Dart FFI的Windows樂趣。
Windows資源Flutter
無論您在Flutter for Windows之旅中的任何地方,都應確保閱讀flutter.dev上的桌面文檔,其中包括最新詳細信息。另外,您將需要熟悉 Flutter代碼實驗室,以編寫Windows,macOS和Windows桌面目標應用程序,其中包括用於真實場景的代碼,例如使用OAuth進行身份驗證,訪問GitHub API和使用GraphQL。或者,對於在Windows上運行的Flutter桌面代碼的另一個很好的例子,請查看照片搜索示例。
它使用標準的Windows文件打開對話框,樹視圖小部件,拆分器小部件,並將結果與真實世界的REST API集成在一起。
對於其他有用的面向桌面的小部件,我們建議使用菜單欄插件,NavigationRail小部件和DataTable小部件。您可能還對InteractiveViewer小部件感興趣,該小部件具有完整的桌面支持,可通過鼠標手勢來平移和縮放子小部件。
可以探索的另一組有用的小部件是SyncFusion中的那些,它們已經在Windows開發社區中廣為人知。它們提供了廣泛的企業質量小部件,用於創建圖表,儀錶,數據網格等。
這些小部件具有社區和企業許可證,因此您可以找到最適合您的項目的工具。
適用於Windows的Flutter
除了Windows(通常是Flutter桌面)的軟件包和插件外,Flutter開發人員還一直在開發針對Windows的出色應用,例如Invoice Ninja的實驗性構建:
Invoice Ninja是一家依靠Flutter帶來收入的發票公司。他們的目標是今天生產中的Android和iOS,並具有基於Web的演示供您嘗試,但也期待提供桌面版本。
「在過去的Ninja中,我們一直在努力僅支持Web和移動設備,一次只能維護三個單獨的代碼庫。藉助Flutter,以及最近的Flutter Desktop,我們已經能夠使用單個代碼庫為每個主要平台構建應用程序。我們不僅可以從根本上獲得應用程序的免費桌面版本,而且還擁有所有應用程序中最好的性能!」
—Invoice Ninja 聯合創始人Hillel Coren
如果您對實現可在移動和台式機上運行的現實世界中可產生收入的Flutter應用感興趣,則可在GitHub上找到源代碼。
Aartos是另一家製造出色產品的公司,其中包括帶有Flutter編寫的具有多平台客戶端的實時無人機檢測系統。這是在移動客戶端旁邊運行的Windows客戶端的早期版本:
這兩個針對iOS和Windows的版本共享完全相同的代碼庫。
如果您是經驗豐富的Flutter開發人員,並且發現自己在Flutter的不同版本之間進行切換;例如,一個版本用於交付生產型移動應用程序,另一個版本用於測試Windows alpha,那麼您可能會喜歡Flutter版本管理器,該版本管理器現在帶有Windows GUI,您可以下載該版本。
該工具是開源的,因此您可以親自了解Leo如何使其看起來如此出色。
下一步是什麼
現在,我們已經發佈了Alpha版,我們的注意力轉移到完成功能集和穩定產品的發佈上。作為一個開源項目,您可以在GitHub網站上關注我們的beta測試進展,尚需完成的其他工作包括可訪問性,全球化和本地化,增強的鍵盤和文本處理,對命令行參數的支持等等。
除了支持經典的Win32 API外,我們還在試驗基於UWP的Flutter shell版本,該版本使Flutter可以訪問更廣泛的基於Windows的設備,包括Xbox。作為該實驗的一部分,本周我們向Windows應用商店發佈了基於UWP的Flutter Gallery版本。
以下屏幕快照顯示了在Xbox上運行的基於UWP的Flutter Gallery:
這是在Windows 10X模擬器上運行的雙屏Windows設備上運行的同一應用程序:
您可以在GitHub上了解有關Flutter for UWP的進度的更多信息。
摘要
在此版本中,我們將Flutter的功能引入Windows,它具有聲明式,可組合的,反應式的框架,可提高開發人員的工作效率,並具有適應性的Material規範實現,因此您還可以使應用外觀和感覺達到您希望的方式作為Flutter的全套開發和調試工具。完成後,您的應用程序將編譯為本機64位代碼,您可以將其打包並帶到其他Windows計算機上,就像其他任何本機應用程序一樣。最後,您可以使用相同的代碼庫來創建針對Android,iOS,Web,macOS和Linux的應用程序。
如果您想開始使用Flutter構建Windows應用程序,我們希望收到您的反饋!如果您希望利用Windows的專業知識來構建流行插件的Windows實現,或者為Flutter構建一些以Windows為中心的工具(也許是一個CLI,它可以從flutter build windows
命令的輸出中創建MSIX ……),那也歡迎您!
有了Flutter對Windows的新支持,您將要構建什麼?
版權聲明:本文為
`
交流
交流
老孟Flutter博客(330個控件用法+實戰入門系列文章)://laomengit.com
歡迎加入Flutter交流群(微信:laomengit)、關注公眾號【老孟Flutter】: