|
|
|
@ -1,6 +1,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:chewie/chewie.dart'; |
|
|
|
|
import 'package:flutter/services.dart'; |
|
|
|
|
import 'package:flutter_html/flutter_html.dart'; |
|
|
|
|
import 'package:flutter_html/image_render.dart'; |
|
|
|
|
import 'package:chewie/src/chewie_progress_colors.dart' as chewie; |
|
|
|
@ -106,39 +107,60 @@ class _WebContent extends State<WebContent> {
|
|
|
|
|
|
|
|
|
|
Widget videoWidget(double width, double height, src, sandboxMode) { |
|
|
|
|
print("src : $src"); |
|
|
|
|
chewieAudioController = ChewieController( |
|
|
|
|
videoPlayerController: videoPlayerController = |
|
|
|
|
VideoPlayerController.network( |
|
|
|
|
src, |
|
|
|
|
), |
|
|
|
|
aspectRatio: width / height, |
|
|
|
|
//宽高比 |
|
|
|
|
autoPlay: false, |
|
|
|
|
//自动播放 |
|
|
|
|
looping: false, |
|
|
|
|
//循环播放 |
|
|
|
|
allowFullScreen: true, |
|
|
|
|
// systemOverlaysAfterFullScreen: [], |
|
|
|
|
// systemOverlaysOnEnterFullScreen: [], |
|
|
|
|
// deviceOrientationsAfterFullScreen: [], |
|
|
|
|
// deviceOrientationsOnEnterFullScreen: [], |
|
|
|
|
// 拖动条样式颜色 |
|
|
|
|
materialProgressColors: chewie.ChewieProgressColors( |
|
|
|
|
playedColor: Colors.white, |
|
|
|
|
handleColor: Colors.white, |
|
|
|
|
backgroundColor: Colors.grey, |
|
|
|
|
bufferedColor: Colors.transparent, |
|
|
|
|
), |
|
|
|
|
autoInitialize: true, |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
chewieAudioController.addListener(_fullScreenListener); |
|
|
|
|
|
|
|
|
|
return MediaQuery( |
|
|
|
|
data: MediaQuery.of(context).copyWith( |
|
|
|
|
textScaleFactor: 0.9, |
|
|
|
|
textScaleFactor: textScaleFactor, |
|
|
|
|
), |
|
|
|
|
child: Container( |
|
|
|
|
width: MediaQuery.of(context).size.width - 17, |
|
|
|
|
height: (MediaQuery.of(context).size.width) / (width / height), |
|
|
|
|
child: chewies = Chewie( |
|
|
|
|
controller: chewieAudioController = ChewieController( |
|
|
|
|
videoPlayerController: videoPlayerController = |
|
|
|
|
VideoPlayerController.network( |
|
|
|
|
src, |
|
|
|
|
), |
|
|
|
|
aspectRatio: width / height, |
|
|
|
|
//宽高比 |
|
|
|
|
autoPlay: false, |
|
|
|
|
//自动播放 |
|
|
|
|
looping: false, |
|
|
|
|
//循环播放 |
|
|
|
|
// 拖动条样式颜色 |
|
|
|
|
materialProgressColors: chewie.ChewieProgressColors( |
|
|
|
|
playedColor: Colors.white, |
|
|
|
|
handleColor: Colors.white, |
|
|
|
|
backgroundColor: Colors.grey, |
|
|
|
|
bufferedColor: Colors.transparent, |
|
|
|
|
), |
|
|
|
|
autoInitialize: true, |
|
|
|
|
), |
|
|
|
|
controller: chewieAudioController, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Future<void> _fullScreenListener() async { |
|
|
|
|
print("object: isPlaying: ${videoPlayerController.value.isPlaying}"); |
|
|
|
|
print("object: isFullScreen: ${chewieAudioController.isFullScreen}"); |
|
|
|
|
|
|
|
|
|
if (!chewieAudioController.isFullScreen) { |
|
|
|
|
textScaleFactor = 1; |
|
|
|
|
setState(() {}); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
double textScaleFactor = 0.9; |
|
|
|
|
|
|
|
|
|
Widget audioWidget(showControls, loop, autoplay, src, width) { |
|
|
|
|
return Container( |
|
|
|
|
width: width, |
|
|
|
|