Flutter支持穩(wěn)定的桌面設備開發(fā)已經(jīng)一段時間了,不得不說,F(xiàn)lutter多平臺支持的特性真的很香。我本人并沒有任何桌面開發(fā)的經(jīng)驗,但仍然使用Flutter開發(fā)出了一個桌面版小程序,功能很簡單,就是對輸入的json做格式化處理和轉(zhuǎn)模型。
網(wǎng)站設計制作、成都網(wǎng)站建設介紹好的網(wǎng)站是理念、設計和技術的結(jié)合。創(chuàng)新互聯(lián)公司擁有的網(wǎng)站設計理念、多方位的設計風格、經(jīng)驗豐富的設計團隊。提供PC端+手機端網(wǎng)站建設,用營銷思維進行網(wǎng)站設計、采用先進技術開源代碼、注重用戶體驗與SEO基礎,將技術與創(chuàng)意整合到網(wǎng)站之中,以契合客戶的方式做到創(chuàng)意性的視覺化效果。
話不多說,先來看看實際效果。 項目源碼地址
開發(fā)環(huán)境如下:
Flutter : 2.8.1
Dart : 2.15.1
IDE : VSCode
JSON作為我們?nèi)粘i_發(fā)工作中經(jīng)常要打交道的一種數(shù)據(jù)格式,它共有6種數(shù)據(jù)類型: null , num , string , object , array , bool 。我們勢必對它又愛又恨。愛他因為他作為數(shù)據(jù)處理的一種格式確實非常方便簡潔。但是在我們做Flutter開發(fā)中,又需要接觸到json解析時,就會感覺非常棘手,因為flutter沒有反射,導致json轉(zhuǎn)模型這塊需要手寫那繁雜的映射關系。就像下面這樣子。
數(shù)據(jù)量少還能接受,一旦量大,那么光手寫這個解析方法都能讓你懷疑人生。更何況手寫還有出錯的可能。好在官方有個工具**json_serializable**可以自動生成這塊轉(zhuǎn)換代碼,也解決了flutter界json轉(zhuǎn)模型的空缺。當然,業(yè)界也有專門解析json的網(wǎng)站,可以自動生成dart代碼,使用者在生成后復制進項目中即可,也是非常方便的。
本項目以json解析為切入點,和大家一起來看下flutter是如何開發(fā)桌面應用的。
要讓我們的flutter項目支持桌面設備。我們首先需要修改下flutter的設置。如下,讓我們的項目支持 windows 和 macos 系統(tǒng)。
接下來使用 flutter create 命令創(chuàng)建我們的模版工程。
創(chuàng)建完項目后,我們就可以 run 起來了。
先來看下整體界面,界面四塊,分別為功能模塊、文件選擇模塊、輸入模塊、輸出模塊。
我們在新建一個桌面應用時,默認的模版又一個Appbar,此時應用可以用鼠標拖拽移動,放大縮小,還可以縮到很小。但是,我們一旦去掉這個導航欄,那么窗口就不能用鼠標拖動了,并且我們往往不希望用戶將我們的窗口縮放的很小,這會導致頁面異常,一些重要信息都展示不全。因此這里需要借助第三方組件 bitsdojo_window 。通過 bitsdojo_window ,我們可以實現(xiàn)窗口的定制化,拖動,最小尺寸,最大尺寸,窗口邊框,窗口頂部放大、縮小、關閉的按鈕等。
通過 InkWell 組件,可以捕捉到手勢、鼠標、觸控筆的移動和停留位置
這個功能是鼠標移動后的UI交互界面。要在窗口上顯示一個提示框,可以使用 Overlay 。需要注意的是,由于在 Overlay 上的 text 的根結(jié)點不是 Material 風格的組件,因此會出現(xiàn)黃色的下劃線。因此一定要用 Material 包一下 text 。并且你必須給創(chuàng)建的 OverlayEntry 一個位置,否則它將全屏顯示。
讀取說表拖拽的文件一開始想嘗試使用 InkWell 組件,但是這個組件無法識別拖拽中的鼠標,并且也無法從中拿到文件信息。因此放棄。后來從文章《Flutter-2天寫個桌面端APP》中發(fā)現(xiàn)一個可讀取拖拽文件的組件 desktop_drop ,能滿足要求。
使用開源組件 file_picker ,選完圖片后的操作和拖拽選擇圖片后的操作一致。
Textfield 如果要顯示富文本,那么需要自定義 TextEditingController 。并重寫 buildTextSpan 方法。
在做導出功能時遇到下列報錯,保存提示為沒有權(quán)限訪問對應目錄下的文件。
通過Apple的開發(fā)文檔找到有關權(quán)限問題的說明。其中有個授權(quán)私鑰的key為 com.apple.security.files.downloads.read-write ,表示 對用戶的下載文件夾的讀/寫訪問權(quán)限 。那么,使用Xcode打開Flutter項目中的mac應用,修改工程目錄下的 DebugProfile.entitlements 文件,向 entitlements 文件中添加 com.apple.security.files.downloads.read-write ,并將值設置為YES,保存后重啟Flutter項目。發(fā)現(xiàn)已經(jīng)可以向下載目錄中讀寫文件了。
當然,這是正常操作。還有個騷操作就是關閉系統(tǒng)的沙盒機制。將 entitlements 文件的 App Sandbox 設置為NO。這樣我們就可以訪問任意路徑了。當然關閉應用的沙盒也就相當于關閉了應用的防護機制,因此這個選項慎用。
原文地址:
emotional flutter
感情的浮動
笑顏(えがお)殘(のこ)る 帰(かえ)り道(みち)に
いつかなくした 聲(こえ)探(さが)してる
歸途中,殘留著你的笑容
尋找著,曾幾何時的聲音
記憶(きおく)の暗(やみ)が刻(きざ)む時(とき)
今(いま)も終(お)わらなくて
烙印在黑暗中的記憶
那一刻始終無法沒滅
空(そら)の中(なか)舞(ま)い降(お)りる
白(しろ)い羽(はね) 揺(ゆ)らして
舞動潔白的雙翼
從空中飄舞而降
手(て)を伸(の)ばし 駆(か)け抜(ぬ)け
あなたの影(かげ) 追(お)いかけていく
出雙手,奔向前方
追尋著你熟悉的身影
白(しろ)い雪(ゆき)が降(ふ)り積(つ)もれば
包(つつ)み隠(かく)すの 悲(かな)しみの色(いろ)
皚皚的白雪從天而降
為我掩蓋悲傷的色彩
心(こころ)の奧(おく)に潛(ひそ)む愛(あい)
どうか憶(おぼ)えていて
將我心底潛藏的愛
毫無保留的獻予你
空(そら)高(たか)く舞(ま)い上(あ)がる
白(しろ)い羽(はね) 広(ひろ)げて
舒展?jié)嵃椎碾p翼
輕舞飛揚于廣闊的天際
柔(やわ)らかな陽(ひ)の中(なか)
あなたの夢(ゆめ)みていたい
在柔和的陽光里
滿懷著你的夢想
遠(とお)く空(そら) 舞(ま)い踴(おど)る
白(しろ)い羽(はね) 纏(まと)って
身披潔白的雙翼
翩翩起舞于悠遠的天空
ふたつの手(て) 重(かさ)ねて
未來(みらい)を離(はな)さないでいて
我們的雙手緊緊牽系
把握住未來,請不要放手
是 Never Grow Up 吧 ~
Your little hand's wrapped around my finger 你的小手握著我的手指
And it's so quiet in the world tonight今晚,這個世界好安靜
Your little eyelids flutter cause you're dreaming 你的眼皮因為你正做的夢微微的顫動著
So I tuck you in, turn on your favorite night light 我?guī)湍闵w上被子,打開了你最喜愛的小夜燈
To you everything's funny, you got nothing to regret 對你而言,這一切是多么的有趣,沒有事情讓你感到遺憾
I'd give all I have, honey 親愛的,我給了你一切我所擁有的
If you could stay like that 希望你能一直保持這樣
Oh darling, don't you ever grow up 親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, just stay this little就這樣不要長大,就一直這樣小小的
Oh darling, don't you ever grow up親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, it could stay this simple就這樣不要長大,世界就會這樣一直簡簡單單的
I won't let nobody hurt you, won't let no one break your heart 我不會讓任何人傷害你,我不會讓任何人打碎你的心
And no one will desert you 沒有人會拋棄你
Just try to never grow up, never grow up 試著的不要長大,不要長大
You're in the car on the way to the movies 你坐在車里,在去看電影的路上
And you're mortified your mom's dropping you off 因為媽媽送你,而讓你感到羞愧
At 14 there's just so much you can't do 當你14歲的時候,有許許多多的事情你沒有辦法做
And you can't wait to move out someday and call your own shots你等不及有一天,你會搬出去,擁有自己的房子,掌握著自己的一切
But don't make her drop you off around the block 但是別讓她送你到離目的地一個街區(qū)遠的地方(怕被別人看見)
Remember that she's getting older too 記得,她也在慢慢的變老
And don't lose the way that you dance around in your pj's getting ready for school
不要忘了你曾是如此興奮的穿著睡衣一邊跳著舞,一邊做著準備去學校,
Oh darling, don't you ever grow up親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, just stay this little就這樣不要長大,就這樣一直小小的
Oh darling, don't you ever grow up親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, it could stay this simple就這樣不要長大,世界就會這樣一直簡簡單單的
No one's ever burned you, nothing's ever left you scarred 沒有人傷害你,永遠不會有人讓你一個人害怕
And even though you want to, just try to never grow up即使你盼望著,也請試著不要長大吧
Take pictures in your mind of your childhood room 把你童年房間的樣子印在記憶里
Memorize what it sounded like when your dad gets home 記憶聽上去好像爸爸到家時的腳步聲一般溫馨
Remember the footsteps, remember the words said 記得那個腳步聲,記得那些話語
And all your little brother's favorite songs 還有所有你弟弟最愛的歌
I just realized everything I have is someday gonna be gone 我才意識到,我現(xiàn)在擁有的一切都會在未來的某一天消失
So here I am in my new apartment現(xiàn)在, 我站在我的新的公寓里
In a big city, they just dropped me off 在一個大城市, 他們開車送我到這里
It's so much colder that I thought it would be 比我想象的要寒冷的許多
So I tuck myself in and turn my night light on 我蓋上了自己的被子,打開了自己的小夜燈
Wish I'd never grown up 真希望我沒有長大
I wish I'd never grown up 我祈禱著,我還沒有長大
Oh I don't wanna grow up, wish I'd never grown up 我不想長大,真希望我沒有長大
I could still be little 我依舊是那樣小小的
Oh I don't wanna grow up, wish I'd never grown up我不想長大,真希望我沒有長大
It could still be simple 世界依舊是那樣的簡單
Oh darling, don't you ever grow up 親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, just stay this little就這樣不要長大,就一直這樣小小的
Oh darling, don't you ever grow up親愛的, 你可以就這樣不要長大嗎
Don't you ever grow up, it could stay this simple就這樣不要長大,世界就會這樣一直簡簡單單的
Won't let nobody hurt you 我不會讓任何人傷害你
Won't let no one break your heart不會讓任何人打碎你的心
And even though you want to, please try to never grow up 即使你盼望著,也請你試著不要長大
Oh, don't you ever grow up 不要長大
Oh, never grow up, just never grow up
不要長大,就這樣不要長大
在和lib平級 創(chuàng)建兩個目錄 assets 里面放置json文件
在pubspec.yaml里面配置
注意打包的時候json文件會被當成資源打入到包中,所以我們訪問的時候要在runApp之前配置下初始化訪問二進制權(quán)限。否則會報錯
由于 Flutter 不支持運行時反射,JSON 解析完全是手動的。
所謂手動解析,是指使用 dart:convert 庫中內(nèi)置的 JSON 解碼器,將 JSON 字符串解析成自定義對象的過程。使用這種方式,我們需要先將 JSON 字符串傳遞給 JSON.decode 方法解析成一個 Map,然后把這個 Map 傳給自定義的類,進行相關屬性的賦值。
下面動手解析一個用戶的信息
首先,我們根據(jù) JSON 結(jié)構(gòu)定義 User類,并創(chuàng)建一個工廠類,來處理 User 類屬性成員與 JSON 字典對象的值之間的映射關系:
數(shù)據(jù)解析類創(chuàng)建好了,剩下的事情就相對簡單了,我們只需要把 JSON 文本通過 JSON.decode 方法轉(zhuǎn)換成 Map,然后把它交給 User 的工廠類 fromJson 方法,即可完成 User 對象的解析:
項目中往往會碰到 嵌套對象屬性 情況,
面對這種情況,我們需要為每一個非基本類型屬性創(chuàng)建一個解析類。
然后,我們只需要在 User 類中,增加 dog 屬性及對應的 JSON 映射規(guī)則即可:
通過這種方法,無論對象有多復雜的非基本類型屬性,我們都可以創(chuàng)建對應的解析類進行處理。
不過到現(xiàn)在為止,我們的 JSON 數(shù)據(jù)解析還是在主 Isolate 中完成。如果 JSON 的數(shù)據(jù)格式比較復雜,數(shù)據(jù)量又大,這種解析方式可能會造成短期 UI 無法響應。下面我們可以用 compute 函數(shù)優(yōu)化一下
通過 compute 的改造,我們就不用擔心 JSON 解析時間過長阻塞 UI 響應了。