chore: Merge upstream changes --------- Signed-off-by: Krille <c.kussowski@famedly.com> Co-authored-by: krille-chan <christian-kussowski@posteo.de> Co-authored-by: Krille <c.kussowski@famedly.com> Co-authored-by: Linerly <linerly@proton.me> Co-authored-by: Priit Jõerüüt <hwlate@joeruut.com> Co-authored-by: 大王叫我来巡山 <hamburger2048@users.noreply.hosted.weblate.org> Co-authored-by: fadelkon <fadelkon@posteo.net> Co-authored-by: Aindriú Mac Giolla Eoin <aindriu80@gmail.com> Co-authored-by: Edgars Andersons <Edgars+Weblate@gaitenis.id.lv> Co-authored-by: josé m <correoxm@disroot.org> Co-authored-by: Bezruchenko Simon <worcposj44@gmail.com> Co-authored-by: Christian <christian-pauly@posteo.de> Co-authored-by: - <hitekex@yandex.ru> Co-authored-by: Angelo Schirinzi <Odi-3@users.noreply.hosted.weblate.org> Co-authored-by: xabirequejo <xabi.rn@gmail.com> Co-authored-by: Piotr Orzechowski <piotr@orzechowski.tech> Co-authored-by: Rex_sa <rex.sa@pm.me> Co-authored-by: Tewuzij <tenajeza@outlook.com> Co-authored-by: goknarbahceli <goknarbahceli@proton.me> Co-authored-by: தமிழ்நேரம் <anishprabu.t@gmail.com> Co-authored-by: Erin <erin@erindesu.cz> Co-authored-by: EpicKiwi <me@epickiwi.fr> Co-authored-by: Christian Tietze <me@christiantietze.de> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
86 lines
2.1 KiB
Dart
86 lines
2.1 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_webrtc/flutter_webrtc.dart';
|
|
import 'package:matrix/matrix.dart';
|
|
|
|
class VideoRenderer extends StatefulWidget {
|
|
final WrappedMediaStream? stream;
|
|
final bool mirror;
|
|
final RTCVideoViewObjectFit fit;
|
|
|
|
const VideoRenderer(
|
|
this.stream, {
|
|
this.mirror = false,
|
|
this.fit = RTCVideoViewObjectFit.RTCVideoViewObjectFitContain,
|
|
super.key,
|
|
});
|
|
|
|
@override
|
|
State<StatefulWidget> createState() => _VideoRendererState();
|
|
}
|
|
|
|
class _VideoRendererState extends State<VideoRenderer> {
|
|
RTCVideoRenderer? _renderer;
|
|
bool _rendererReady = false;
|
|
MediaStream? get mediaStream => widget.stream?.stream;
|
|
StreamSubscription? _streamChangeSubscription;
|
|
|
|
Future<RTCVideoRenderer> _initializeRenderer() async {
|
|
_renderer ??= RTCVideoRenderer();
|
|
await _renderer!.initialize();
|
|
_renderer!.srcObject = mediaStream;
|
|
return _renderer!;
|
|
}
|
|
|
|
void disposeRenderer() {
|
|
try {
|
|
_renderer?.srcObject = null;
|
|
_renderer?.dispose();
|
|
_renderer = null;
|
|
// ignore: empty_catches
|
|
} catch (e) {}
|
|
}
|
|
|
|
@override
|
|
void initState() {
|
|
_streamChangeSubscription =
|
|
widget.stream?.onStreamChanged.stream.listen((stream) {
|
|
setState(() {
|
|
_renderer?.srcObject = stream;
|
|
});
|
|
});
|
|
setupRenderer();
|
|
super.initState();
|
|
}
|
|
|
|
Future<void> setupRenderer() async {
|
|
await _initializeRenderer();
|
|
setState(() => _rendererReady = true);
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
_streamChangeSubscription?.cancel();
|
|
disposeRenderer();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) => !_rendererReady
|
|
? Container()
|
|
: Builder(
|
|
key: widget.key,
|
|
builder: (ctx) {
|
|
return RTCVideoView(
|
|
_renderer!,
|
|
mirror: widget.mirror,
|
|
filterQuality: FilterQuality.medium,
|
|
objectFit: widget.fit,
|
|
placeholderBuilder: (_) =>
|
|
Container(color: Colors.white.withAlpha(45)),
|
|
);
|
|
},
|
|
);
|
|
}
|