Flutter SystemChrome使用方法詳解
引言
SystemChrome 控制操作系統(tǒng)圖形界面的特定方面以及它如何與應用程序交互。
需要注意的是在使用的時候一定要保證先執(zhí)行 WidgetsFlutterBinding.ensureInitialized();
setPreferredOrientations 設置橫屏或堅屏
一般我們顯示是要強制堅屏,只需要指定 DeviceOrientation.portraitUp 就夠了。
SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp]);
不需要再加上 DeviceOrientation.portraitDown,因為加上也不會有效果。
SystemChrome.setPreferredOrientations([ DeviceOrientation.portraitUp,DeviceOrientation.portraitDown]);
這樣寫也可以,只有后面的 portraitDown 有點多余,如果可以的話,系統(tǒng)不允許在豎直方向倒過來,所以即使是手機設置中沒有打開方向鎖定,也不用擔心會倒過來。
如果想在豎直方向倒過來,可以只指定 portraitDown。這樣畫面就會一直倒置。
SystemChrome.setPreferredOrientations([DeviceOrientation.portraitDown]);
如果想設置畫面水平一般會同時設置兩個。當手機反轉的時候,畫面也可以隨著反轉。(沒有設置鎖定的情況下)
SystemChrome.setPreferredOrientations([ DeviceOrientation.landscapeLeft,DeviceOrientation.landscapeRight]);
只有禁用多任務處理時,此設置才會在 iPad 上生效。
setEnabledSystemUIMode 設置全屏顯示
用 manual 的方式可以指定顯下面或下面的 overlay,或都不顯示。
//都不顯示,全屏 SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual,overlays: []); //顯示上面 SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual,overlays: [SystemUiOverlay.top]); //顯示下面 SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual,overlays: [SystemUiOverlay.bottom]);
setSystemUIOverlayStyle 設置 overlay 樣式,
overlay 的顯示樣式,比如可以顯示 dark style
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.dark);
android 有效,ios 可能沒有效果。
如果有的設置沒生效,可以重新啟動 app 試試
全屏播放視頻
如果要全屏播放視頻可以做如下設置,橫屏,并去掉 overlays。
SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual,overlays: []); SystemChrome.setPreferredOrientations([ DeviceOrientation.landscapeLeft,DeviceOrientation.landscapeRight]);
setSystemUIChangeCallback
只在 android 有效,SystemUiMode 設置 SystemUiMode.leanBack 或 SystemUiMode.immersive 或 SystemUiMode.immersiveSticky 的時候, overlays 會隨著與用戶交互消失或出現(xiàn),可以監(jiān)聽 setSystemUIChangeCallback 讓 overlays 自動恢復原來的狀態(tài)。
WidgetsFlutterBinding.ensureInitialized(); SystemChrome.setEnabledSystemUIMode(SystemUiMode.immersive); SystemChrome.setSystemUIChangeCallback((systemOverlaysAreVisible) async { await Future.delayed(const Duration(seconds: 1)); SystemChrome.restoreSystemUIOverlays(); });
AnnotatedRegion
如果想控制 status bar 的樣式還可以用 AnnotatedRegion,需要注意的是,使用 AnnotatedRegion 就不要使用 AppBar了,否則會被 AppBar了 覆蓋。
AnnotatedRegion( child: Text('IAM17'), value: SystemUiOverlayStyle( statusBarColor: Colors.green, statusBarIconBrightness: Brightness.light, //底部navigationBar背景顏色 systemNavigationBarColor: Colors.white), )
以上就是Flutter SystemChrome使用方法詳解的詳細內容,更多關于Flutter SystemChrome使用的資料請關注腳本之家其它相關文章!
相關文章
Flutter框架實現(xiàn)Android拖動到垃圾桶刪除效果
這篇文章主要介紹了Flutter框架實現(xiàn)Android拖動到垃圾桶刪除效果,Flutter框架中的Draggable部件,用于支持用戶通過手勢拖動,它是基于手勢的一種方式,可以使用戶可以在屏幕上拖動指定的部件,下面我們來詳細了解一下2023-12-12android實現(xiàn)raw文件夾導入數(shù)據(jù)庫代碼
這篇文章主要介紹了android實現(xiàn)raw文件夾導入數(shù)據(jù)庫代碼,有需要的朋友可以參考一下2013-12-12Android編程開發(fā)ScrollView中ViewPager無法正?;瑒訂栴}解決方法
這篇文章主要介紹了Android編程開發(fā)ScrollView中ViewPager無法正常滑動問題解決方法,以實例形式分析了ScrollView中滑動失效的原因及解決方法,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10Android實現(xiàn)SwipeRefreshLayout首次進入自動刷新
這篇文章主要為大家詳細介紹了Android實現(xiàn)SwipeRefreshLayout首次進入自動刷新,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01android開發(fā)之橫向滾動/豎向滾動的ListView(固定列頭)
由于項目需要,我們需要一個可以橫向滾動的,又可以豎向滾動的 表格;經(jīng)過幾天的研究終于搞定,感興趣的朋友可以了解下哦2013-01-01Android中EditText setText方法的踩坑實戰(zhàn)
這篇文章主要給大家分享了一些關于Android中EditText setText方法的踩坑記錄,文中通過示例代碼介紹的非常詳細,對各位Android開發(fā)者們具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-07-07