more reliable video playback
This commit is contained in:
parent
ce15add4e7
commit
5c2f8fa014
1 changed files with 10 additions and 3 deletions
|
|
@ -1,3 +1,5 @@
|
||||||
|
import "dart:async";
|
||||||
|
|
||||||
import "package:flutter/material.dart";
|
import "package:flutter/material.dart";
|
||||||
import "package:hooks_riverpod/hooks_riverpod.dart";
|
import "package:hooks_riverpod/hooks_riverpod.dart";
|
||||||
import "package:nexus/models/info/video.dart";
|
import "package:nexus/models/info/video.dart";
|
||||||
|
|
@ -13,15 +15,20 @@ class VideoPlayer extends HookConsumerWidget {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
Widget build(BuildContext context, WidgetRef ref) {
|
||||||
late final player = useMemoized(
|
final player = useMemoized(
|
||||||
() => Player(
|
() => Player(
|
||||||
configuration: PlayerConfiguration(bufferSize: 128 * 1024 * 1024),
|
configuration: PlayerConfiguration(bufferSize: 128 * 1024 * 1024),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
late final controller = useMemoized(() => VideoController(player));
|
final controller = useMemoized(() => VideoController(player));
|
||||||
|
|
||||||
useEffect(() {
|
useEffect(() {
|
||||||
player.open(Media(url.toString(), httpHeaders: ref.headers), play: false);
|
scheduleMicrotask(
|
||||||
|
() => player.open(
|
||||||
|
Media(url.toString(), httpHeaders: ref.headers),
|
||||||
|
play: false,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
return player.dispose;
|
return player.dispose;
|
||||||
}, []);
|
}, []);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue