這里是堅(jiān)果前端小課堂,歡迎關(guān)注公眾號(hào)“堅(jiān)果前端”,

#yyds干貨盤點(diǎn)#Flutter

問題引出

群友發(fā)來問題: Flutter 怎么禁止橫屏顯示呀,網(wǎng)上說的幾個(gè)方法 都沒有效

#yyds干貨盤點(diǎn)#Flutter

群友遇到問題,就要群友去幫助,這樣,這個(gè)群就有了存在的意義。

正文

在一些特定的 App 里,我們不希望手機(jī)橫屏的時(shí)候,App 發(fā)生旋轉(zhuǎn),在 ??main?? 函數(shù)里,像下面這樣設(shè)定,就可以做到全局禁用橫屏模式了。 代碼

import package:flutter/services.dart;

void main() async => {

WidgetsFlutterBinding.ensureInitialized();

await SystemChrome.setPreferredOrientations(

[

DeviceOrientation.portraitUp, // 豎屏 Portrait 模式

DeviceOrientation.portraitDown,
// DeviceOrientation.landscapeLeft, // 橫屏 Landscape 模式

// DeviceOrientation.landscapeRight,

],

);

runApp(MyApp());

};

看你咋寫

void main() {

WidgetsFlutterBinding.ensureInitialized();

SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp])

.then((_) {

runApp(new MyApp());

});

}

不過,在部分需求里,并不是徹底禁用了橫屏模式,比如打開網(wǎng)頁,也就是在WebView 的場景下,是可以橫屏的,但是在其他界面下不可以橫屏。這要怎么設(shè)置呢?

@override

void initState() {

super.initState();

SystemChrome.setPreferredOrientations([

DeviceOrientation.landscapeLeft,

DeviceOrientation.landscapeRight,

DeviceOrientation.portraitUp,

DeviceOrientation.portraitDown,

]);

}

@override

void dispose() {

SystemChrome.setPreferredOrientations([

DeviceOrientation.portraitUp,

DeviceOrientation.portraitDown,

]);

super.dispose();

}

像這樣,設(shè)置到一個(gè) StatefulWidget 的 ??initState??? 和 ??dispose?? 里面就可以了。比如在我的代碼里,我把 WebView 專門封裝了一個(gè)頁面,叫 WebPage,這樣設(shè)定后,當(dāng)用戶進(jìn)入網(wǎng)頁的時(shí)候,可以橫屏,但是退回后,就會(huì)強(qiáng)制恢復(fù)豎屏。 最后如果不起作用,可以分別做如下設(shè)置

IOS:

#yyds干貨盤點(diǎn)#Flutter

安卓:

android/app/src/main/AndroidManifest.xml`如下所示:

#yyds干貨盤點(diǎn)#Flutter

另外pub.dev上有個(gè)

插件orientation

https://pub.flutter-io.cn/packages/orientation/install 可以去試一下,我在這兒就不做解釋了。

大家覺得幫到你的話,關(guān)注一下哦!


當(dāng)然對(duì)于生活這段代碼來說,不會(huì)按照你的想法來執(zhí)行,充滿了太多的未知和異常,稍不留神就是報(bào)錯(cuò),遇到問題就必須處理,DeBug的過程雖然很難很痛苦,但成功解決完之后又是另一番美景。堅(jiān)果加油