【问题标题】:How to play a video in flutter in landscape view?如何在横向视图中播放视频?
【发布时间】:2020-05-20 20:26:55
【问题描述】:

我的资产文件夹中有一个视频,当我尝试代码时,它给出了一些例外。谁能帮帮我?

class VideoExample extends StatefulWidget {
  @override
  VideoState createState() => VideoState();
}
class VideoState extends State<VideoExample> {
  VideoPlayerController playerController;
  VoidCallback listener;

  @override
  void initState() {
    super.initState();
    listener = () {
      setState(() {});
    };
  }

  void createVideo() {
    if (playerController == null) {
      playerController = VideoPlayerController.asset("assets/videos/video.mp4")
      ..addListener(listener)
      ..setVolume(1.0)
      ..initialize();
    }
  }

  @override
  void deactivate() {
    playerController.setVolume(0.0);
    playerController.removeListener(listener);
    super.deactivate();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Video'),
      ),
      body: Center(
          child: AspectRatio(
              aspectRatio: 16 / 9,
              child: Container(
                child: (playerController != null
                    ? VideoPlayer(
                  playerController,
                )
                    : Container()),
              ))),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          createVideo();
          playerController.play();
        },
        child: Icon(Icons.play_arrow),
      ),
    );
  }

}

我只想让视频以横向模式全屏播放。

我已经导入了所有基本包并更改了 pubspec.yaml 文件。

它正在播放视频,但不是在全屏横向模式下播放。

【问题讨论】:

    标签: android flutter dart


    【解决方案1】:

    您可以在下面复制粘贴运行完整代码
    您可以使用包https://pub.dev/packages/chewiehttps://pub.dev/packages/auto_orientation
    您可以使用_chewieController.enterFullScreen() 进入全屏模式

    代码sn-p

    _chewieController = ChewieController(
        videoPlayerController: _videoPlayerController1,
        aspectRatio: 3 / 2,
        autoPlay: true,
        looping: true,
        routePageBuilder: (BuildContext context, Animation<double> animation,
            Animation<double> secondAnimation, provider) {
          return AnimatedBuilder(
            animation: animation,
            builder: (BuildContext context, Widget child) {
              return VideoScaffold(
                child: Scaffold(
                  resizeToAvoidBottomPadding: false,
                  body: Container(
                    alignment: Alignment.center,
                    color: Colors.black,
                    child: provider,
                  ),
                ),
              );
            },
          );
        }
    
    FlatButton(
                  onPressed: () {
                    _chewieController.enterFullScreen();
                  },
                  child: Text('Fullscreen'),
                ),
    

    工作演示

    完整代码

    import 'package:auto_orientation/auto_orientation.dart';
    import 'package:chewie/chewie.dart';
    import 'package:chewie/src/chewie_player.dart';
    import 'package:flutter/cupertino.dart';
    import 'package:flutter/material.dart';
    import 'package:flutter/services.dart';
    import 'package:video_player/video_player.dart';
    
    void main() {
      runApp(
        ChewieDemo(),
      );
    }
    
    class ChewieDemo extends StatefulWidget {
      ChewieDemo({this.title = 'Chewie Demo'});
    
      final String title;
    
      @override
      State<StatefulWidget> createState() {
        return _ChewieDemoState();
      }
    }
    
    class _ChewieDemoState extends State<ChewieDemo> {
      TargetPlatform _platform;
      VideoPlayerController _videoPlayerController1;
      VideoPlayerController _videoPlayerController2;
      ChewieController _chewieController;
    
      @override
      void initState() {
        super.initState();
        _videoPlayerController1 = VideoPlayerController.network(
            'https://flutter.github.io/assets-for-api-docs/assets/videos/butterfly.mp4');
        _videoPlayerController2 = VideoPlayerController.network(
            'https://www.sample-videos.com/video123/mp4/480/big_buck_bunny_480p_20mb.mp4');
        _chewieController = ChewieController(
            videoPlayerController: _videoPlayerController1,
            aspectRatio: 3 / 2,
            autoPlay: true,
            looping: true,
            routePageBuilder: (BuildContext context, Animation<double> animation,
                Animation<double> secondAnimation, provider) {
              return AnimatedBuilder(
                animation: animation,
                builder: (BuildContext context, Widget child) {
                  return VideoScaffold(
                    child: Scaffold(
                      resizeToAvoidBottomPadding: false,
                      body: Container(
                        alignment: Alignment.center,
                        color: Colors.black,
                        child: provider,
                      ),
                    ),
                  );
                },
              );
            }
          // Try playing around with some of these other options:
    
          // showControls: false,
          // materialProgressColors: ChewieProgressColors(
          //   playedColor: Colors.red,
          //   handleColor: Colors.blue,
          //   backgroundColor: Colors.grey,
          //   bufferedColor: Colors.lightGreen,
          // ),
          // placeholder: Container(
          //   color: Colors.grey,
          // ),
          // autoInitialize: true,
        );
      }
    
      @override
      void dispose() {
        _videoPlayerController1.dispose();
        _videoPlayerController2.dispose();
        _chewieController.dispose();
        super.dispose();
      }
    
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: widget.title,
          theme: ThemeData.light().copyWith(
            platform: _platform ?? Theme.of(context).platform,
          ),
          home: Scaffold(
            appBar: AppBar(
              title: Text(widget.title),
            ),
            body: Column(
              children: <Widget>[
                Expanded(
                  child: Center(
                    child: Chewie(
                      controller: _chewieController,
                    ),
                  ),
                ),
                FlatButton(
                  onPressed: () {
                    _chewieController.enterFullScreen();
                  },
                  child: Text('Fullscreen'),
                ),
                Row(
                  children: <Widget>[
                    Expanded(
                      child: FlatButton(
                        onPressed: () {
                          setState(() {
                            _chewieController.dispose();
                            _videoPlayerController2.pause();
                            _videoPlayerController2.seekTo(Duration(seconds: 0));
                            _chewieController = ChewieController(
                              videoPlayerController: _videoPlayerController1,
                              aspectRatio: 3 / 2,
                              autoPlay: true,
                              looping: true,
                            );
                          });
                        },
                        child: Padding(
                          child: Text("Video 1"),
                          padding: EdgeInsets.symmetric(vertical: 16.0),
                        ),
                      ),
                    ),
                    Expanded(
                      child: FlatButton(
                        onPressed: () {
                          setState(() {
                            _chewieController.dispose();
                            _videoPlayerController1.pause();
                            _videoPlayerController1.seekTo(Duration(seconds: 0));
                            _chewieController = ChewieController(
                              videoPlayerController: _videoPlayerController2,
                              aspectRatio: 3 / 2,
                              autoPlay: true,
                              looping: true,
                            );
                          });
                        },
                        child: Padding(
                          padding: EdgeInsets.symmetric(vertical: 16.0),
                          child: Text("Video 2"),
                        ),
                      ),
                    )
                  ],
                ),
                Row(
                  children: <Widget>[
                    Expanded(
                      child: FlatButton(
                        onPressed: () {
                          setState(() {
                            _platform = TargetPlatform.android;
                          });
                        },
                        child: Padding(
                          child: Text("Android controls"),
                          padding: EdgeInsets.symmetric(vertical: 16.0),
                        ),
                      ),
                    ),
                    Expanded(
                      child: FlatButton(
                        onPressed: () {
                          setState(() {
                            _platform = TargetPlatform.iOS;
                          });
                        },
                        child: Padding(
                          padding: EdgeInsets.symmetric(vertical: 16.0),
                          child: Text("iOS controls"),
                        ),
                      ),
                    )
                  ],
                )
              ],
            ),
          ),
        );
      }
    }
    
    class VideoScaffold extends StatefulWidget {
      const VideoScaffold({Key key, this.child}) : super(key: key);
    
      final Widget child;
    
      @override
      State<StatefulWidget> createState() => _VideoScaffoldState();
    }
    
    class _VideoScaffoldState extends State<VideoScaffold> {
      @override
      void initState() {
        SystemChrome.setPreferredOrientations([
          DeviceOrientation.landscapeRight,
          DeviceOrientation.landscapeLeft,
        ]);
        AutoOrientation.landscapeAutoMode();
        super.initState();
      }
    
      @override
      dispose() {
        SystemChrome.setPreferredOrientations([
          DeviceOrientation.portraitUp,
          DeviceOrientation.portraitDown,
        ]);
        AutoOrientation.portraitAutoMode();
        super.dispose();
      }
    
      @override
      Widget build(BuildContext context) {
        return widget.child;
      }
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-03-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-03-13
      相关资源
      最近更新 更多