OpenMediacenterMobileFlutter/lib/videoscreen_desktop.dart

129 lines
3.2 KiB
Dart
Raw Normal View History

2022-04-15 16:15:44 +00:00
import 'dart:convert';
import 'dart:math';
2022-04-15 18:19:09 +00:00
import 'package:chewie/chewie.dart';
2022-04-15 16:15:44 +00:00
import "package:dart_vlc/dart_vlc.dart";
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:openmediacentermobile/preview_tile.dart';
2022-04-15 18:19:09 +00:00
import 'package:video_player/video_player.dart';
2022-04-15 16:15:44 +00:00
import 'api/api.dart';
import 'api/token.dart';
2022-04-15 18:19:09 +00:00
import 'log/log.dart';
2022-04-15 16:15:44 +00:00
import 'platform.dart';
class VideoScreen extends StatefulWidget {
const VideoScreen({Key? key, required this.MetaData}) : super(key: key);
final VideoT MetaData;
2022-04-15 16:15:44 +00:00
@override
State<VideoScreen> createState() => _VideoScreenState();
}
class _VideoScreenState extends State<VideoScreen> {
Player? player = isDesktop() ? Player(id: Random().nextInt(0x7fffffff)) : null;
2022-04-15 18:19:09 +00:00
ChewieController? _chewieController;
2022-04-15 16:15:44 +00:00
void loadData() async {
final data = await API.query("video", "loadVideo", {'MovieId': widget.MetaData.id});
2022-04-15 16:15:44 +00:00
final d = jsonDecode(data);
final url = d["MovieUrl"];
final token = await Token.getInstance().getToken();
if (token == null) return;
final baseurl = token.domain;
// todo not static middle path
final path = baseurl + "/videos/vids/" + url;
if (isDesktop()) {
final media2 = Media.network(path);
player?.open(
2022-04-15 16:15:44 +00:00
media2,
autoStart: true, // default
);
} else {
2022-04-15 18:19:09 +00:00
final VideoPlayerController _controller = VideoPlayerController.network(path);
await _controller.initialize();
_chewieController = ChewieController(
videoPlayerController: _controller,
autoPlay: true,
looping: true,
2022-08-21 20:44:12 +00:00
allowFullScreen: true,
allowMuting: true,
allowPlaybackSpeedChanging: true,
zoomAndPan: true
2022-04-15 18:19:09 +00:00
);
setState(() {});
2022-04-15 16:15:44 +00:00
}
}
@override
void initState() {
super.initState();
if(isDesktop()){
RawKeyboard.instance.addListener((value) {
if (value.logicalKey == LogicalKeyboardKey.arrowRight) {
player?.seek(player!.position.position! + const Duration(seconds: 5));
} else if (value.logicalKey == LogicalKeyboardKey.arrowLeft) {
player?.seek(player!.position.position! + const Duration(seconds: -5));
}
});
}
2022-04-15 16:15:44 +00:00
loadData();
// todo hide appbar after some seonds
}
@override
void dispose() {
super.dispose();
2022-04-15 18:19:09 +00:00
if (isDesktop()) {
player?.dispose();
2022-04-15 18:19:09 +00:00
} else {
_chewieController?.videoPlayerController.dispose();
_chewieController?.dispose();
}
2022-04-15 16:15:44 +00:00
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.MetaData.title),
2022-04-15 16:15:44 +00:00
),
2022-04-15 18:19:09 +00:00
body: Center(child: isDesktop() ? videoDesktop() : videoNotDesktop()),
);
}
Widget videoDesktop() {
return Video(
player: player,
scale: 1.0, // default
showControls: true,
playlistLength: 1, // default
);
}
Widget videoNotDesktop() {
if (_chewieController == null) {
return Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: const [CircularProgressIndicator(), Text("loading...")],
);
}
return Chewie(
controller: _chewieController!,
2022-04-15 16:15:44 +00:00
);
}
}