Skip to content

Commit

Permalink
Merge pull request #202 from bitmovin/feature/enhance-casting-sample
Browse files Browse the repository at this point in the history
Add player info widget to Casting sample
  • Loading branch information
hawk23 authored Nov 29, 2024
2 parents 6614544 + a53b78c commit 5de7a2d
Showing 1 changed file with 26 additions and 10 deletions.
36 changes: 26 additions & 10 deletions example/lib/pages/casting.dart
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import 'package:bitmovin_player/bitmovin_player.dart';
import 'package:bitmovin_player_example/controls.dart';
import 'package:bitmovin_player_example/env/env.dart';
import 'package:bitmovin_player_example/platform.dart';
import 'package:bitmovin_player_example/player_info.dart';
import 'package:bitmovin_player_example/player_view_container.dart';
import 'package:flutter/material.dart';
import 'package:logger/logger.dart';
Expand Down Expand Up @@ -34,18 +35,20 @@ final SourceConfig _sourceConfig = isIOS
: const SourceConfig(url: artOfMotionDash, type: SourceType.dash);

class _CastingState extends State<Casting> {
factory _CastingState() {
final logger = Logger();
void eventListener(Event event) => _onEvent(logger, event);

return _CastingState._(createPlayerState(_sourceConfig, eventListener));
_CastingState() {
_playerState = createPlayerState(
_sourceConfig,
(Event event) {
_onEvent(logger, event);
},
);
}

_CastingState._(this._playerState);
final logger = Logger();
late final Future<_PlayerState> _playerState;
final _playerInfoKey = GlobalKey<PlayerInfoState>();

final Future<_PlayerState> _playerState;

static Future<_PlayerState> createPlayerState(
Future<_PlayerState> createPlayerState(
SourceConfig sourceConfig,
void Function(Event event) eventListener,
) async {
Expand Down Expand Up @@ -82,10 +85,17 @@ class _CastingState extends State<Casting> {
return _PlayerState(player, castManager);
}

static void _onEvent(
void _onEvent(
Logger logger,
Event event,
) {
_playerState.then(
(state) => _playerInfoKey.currentState?.updatePlayerInfo(
state.player,
event,
),
);

final eventName = '${event.runtimeType}';
final eventData = '$eventName ${event.toJson()}';
logger.d(eventData);
Expand Down Expand Up @@ -166,6 +176,12 @@ class _CastingState extends State<Casting> {
),
],
),
Expanded(
child: Container(
margin: const EdgeInsets.fromLTRB(10, 10, 10, 10),
child: PlayerInfo(key: _playerInfoKey),
),
),
],
);
}
Expand Down

0 comments on commit 5de7a2d

Please sign in to comment.