鴻蒙應用開發之運行HelloWorld
https://harmonyos.51cto.com/#zz
最近我可以說是同步也在進行Flutter應用開發的學習。
與鴻蒙的開發相比,Flutter的環境搭建和IDE使用就相對麻煩一些。
當然,這里面有客觀原因,比如說網絡問題。
但是,如果我們不考慮這些客觀原因,Flutter的環境搭建也依然是很麻煩,并且繼承了Google一貫的不靠譜以及把事情復雜化的作風(是不是因為美國寫代碼的印度人越來越多了?)。
可以參考我的文章
Flutter應用開發之第一步(踩坑記)
DevEco Studio開發環境配置非常簡單,可以參考他們的官方網站
HarmonyOS配置開發環境developer.harmonyos.com
值得一提的是,在這篇文檔里,有專門設置gradle代理的部分:
設置Gradle代理 如果網絡不能直接訪問Internet,而是需要通過代理服務器才可以訪問,這種情況下,需要設置Gradle代理,來訪問和下載Gradle所需的依賴。否則,請跳過本章節。
打開“此電腦”,在文件夾地址欄中輸入%userprofile%,進入個人數據界面。

創建一個文件夾,命名為.gradle.。如果已有.gradle文件夾,請跳過此操作。
進入.gradle文件夾,新建一個文本文檔,命名為gradle,并修改后綴為.properties。
打開Gradle.properties文件中,添加如下腳本,然后保存。其中代理服務器、端口、用戶名、密碼和不使用代理的域名,請根據實際代理情況進行修改。其中不使用代理的 “nonProxyHosts”的配置間隔符是 “|”。
- systemProp.http.proxyHost=proxy.server.com
- systemProp.http.proxyPort=8080
- systemProp.http.nonProxyHosts=*.company.com|10.*|100.*
- systemProp.http.proxyUser=userId
- systemProp.http.proxyPassword=password
- systemProp.https.proxyHost=proxy.server.com
- systemProp.https.proxyPort=8080
- systemProp.https.nonProxyHosts=*.company.com|10.*|100.*
- systemProp.https.proxyUser=userId
- systemProp.https.proxyPassword=password
這點讓我非常開心,雖然對我來說并沒什么用,不過可以看出華為的開發畢竟還是自己人,了解咱們的痛點。
DevEco Studio開發環境配置完成后,可以通過運行HelloWorld工程來驗證環境設置是否正確。
以Wearable工程為例,在Wearable遠程模擬器中運行該工程。
打開DevEco Studio,在歡迎頁點擊Create HarmonyOS Project,創建一個新工程。
選擇設備類型和模板,以Wearable為例,選擇Empty Feature Ability(Java),點擊Next。

3. 填寫項目相關信息,保持默認值即可,點擊Finish。
4. 工程創建完成后,DevEco Studio會自動進行工程的同步,同步成功如下圖所示。首次創建工程時,會自動下載Gradle工具(Gradle下載失敗如何解決?),時間較長,請耐心等待。

5. 在DevEco Studio菜單欄,點擊Tools > HVD Manager。首次使用模擬器,需下載模擬器相關資源,請點擊OK,等待資源下載完成后,點擊模擬器界面左下角的Refresh按鈕。(查看使用遠程模擬器的常見問題)

在瀏覽器中彈出華為帳號登錄界面,請輸入已實名認證的華為帳號的用戶名和密碼進行登錄。 說明 推薦使用Chrome瀏覽器,如果使用Safari、360等其他瀏覽器,要取消阻止跨站跟蹤和阻止所有Cookie功能。
7. 登錄后,請點擊界面的允許按鈕進行授權。

在設備列表中,選擇Wearable設備,并點擊
按鈕,運行模擬器。

點擊DevEco Studio工具欄中的
按鈕運行工程,或使用默認快捷鍵Shift+F10運行工程。
在彈出的Select Deployment Target界面選擇Connected Devices,點擊OK按鈕。
DevEco Studio會啟動應用的編譯構建,完成后應用即可運行在Remote Device上。
其中的UI部分用的是JS,這正是我擅長的,將index.js中的world改成James之后,模擬器中立刻進行了熱更新。
https://harmonyos.51cto.com/#zz