From 32f868a91c59f108f448c5405fd7d9365d5b2340 Mon Sep 17 00:00:00 2001 From: Tamius Han Date: Fri, 2 Nov 2018 21:41:26 +0100 Subject: [PATCH] Basic mode: when switching to full screen, restart ar detection proper --- js/lib/PlayerData.js | 7 ++----- js/lib/VideoData.js | 7 +++++++ 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/js/lib/PlayerData.js b/js/lib/PlayerData.js index 43f935c..71821ca 100644 --- a/js/lib/PlayerData.js +++ b/js/lib/PlayerData.js @@ -143,7 +143,7 @@ class PlayerData { if (this.checkFullscreenChange()) { if (PlayerData.isFullScreen()) { this.videoData.resizer.restore(); - this.videoData.startArDetection(); + this.videoData.rebootArDetection(); } else { const lastAr = this.videoData.resizer.getLastAr(); // save last ar for restore later this.videoData.resizer.reset(); @@ -159,7 +159,6 @@ class PlayerData { this.ghettoWatcherFull(); this.scheduleGhettoWatcher(); } else if (this.extensionMode === ExtensionMode.Basic) { - console.log("ghetto watcher basic mode - triggered") this.ghettoWatcherBasic(); this.scheduleGhettoWatcher(); } @@ -309,8 +308,6 @@ class PlayerData { checkFullscreenChange() { const isFs = PlayerData.isFullScreen(); - console.log("isFs:", isFs) - if (this.dimensions) { if (this.dimensions.fullscreen != isFs) { this.dimensions = { @@ -324,7 +321,7 @@ class PlayerData { } if(Debug.debug) { - console.log("[PlayerData::checkFullscreenChange] this.dimensions is not defined.") + console.log("[PlayerData::checkFullscreenChange] this.dimensions is not defined. Assuming fs change happened and setting default values.") } this.dimensions = { diff --git a/js/lib/VideoData.js b/js/lib/VideoData.js index 97bded4..3f2a60c 100644 --- a/js/lib/VideoData.js +++ b/js/lib/VideoData.js @@ -56,6 +56,13 @@ class VideoData { this.arDetector.start(); } + rebootArDetection() { + if(this.destroyed) { + throw {error: 'VIDEO_DATA_DESTROYED', data: {videoData: this}}; + } + this.arDetector.init(); + } + stopArDetection() { if (this.arDetector) { this.arDetector.stop();