2023-06-26 17:27:47 +02:00
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2024-08-29 00:01:13 +02:00
|
|
|
import 'package:native_video_player/native_video_player.dart';
|
2024-03-06 04:42:22 +01:00
|
|
|
import 'package:video_player/video_player.dart';
|
2023-06-26 17:27:47 +02:00
|
|
|
|
2024-03-06 04:42:22 +01:00
|
|
|
enum VideoPlaybackState {
|
|
|
|
initializing,
|
|
|
|
paused,
|
|
|
|
playing,
|
|
|
|
buffering,
|
|
|
|
completed,
|
|
|
|
}
|
2023-06-26 17:27:47 +02:00
|
|
|
|
2024-03-06 04:42:22 +01:00
|
|
|
class VideoPlaybackValue {
|
|
|
|
/// The current position of the video
|
2023-06-26 17:27:47 +02:00
|
|
|
final Duration position;
|
2024-03-06 04:42:22 +01:00
|
|
|
|
|
|
|
/// The total duration of the video
|
2023-06-26 17:27:47 +02:00
|
|
|
final Duration duration;
|
2024-03-06 04:42:22 +01:00
|
|
|
|
|
|
|
/// The current state of the video playback
|
|
|
|
final VideoPlaybackState state;
|
|
|
|
|
|
|
|
/// The volume of the video
|
|
|
|
final double volume;
|
|
|
|
|
|
|
|
VideoPlaybackValue({
|
|
|
|
required this.position,
|
|
|
|
required this.duration,
|
|
|
|
required this.state,
|
|
|
|
required this.volume,
|
|
|
|
});
|
|
|
|
|
2024-08-29 00:01:13 +02:00
|
|
|
factory VideoPlaybackValue.fromNativeController(
|
|
|
|
NativeVideoPlayerController controller,
|
|
|
|
) {
|
|
|
|
final playbackInfo = controller.playbackInfo;
|
|
|
|
final videoInfo = controller.videoInfo;
|
|
|
|
late VideoPlaybackState s;
|
|
|
|
if (playbackInfo?.status == null) {
|
|
|
|
s = VideoPlaybackState.initializing;
|
|
|
|
} else if (playbackInfo?.status == PlaybackStatus.stopped &&
|
|
|
|
(playbackInfo?.positionFraction == 1 ||
|
|
|
|
playbackInfo?.positionFraction == 0)) {
|
|
|
|
s = VideoPlaybackState.completed;
|
|
|
|
} else if (playbackInfo?.status == PlaybackStatus.playing) {
|
|
|
|
s = VideoPlaybackState.playing;
|
|
|
|
} else {
|
|
|
|
s = VideoPlaybackState.paused;
|
|
|
|
}
|
|
|
|
|
|
|
|
return VideoPlaybackValue(
|
|
|
|
position: Duration(seconds: playbackInfo?.position ?? 0),
|
|
|
|
duration: Duration(seconds: videoInfo?.duration ?? 0),
|
|
|
|
state: s,
|
|
|
|
volume: playbackInfo?.volume ?? 0.0,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-03-06 04:42:22 +01:00
|
|
|
factory VideoPlaybackValue.fromController(VideoPlayerController? controller) {
|
|
|
|
final video = controller?.value;
|
|
|
|
late VideoPlaybackState s;
|
|
|
|
if (video == null) {
|
|
|
|
s = VideoPlaybackState.initializing;
|
|
|
|
} else if (video.isCompleted) {
|
|
|
|
s = VideoPlaybackState.completed;
|
|
|
|
} else if (video.isPlaying) {
|
|
|
|
s = VideoPlaybackState.playing;
|
|
|
|
} else if (video.isBuffering) {
|
|
|
|
s = VideoPlaybackState.buffering;
|
|
|
|
} else {
|
|
|
|
s = VideoPlaybackState.paused;
|
|
|
|
}
|
|
|
|
|
|
|
|
return VideoPlaybackValue(
|
|
|
|
position: video?.position ?? Duration.zero,
|
|
|
|
duration: video?.duration ?? Duration.zero,
|
|
|
|
state: s,
|
|
|
|
volume: video?.volume ?? 0.0,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
factory VideoPlaybackValue.uninitialized() {
|
|
|
|
return VideoPlaybackValue(
|
|
|
|
position: Duration.zero,
|
|
|
|
duration: Duration.zero,
|
|
|
|
state: VideoPlaybackState.initializing,
|
|
|
|
volume: 0.0,
|
|
|
|
);
|
|
|
|
}
|
2024-08-29 20:46:39 +02:00
|
|
|
|
|
|
|
VideoPlaybackValue copyWith({
|
|
|
|
Duration? position,
|
|
|
|
Duration? duration,
|
|
|
|
VideoPlaybackState? state,
|
|
|
|
double? volume,
|
|
|
|
}) {
|
|
|
|
return VideoPlaybackValue(
|
|
|
|
position: position ?? this.position,
|
|
|
|
duration: duration ?? this.duration,
|
|
|
|
state: state ?? this.state,
|
|
|
|
volume: volume ?? this.volume,
|
|
|
|
);
|
|
|
|
}
|
2023-06-26 17:27:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
final videoPlaybackValueProvider =
|
|
|
|
StateNotifierProvider<VideoPlaybackValueState, VideoPlaybackValue>((ref) {
|
|
|
|
return VideoPlaybackValueState(ref);
|
|
|
|
});
|
|
|
|
|
|
|
|
class VideoPlaybackValueState extends StateNotifier<VideoPlaybackValue> {
|
|
|
|
VideoPlaybackValueState(this.ref)
|
|
|
|
: super(
|
2024-03-06 04:42:22 +01:00
|
|
|
VideoPlaybackValue.uninitialized(),
|
2023-06-26 17:27:47 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
final Ref ref;
|
|
|
|
|
|
|
|
VideoPlaybackValue get value => state;
|
|
|
|
|
|
|
|
set value(VideoPlaybackValue value) {
|
|
|
|
state = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
set position(Duration value) {
|
2024-03-06 04:42:22 +01:00
|
|
|
state = VideoPlaybackValue(
|
|
|
|
position: value,
|
|
|
|
duration: state.duration,
|
|
|
|
state: state.state,
|
|
|
|
volume: state.volume,
|
|
|
|
);
|
2023-06-26 17:27:47 +02:00
|
|
|
}
|
|
|
|
}
|