2023-04-03 21:11:25 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:media_kit/media_kit.dart';
|
|
|
|
import 'package:media_kit_video/media_kit_video.dart';
|
|
|
|
|
|
|
|
class MediaKitAvControl extends StatefulWidget {
|
|
|
|
final String videoUrl;
|
2023-04-13 14:30:09 +00:00
|
|
|
final double? width;
|
|
|
|
final double? height;
|
2023-04-26 19:58:33 +00:00
|
|
|
final Function()? onGoFullScreen;
|
2023-04-03 21:11:25 +00:00
|
|
|
|
|
|
|
const MediaKitAvControl({
|
|
|
|
super.key,
|
|
|
|
required this.videoUrl,
|
|
|
|
required this.width,
|
|
|
|
required this.height,
|
2023-04-26 19:58:33 +00:00
|
|
|
this.onGoFullScreen,
|
2023-04-03 21:11:25 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<MediaKitAvControl> createState() => _MediaKitAvControlState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _MediaKitAvControlState extends State<MediaKitAvControl> {
|
|
|
|
static final _logger = Logger('$MediaKitAvControl');
|
2023-04-19 15:46:14 +00:00
|
|
|
final Player player = Player(
|
|
|
|
configuration: const PlayerConfiguration(
|
|
|
|
logLevel: MPVLogLevel.warn,
|
2023-11-29 21:02:23 +00:00
|
|
|
muted: true,
|
2023-04-19 15:46:14 +00:00
|
|
|
),
|
|
|
|
);
|
2023-04-03 21:11:25 +00:00
|
|
|
VideoController? controller;
|
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
2023-10-31 01:44:16 +00:00
|
|
|
controller = VideoController(player);
|
|
|
|
player.open(Media(widget.videoUrl), play: false);
|
2023-04-03 21:11:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
Future.microtask(() async {
|
|
|
|
await player.dispose();
|
|
|
|
});
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void deactivate() {
|
|
|
|
player.pause();
|
|
|
|
super.deactivate();
|
|
|
|
}
|
|
|
|
|
2023-04-13 14:30:09 +00:00
|
|
|
double? get height => widget.height == null ? null : widget.height! - 50;
|
2023-04-04 17:54:08 +00:00
|
|
|
|
2023-04-13 14:30:09 +00:00
|
|
|
double? get width => widget.width;
|
2023-04-04 17:54:08 +00:00
|
|
|
|
2023-04-03 21:11:25 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2023-11-27 19:16:11 +00:00
|
|
|
_logger.finest('Building MediaKit Control for ${widget.videoUrl}');
|
2023-04-03 21:11:25 +00:00
|
|
|
if (controller == null) {
|
2023-04-19 15:46:14 +00:00
|
|
|
return Container(
|
|
|
|
width: widget.width,
|
|
|
|
height: widget.height,
|
|
|
|
color: Colors.black12,
|
|
|
|
child: Column(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
|
|
children: const [
|
|
|
|
CircularProgressIndicator(),
|
|
|
|
],
|
|
|
|
),
|
2023-04-03 21:11:25 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return GestureDetector(
|
|
|
|
child: Column(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: [
|
2023-04-13 14:30:09 +00:00
|
|
|
Expanded(
|
|
|
|
child: Video(
|
2023-10-31 01:44:16 +00:00
|
|
|
controller: controller!,
|
2023-04-13 14:30:09 +00:00
|
|
|
width: width,
|
|
|
|
height: height,
|
|
|
|
),
|
2023-04-03 21:11:25 +00:00
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|