天天看點

#yyds幹貨盤點#Flutter 如何禁止手機橫屏[Flutter專題32]

這裡是堅果前端小課堂,歡迎關注公衆号“堅果前端”,

#yyds幹貨盤點#Flutter 如何禁止手機橫屏[Flutter專題32]

問題引出

群友發來問題: Flutter 怎麼禁止橫屏顯示呀,網上說的幾個方法 都沒有效

#yyds幹貨盤點#Flutter 如何禁止手機橫屏[Flutter專題32]

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

正文

在一些特定的 App 裡,我們不希望手機橫屏的時候,App 發生旋轉,在 ​

​main​

​ 函數裡,像下面這樣設定,就可以做到全局禁用橫屏模式了。 代碼

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());

    });

}      

不過,在部分需求裡,并不是徹底禁用了橫屏模式,比如打開網頁,也就是在WebView 的場景下,是可以橫屏的,但是在其他界面下不可以橫屏。這要怎麼設定呢?

@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();

  }      

像這樣,設定到一個 StatefulWidget 的 ​

​initState​

​​ 和 ​

​dispose​

​ 裡面就可以了。比如在我的代碼裡,我把 WebView 專門封裝了一個頁面,叫 WebPage,這樣設定後,當使用者進入網頁的時候,可以橫屏,但是退回後,就會強制恢複豎屏。 最後如果不起作用,可以分别做如下設定

IOS:

#yyds幹貨盤點#Flutter 如何禁止手機橫屏[Flutter專題32]

安卓:

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

#yyds幹貨盤點#Flutter 如何禁止手機橫屏[Flutter專題32]

另外pub.dev上有個

插件orientation

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