sensible variable naming is important + remove redundant code
This commit is contained in:
parent
e12154601b
commit
0778f07922
@ -11,6 +11,7 @@ import Logger from '../Logger';
|
|||||||
import EventBus from '../EventBus';
|
import EventBus from '../EventBus';
|
||||||
import UI from '../uwui/UI';
|
import UI from '../uwui/UI';
|
||||||
import { SiteSettings } from '../settings/SiteSettings';
|
import { SiteSettings } from '../settings/SiteSettings';
|
||||||
|
import PageInfo from './PageInfo';
|
||||||
|
|
||||||
if (process.env.CHANNEL !== 'stable'){
|
if (process.env.CHANNEL !== 'stable'){
|
||||||
console.info("Loading: PlayerData.js");
|
console.info("Loading: PlayerData.js");
|
||||||
@ -42,13 +43,14 @@ class PlayerData {
|
|||||||
//#region helper objects
|
//#region helper objects
|
||||||
logger: Logger;
|
logger: Logger;
|
||||||
videoData: VideoData;
|
videoData: VideoData;
|
||||||
|
pageInfo: PageInfo;
|
||||||
siteSettings: SiteSettings;
|
siteSettings: SiteSettings;
|
||||||
notificationService: PlayerNotificationUi;
|
notificationService: PlayerNotificationUi;
|
||||||
eventBus: EventBus;
|
eventBus: EventBus;
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
//#region HTML objects
|
//#region HTML objects
|
||||||
video: any;
|
videoElement: any;
|
||||||
element: any;
|
element: any;
|
||||||
overlayNode: any;
|
overlayNode: any;
|
||||||
//#endregion
|
//#endregion
|
||||||
@ -102,13 +104,18 @@ class PlayerData {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//#region lifecycle
|
||||||
constructor(videoData) {
|
constructor(videoData) {
|
||||||
try {
|
try {
|
||||||
|
// set all our helper objects
|
||||||
this.logger = videoData.logger;
|
this.logger = videoData.logger;
|
||||||
this.videoData = videoData;
|
this.videoData = videoData;
|
||||||
this.video = videoData.video;
|
this.videoElement = videoData.video;
|
||||||
|
this.pageInfo = videoData.pageInfo;
|
||||||
this.siteSettings = videoData.siteSettings;
|
this.siteSettings = videoData.siteSettings;
|
||||||
this.eventBus = videoData.eventBus;
|
this.eventBus = videoData.eventBus;
|
||||||
|
|
||||||
|
// do the rest
|
||||||
this.invalid = false;
|
this.invalid = false;
|
||||||
this.element = this.getPlayer();
|
this.element = this.getPlayer();
|
||||||
this.initEventBus();
|
this.initEventBus();
|
||||||
@ -136,7 +143,6 @@ class PlayerData {
|
|||||||
|
|
||||||
this.trackDimensionChanges();
|
this.trackDimensionChanges();
|
||||||
this.startChangeDetection();
|
this.startChangeDetection();
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error('[Ultrawidify::PlayerData::ctor] There was an error setting up player data. You should be never seeing this message. Error:', e);
|
console.error('[Ultrawidify::PlayerData::ctor] There was an error setting up player data. You should be never seeing this message. Error:', e);
|
||||||
this.invalid = true;
|
this.invalid = true;
|
||||||
@ -151,6 +157,38 @@ class PlayerData {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
destroy() {
|
||||||
|
this.stopChangeDetection();
|
||||||
|
this.destroyOverlay();
|
||||||
|
this.notificationService?.destroy();
|
||||||
|
}
|
||||||
|
//#endregion
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enables ultrawidify for this video by adding the relevant classes
|
||||||
|
* to the video and player element.
|
||||||
|
*/
|
||||||
|
enable() {
|
||||||
|
this.enabled = true;
|
||||||
|
this.element.classList.add(this.playerCssClass);
|
||||||
|
this.startChangeDetection();
|
||||||
|
this.videoData.enable({fromPlayer: true});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disables ultrawidify for this video by removing the relevant classes
|
||||||
|
* from the video and player elements.
|
||||||
|
*
|
||||||
|
* NOTE: it is very important to keep change detection active while disabled,
|
||||||
|
* because otherwise ultrawidify will otherwise remain inactive after
|
||||||
|
* switching (back to) full screen.
|
||||||
|
*/
|
||||||
|
disable() {
|
||||||
|
this.enabled = false;
|
||||||
|
this.element.classList.remove(this.playerCssClass);
|
||||||
|
this.videoData.disable({fromPlayer: true});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Detects whether player element is in theater mode or not.
|
* Detects whether player element is in theater mode or not.
|
||||||
* If theater mode changed, emits event.
|
* If theater mode changed, emits event.
|
||||||
@ -272,42 +310,12 @@ class PlayerData {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Enables ultrawidify for this video by adding the relevant classes
|
|
||||||
* to the video and player element.
|
|
||||||
*/
|
|
||||||
enable() {
|
|
||||||
this.enabled = true;
|
|
||||||
this.element.classList.add(this.playerCssClass);
|
|
||||||
this.startChangeDetection();
|
|
||||||
this.videoData.enable({fromPlayer: true});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Disables ultrawidify for this video by removing the relevant classes
|
|
||||||
* from the video and player elements.
|
|
||||||
*
|
|
||||||
* NOTE: it is very important to keep change detection active while disabled,
|
|
||||||
* because otherwise ultrawidify will otherwise remain inactive after
|
|
||||||
* switching (back to) full screen.
|
|
||||||
*/
|
|
||||||
disable() {
|
|
||||||
this.enabled = false;
|
|
||||||
this.element.classList.remove(this.playerCssClass);
|
|
||||||
this.videoData.disable({fromPlayer: true});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
onPlayerDimensionsChanged(mutationList?, observer?) {
|
onPlayerDimensionsChanged(mutationList?, observer?) {
|
||||||
this.trackDimensionChanges();
|
this.trackDimensionChanges();
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy() {
|
|
||||||
this.stopChangeDetection();
|
|
||||||
this.destroyOverlay();
|
|
||||||
this.notificationService?.destroy();
|
|
||||||
}
|
|
||||||
|
|
||||||
//#region player element change detection
|
//#region player element change detection
|
||||||
startChangeDetection(){
|
startChangeDetection(){
|
||||||
if (this.invalid) {
|
if (this.invalid) {
|
||||||
@ -451,17 +459,17 @@ class PlayerData {
|
|||||||
*/
|
*/
|
||||||
getPlayer(options?: {verbose?: boolean}) {
|
getPlayer(options?: {verbose?: boolean}) {
|
||||||
const host = window.location.hostname;
|
const host = window.location.hostname;
|
||||||
let element = this.video.parentNode;
|
let element = this.videoElement.parentNode;
|
||||||
const videoWidth = this.video.offsetWidth;
|
const videoWidth = this.videoElement.offsetWidth;
|
||||||
const videoHeight = this.video.offsetHeight;
|
const videoHeight = this.videoElement.offsetHeight;
|
||||||
let playerCandidate;
|
let playerCandidate;
|
||||||
|
|
||||||
const elementStack: any[] = [{
|
const elementStack: any[] = [{
|
||||||
element: this.video,
|
element: this.videoElement,
|
||||||
type: 'video',
|
type: 'video',
|
||||||
tagName: 'video',
|
tagName: 'video',
|
||||||
classList: this.video.classList,
|
classList: this.videoElement.classList,
|
||||||
id: this.video.id,
|
id: this.videoElement.id,
|
||||||
}];
|
}];
|
||||||
|
|
||||||
// first pass to generate the element stack and translate it into array
|
// first pass to generate the element stack and translate it into array
|
||||||
@ -667,10 +675,6 @@ class PlayerData {
|
|||||||
// this.notificationService?.replace(this.element);
|
// this.notificationService?.replace(this.element);
|
||||||
this.trackDimensionChanges();
|
this.trackDimensionChanges();
|
||||||
}
|
}
|
||||||
|
|
||||||
showNotification(notificationId) {
|
|
||||||
// this.notificationService?.showNotification(notificationId);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.CHANNEL !== 'stable'){
|
if (process.env.CHANNEL !== 'stable'){
|
||||||
|
@ -36,7 +36,7 @@ class Resizer {
|
|||||||
scaler: Scaler;
|
scaler: Scaler;
|
||||||
stretcher: Stretcher;
|
stretcher: Stretcher;
|
||||||
zoom: Zoom;
|
zoom: Zoom;
|
||||||
conf: VideoData;
|
videoData: VideoData;
|
||||||
eventBus: EventBus;
|
eventBus: EventBus;
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ class Resizer {
|
|||||||
|
|
||||||
constructor(videoData) {
|
constructor(videoData) {
|
||||||
this.resizerId = (Math.random()*100).toFixed(0);
|
this.resizerId = (Math.random()*100).toFixed(0);
|
||||||
this.conf = videoData;
|
this.videoData = videoData;
|
||||||
this.logger = videoData.logger;
|
this.logger = videoData.logger;
|
||||||
this.video = videoData.video;
|
this.video = videoData.video;
|
||||||
this.settings = videoData.settings;
|
this.settings = videoData.settings;
|
||||||
@ -126,9 +126,9 @@ class Resizer {
|
|||||||
this.eventBus = videoData.eventBus;
|
this.eventBus = videoData.eventBus;
|
||||||
this.initEventBus();
|
this.initEventBus();
|
||||||
|
|
||||||
this.scaler = new Scaler(this.conf);
|
this.scaler = new Scaler(this.videoData);
|
||||||
this.stretcher = new Stretcher(this.conf);
|
this.stretcher = new Stretcher(this.videoData);
|
||||||
this.zoom = new Zoom(this.conf);
|
this.zoom = new Zoom(this.videoData);
|
||||||
|
|
||||||
this.videoAlignment = this.siteSettings.getDefaultOption('alignment') as {x: VideoAlignmentType, y: VideoAlignmentType} // this is initial video alignment
|
this.videoAlignment = this.siteSettings.getDefaultOption('alignment') as {x: VideoAlignmentType, y: VideoAlignmentType} // this is initial video alignment
|
||||||
|
|
||||||
@ -186,24 +186,24 @@ class Resizer {
|
|||||||
// handles "legacy" options, such as 'fit to widht', 'fit to height' and AspectRatioType.Reset. No zoom tho
|
// handles "legacy" options, such as 'fit to widht', 'fit to height' and AspectRatioType.Reset. No zoom tho
|
||||||
let ratioOut;
|
let ratioOut;
|
||||||
|
|
||||||
if (!this.conf.video) {
|
if (!this.videoData.video) {
|
||||||
this.logger.log('info', 'debug', "[Scaler.js::modeToAr] No video??",this.conf.video, "killing videoData");
|
this.logger.log('info', 'debug', "[Scaler.js::modeToAr] No video??",this.videoData.video, "killing videoData");
|
||||||
this.conf.destroy();
|
this.videoData.destroy();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (! this.conf.player.dimensions) {
|
if (! this.videoData.player.dimensions) {
|
||||||
ratioOut = screen.width / screen.height;
|
ratioOut = screen.width / screen.height;
|
||||||
} else {
|
} else {
|
||||||
this.logger.log('info', 'debug', `[Resizer::calculateRatioForLegacyOptions] <rid:${this.resizerId}> Player dimensions:`, this.conf.player.dimensions.width ,'x', this.conf.player.dimensions.height,'aspect ratio:', this.conf.player.dimensions.width / this.conf.player.dimensions.height)
|
this.logger.log('info', 'debug', `[Resizer::calculateRatioForLegacyOptions] <rid:${this.resizerId}> Player dimensions:`, this.videoData.player.dimensions.width ,'x', this.videoData.player.dimensions.height,'aspect ratio:', this.videoData.player.dimensions.width / this.videoData.player.dimensions.height)
|
||||||
ratioOut = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
|
ratioOut = this.videoData.player.dimensions.width / this.videoData.player.dimensions.height;
|
||||||
}
|
}
|
||||||
|
|
||||||
// IMPORTANT NOTE: lastAr needs to be set after _res_setAr() is called, as _res_setAr() assumes we're
|
// IMPORTANT NOTE: lastAr needs to be set after _res_setAr() is called, as _res_setAr() assumes we're
|
||||||
// setting a static aspect ratio (even if the function is called from here or ArDetect).
|
// setting a static aspect ratio (even if the function is called from here or ArDetect).
|
||||||
|
|
||||||
let fileAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
|
let fileAr = this.videoData.video.videoWidth / this.videoData.video.videoHeight;
|
||||||
|
|
||||||
if (ar.type === AspectRatioType.FitWidth){
|
if (ar.type === AspectRatioType.FitWidth){
|
||||||
ar.ratio = ratioOut > fileAr ? ratioOut : fileAr;
|
ar.ratio = ratioOut > fileAr ? ratioOut : fileAr;
|
||||||
@ -247,10 +247,10 @@ class Resizer {
|
|||||||
|
|
||||||
// handle autodetection stuff
|
// handle autodetection stuff
|
||||||
if (ar.type === AspectRatioType.Automatic) {
|
if (ar.type === AspectRatioType.Automatic) {
|
||||||
this.conf.arDetector?.start();
|
this.videoData.arDetector?.start();
|
||||||
return;
|
return;
|
||||||
} else if (ar.type !== AspectRatioType.AutomaticUpdate) {
|
} else if (ar.type !== AspectRatioType.AutomaticUpdate) {
|
||||||
this.conf.arDetector?.stop();
|
this.videoData.arDetector?.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
// unless we're trying to reset aspect ratio, we need to tell VideoData that this would
|
// unless we're trying to reset aspect ratio, we need to tell VideoData that this would
|
||||||
@ -258,7 +258,7 @@ class Resizer {
|
|||||||
//
|
//
|
||||||
// CSS, et. al. initialization is deferred in order to avoid breaking wonky sites by default.
|
// CSS, et. al. initialization is deferred in order to avoid breaking wonky sites by default.
|
||||||
if (ar.type !== AspectRatioType.Reset && ar.type !== AspectRatioType.Initial) {
|
if (ar.type !== AspectRatioType.Reset && ar.type !== AspectRatioType.Initial) {
|
||||||
await this.conf.preparePage();
|
await this.videoData.preparePage();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ar.type !== AspectRatioType.AutomaticUpdate) {
|
if (ar.type !== AspectRatioType.AutomaticUpdate) {
|
||||||
@ -267,7 +267,7 @@ class Resizer {
|
|||||||
|
|
||||||
if (!this.video.videoWidth || !this.video.videoHeight) {
|
if (!this.video.videoWidth || !this.video.videoHeight) {
|
||||||
this.logger.log('warning', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> Video has no width or no height. This is not allowed. Aspect ratio will not be set, and videoData will be uninitialized.');
|
this.logger.log('warning', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> Video has no width or no height. This is not allowed. Aspect ratio will not be set, and videoData will be uninitialized.');
|
||||||
this.conf.videoUnloaded();
|
this.videoData.videoUnloaded();
|
||||||
}
|
}
|
||||||
|
|
||||||
this.logger.log('info', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar);
|
this.logger.log('info', 'debug', '[Resizer::setAr] <rid:'+this.resizerId+'> trying to set ar. New ar:', ar);
|
||||||
@ -296,11 +296,12 @@ class Resizer {
|
|||||||
// is handled in pageInfo.updateCurrentCrop(), which also makes sure to persist aspect ratio if ar
|
// is handled in pageInfo.updateCurrentCrop(), which also makes sure to persist aspect ratio if ar
|
||||||
// is set to persist between videos / through current session / until manual reset.
|
// is set to persist between videos / through current session / until manual reset.
|
||||||
if (ar.type === AspectRatioType.Reset ||
|
if (ar.type === AspectRatioType.Reset ||
|
||||||
ar.type === AspectRatioType.Initial ) {
|
ar.type === AspectRatioType.Initial
|
||||||
|
) {
|
||||||
// reset/undo default
|
// reset/undo default
|
||||||
this.conf.pageInfo.updateCurrentCrop(undefined);
|
this.videoData.pageInfo.updateCurrentCrop(undefined);
|
||||||
} else {
|
} else {
|
||||||
this.conf.pageInfo.updateCurrentCrop(ar);
|
this.videoData.pageInfo.updateCurrentCrop(ar);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lastAr) {
|
if (lastAr) {
|
||||||
@ -318,7 +319,7 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (! this.video) {
|
if (! this.video) {
|
||||||
this.conf.destroy();
|
this.videoData.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
// pause AR on:
|
// pause AR on:
|
||||||
@ -327,24 +328,25 @@ class Resizer {
|
|||||||
//
|
//
|
||||||
// unpause when using other modes
|
// unpause when using other modes
|
||||||
if (ar.type !== AspectRatioType.Automatic || this.stretcher.mode === StretchType.Basic) {
|
if (ar.type !== AspectRatioType.Automatic || this.stretcher.mode === StretchType.Basic) {
|
||||||
this.conf?.arDetector?.pause();
|
this.videoData?.arDetector?.pause();
|
||||||
} else {
|
} else {
|
||||||
if (this.lastAr.type === AspectRatioType.Automatic) {
|
if (this.lastAr.type === AspectRatioType.Automatic) {
|
||||||
this.conf?.arDetector?.unpause();
|
this.videoData?.arDetector?.unpause();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// do stretch thingy
|
// do stretch thingy
|
||||||
if (this.stretcher.mode === StretchType.NoStretch
|
if (this.stretcher.mode === StretchType.NoStretch
|
||||||
|| this.stretcher.mode === StretchType.Conditional
|
|| this.stretcher.mode === StretchType.Conditional
|
||||||
|| this.stretcher.mode === StretchType.FixedSource){
|
|| this.stretcher.mode === StretchType.FixedSource
|
||||||
|
){
|
||||||
|
|
||||||
stretchFactors = this.scaler.calculateCrop(ar);
|
stretchFactors = this.scaler.calculateCrop(ar);
|
||||||
|
|
||||||
if(! stretchFactors || stretchFactors.error){
|
if(! stretchFactors || stretchFactors.error){
|
||||||
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, stretchFactors?.error);
|
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, stretchFactors?.error);
|
||||||
if (stretchFactors?.error === 'no_video'){
|
if (stretchFactors?.error === 'no_video'){
|
||||||
this.conf.destroy();
|
this.videoData.destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -353,7 +355,7 @@ class Resizer {
|
|||||||
// of the two means video is loaded or playing, and that means video has proper dimensions), it will
|
// of the two means video is loaded or playing, and that means video has proper dimensions), it will
|
||||||
// try to reset or re-apply aspect ratio when the video is finally ready.
|
// try to reset or re-apply aspect ratio when the video is finally ready.
|
||||||
if (stretchFactors?.error === 'illegal_video_dimensions') {
|
if (stretchFactors?.error === 'illegal_video_dimensions') {
|
||||||
this.conf.videoDimensionsLoaded = false;
|
this.videoData.videoDimensionsLoaded = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -395,7 +397,7 @@ class Resizer {
|
|||||||
|
|
||||||
// let the UI know
|
// let the UI know
|
||||||
if(!options?.noAnnounce) {
|
if(!options?.noAnnounce) {
|
||||||
this.conf.eventBus.send('announce-zoom', {x: stretchFactors.xFactor, y: stretchFactors.yFactor});
|
this.videoData.eventBus.send('announce-zoom', {x: stretchFactors.xFactor, y: stretchFactors.yFactor});
|
||||||
}
|
}
|
||||||
|
|
||||||
let translate = this.computeOffsets(stretchFactors);
|
let translate = this.computeOffsets(stretchFactors);
|
||||||
@ -422,7 +424,7 @@ class Resizer {
|
|||||||
|
|
||||||
panHandler(event, forcePan) {
|
panHandler(event, forcePan) {
|
||||||
if (this.canPan || forcePan) {
|
if (this.canPan || forcePan) {
|
||||||
if(!this.conf.player || !this.conf.player.element) {
|
if(!this.videoData.player || !this.videoData.player.element) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// dont allow weird floats
|
// dont allow weird floats
|
||||||
@ -433,7 +435,7 @@ class Resizer {
|
|||||||
this.toFixedAr();
|
this.toFixedAr();
|
||||||
}
|
}
|
||||||
|
|
||||||
const player = this.conf.player.element;
|
const player = this.videoData.player.element;
|
||||||
|
|
||||||
const relativeX = (event.pageX - player.offsetLeft) / player.offsetWidth;
|
const relativeX = (event.pageX - player.offsetLeft) / player.offsetWidth;
|
||||||
const relativeY = (event.pageY - player.offsetTop) / player.offsetHeight;
|
const relativeY = (event.pageY - player.offsetTop) / player.offsetHeight;
|
||||||
@ -563,11 +565,11 @@ class Resizer {
|
|||||||
* We make the assumption of the
|
* We make the assumption of the
|
||||||
*/
|
*/
|
||||||
computeVideoDisplayedDimensions() {
|
computeVideoDisplayedDimensions() {
|
||||||
const offsetWidth = this.conf.video.offsetWidth;
|
const offsetWidth = this.videoData.video.offsetWidth;
|
||||||
const offsetHeight = this.conf.video.offsetHeight;
|
const offsetHeight = this.videoData.video.offsetHeight;
|
||||||
|
|
||||||
const scaleX = offsetWidth / this.conf.video.videoWidth;
|
const scaleX = offsetWidth / this.videoData.video.videoWidth;
|
||||||
const scaleY = offsetHeight / this.conf.video.videoHeight;
|
const scaleY = offsetHeight / this.videoData.video.videoHeight;
|
||||||
|
|
||||||
// if differences between the scale factors are minimal, we presume offsetWidth and
|
// if differences between the scale factors are minimal, we presume offsetWidth and
|
||||||
// offsetHeight are the accurate enough for our needs
|
// offsetHeight are the accurate enough for our needs
|
||||||
@ -581,13 +583,13 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if we're still here, we need to calculate real video dimensions
|
// if we're still here, we need to calculate real video dimensions
|
||||||
const diffX = Math.abs(scaleY * this.conf.video.videoWidth - offsetWidth);
|
const diffX = Math.abs(scaleY * this.videoData.video.videoWidth - offsetWidth);
|
||||||
const diffY = Math.abs(scaleX * this.conf.video.videoHeight - offsetHeight);
|
const diffY = Math.abs(scaleX * this.videoData.video.videoHeight - offsetHeight);
|
||||||
|
|
||||||
// in this case, we want to base our real dimensions off scaleX
|
// in this case, we want to base our real dimensions off scaleX
|
||||||
// otherwise, we want to base it off scaleY
|
// otherwise, we want to base it off scaleY
|
||||||
if (diffX < diffY) {
|
if (diffX < diffY) {
|
||||||
const realHeight = this.conf.video.videoHeight * scaleX;
|
const realHeight = this.videoData.video.videoHeight * scaleX;
|
||||||
return {
|
return {
|
||||||
realVideoWidth: offsetWidth,
|
realVideoWidth: offsetWidth,
|
||||||
realVideoHeight: realHeight,
|
realVideoHeight: realHeight,
|
||||||
@ -595,7 +597,7 @@ class Resizer {
|
|||||||
marginY: (offsetHeight - realHeight) * 0.5
|
marginY: (offsetHeight - realHeight) * 0.5
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
const realWidth = this.conf.video.videoWidth * scaleY;
|
const realWidth = this.videoData.video.videoWidth * scaleY;
|
||||||
return {
|
return {
|
||||||
realVideoWidth: realWidth,
|
realVideoWidth: realWidth,
|
||||||
realVideoHeight: offsetHeight,
|
realVideoHeight: offsetHeight,
|
||||||
@ -608,8 +610,8 @@ class Resizer {
|
|||||||
computeCroppedAreas(stretchFactors) {
|
computeCroppedAreas(stretchFactors) {
|
||||||
// PSA: offsetWidth and offsetHeight DO NOT INCLUDE
|
// PSA: offsetWidth and offsetHeight DO NOT INCLUDE
|
||||||
// ZOOM APPLIED THROUGH THE MAGIC OF CSS TRANSFORMS
|
// ZOOM APPLIED THROUGH THE MAGIC OF CSS TRANSFORMS
|
||||||
const sourceWidth = this.conf.video.offsetWidth;
|
const sourceWidth = this.videoData.video.offsetWidth;
|
||||||
const sourceHeight = this.conf.video.offsetHeight;
|
const sourceHeight = this.videoData.video.offsetHeight;
|
||||||
|
|
||||||
// this is the size of the video AFTER zooming was applied but does
|
// this is the size of the video AFTER zooming was applied but does
|
||||||
// not account for cropping. It may be bigger than the player in
|
// not account for cropping. It may be bigger than the player in
|
||||||
@ -618,8 +620,8 @@ class Resizer {
|
|||||||
const postZoomHeight = sourceHeight * stretchFactors.yFactor;
|
const postZoomHeight = sourceHeight * stretchFactors.yFactor;
|
||||||
|
|
||||||
// this is the size of the video after crop is applied
|
// this is the size of the video after crop is applied
|
||||||
const displayedWidth = Math.min(this.conf.player.dimensions.width, postZoomWidth);
|
const displayedWidth = Math.min(this.videoData.player.dimensions.width, postZoomWidth);
|
||||||
const displayedHeight = Math.min(this.conf.player.dimensions.height, postZoomHeight);
|
const displayedHeight = Math.min(this.videoData.player.dimensions.height, postZoomHeight);
|
||||||
|
|
||||||
// these two are cropped areas. Negative values mean additional
|
// these two are cropped areas. Negative values mean additional
|
||||||
// letterboxing or pillarboxing. We assume center alignment for
|
// letterboxing or pillarboxing. We assume center alignment for
|
||||||
@ -678,19 +680,19 @@ class Resizer {
|
|||||||
stretchFactors.cropStrategy === CropStrategy.CropLetterbox
|
stretchFactors.cropStrategy === CropStrategy.CropLetterbox
|
||||||
&& (!stretchFactors.styleHeightCompensationFactor || stretchFactors.styleHeightCompensationFactor === 1)
|
&& (!stretchFactors.styleHeightCompensationFactor || stretchFactors.styleHeightCompensationFactor === 1)
|
||||||
) {
|
) {
|
||||||
autoHeightCompensationFactor = this.computeAutoHeightCompensationFactor(realVideoWidth, realVideoHeight, this.conf.player.dimensions.width, this.conf.player.dimensions.height, 'height');
|
autoHeightCompensationFactor = this.computeAutoHeightCompensationFactor(realVideoWidth, realVideoHeight, this.videoData.player.dimensions.width, this.videoData.player.dimensions.height, 'height');
|
||||||
stretchFactors.xFactor *= autoHeightCompensationFactor;
|
stretchFactors.xFactor *= autoHeightCompensationFactor;
|
||||||
stretchFactors.yFactor *= autoHeightCompensationFactor;
|
stretchFactors.yFactor *= autoHeightCompensationFactor;
|
||||||
}
|
}
|
||||||
|
|
||||||
const offsetWidth = this.conf.video.offsetWidth;
|
const offsetWidth = this.videoData.video.offsetWidth;
|
||||||
const offsetHeight = this.conf.video.offsetHeight;
|
const offsetHeight = this.videoData.video.offsetHeight;
|
||||||
|
|
||||||
const wdiff = this.conf.player.dimensions.width - realVideoWidth;
|
const wdiff = this.videoData.player.dimensions.width - realVideoWidth;
|
||||||
const hdiff = this.conf.player.dimensions.height - realVideoHeight;
|
const hdiff = this.videoData.player.dimensions.height - realVideoHeight;
|
||||||
|
|
||||||
const wdiffAfterZoom = realVideoWidth * stretchFactors.xFactor - this.conf.player.dimensions.width;
|
const wdiffAfterZoom = realVideoWidth * stretchFactors.xFactor - this.videoData.player.dimensions.width;
|
||||||
const hdiffAfterZoom = realVideoHeight * stretchFactors.yFactor - this.conf.player.dimensions.height;
|
const hdiffAfterZoom = realVideoHeight * stretchFactors.yFactor - this.videoData.player.dimensions.height;
|
||||||
|
|
||||||
const translate = {
|
const translate = {
|
||||||
x: wdiff * 0.5,
|
x: wdiff * 0.5,
|
||||||
@ -725,11 +727,11 @@ class Resizer {
|
|||||||
this.logger.log(
|
this.logger.log(
|
||||||
'info', ['debug', 'resizer'], "[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:",
|
'info', ['debug', 'resizer'], "[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:",
|
||||||
'\n\n---- elements ----',
|
'\n\n---- elements ----',
|
||||||
'\nplayer element: ', this.conf.player.element,
|
'\nplayer element: ', this.videoData.player.element,
|
||||||
'\nvideo element: ', this.conf.video,
|
'\nvideo element: ', this.videoData.video,
|
||||||
'\n\n---- data in ----',
|
'\n\n---- data in ----',
|
||||||
'\nplayer dimensions: ', {w: this.conf.player.dimensions.width, h: this.conf.player.dimensions.height},
|
'\nplayer dimensions: ', {w: this.videoData.player.dimensions.width, h: this.videoData.player.dimensions.height},
|
||||||
'\nvideo dimensions: ', {w: this.conf.video.offsetWidth, h: this.conf.video.offsetHeight},
|
'\nvideo dimensions: ', {w: this.videoData.video.offsetWidth, h: this.videoData.video.offsetHeight},
|
||||||
'\nreal video dimensions:', {w: realVideoWidth, h: realVideoHeight},
|
'\nreal video dimensions:', {w: realVideoWidth, h: realVideoHeight},
|
||||||
'\nauto compensation: ', 'x', autoHeightCompensationFactor,
|
'\nauto compensation: ', 'x', autoHeightCompensationFactor,
|
||||||
'\nstretch factors: ', stretchFactors,
|
'\nstretch factors: ', stretchFactors,
|
||||||
@ -750,8 +752,8 @@ class Resizer {
|
|||||||
// conditions are true at the same time, we need to go 'chiny reckon' and recheck our player
|
// conditions are true at the same time, we need to go 'chiny reckon' and recheck our player
|
||||||
// element. Chances are our video is not getting aligned correctly
|
// element. Chances are our video is not getting aligned correctly
|
||||||
if (
|
if (
|
||||||
(this.conf.video.offsetWidth > this.conf.player.dimensions.width && this.conf.video.offsetHeight > this.conf.player.dimensions.height) ||
|
(this.videoData.video.offsetWidth > this.videoData.player.dimensions.width && this.videoData.video.offsetHeight > this.videoData.player.dimensions.height) ||
|
||||||
(this.conf.video.offsetWidth < this.conf.player.dimensions.width && this.conf.video.offsetHeight < this.conf.player.dimensions.height)
|
(this.videoData.video.offsetWidth < this.videoData.player.dimensions.width && this.videoData.video.offsetHeight < this.videoData.player.dimensions.height)
|
||||||
) {
|
) {
|
||||||
this.logger.log('warn', ['debugger', 'resizer'], `[Resizer::_res_computeOffsets] <rid:${this.resizerId}> We are getting some incredibly funny results here.\n\n`,
|
this.logger.log('warn', ['debugger', 'resizer'], `[Resizer::_res_computeOffsets] <rid:${this.resizerId}> We are getting some incredibly funny results here.\n\n`,
|
||||||
`Video seems to be both wider and taller (or shorter and narrower) than player element at the same time. This is super duper not supposed to happen.\n\n`,
|
`Video seems to be both wider and taller (or shorter and narrower) than player element at the same time. This is super duper not supposed to happen.\n\n`,
|
||||||
@ -762,7 +764,7 @@ class Resizer {
|
|||||||
// There seems to be no way to reproduce it.
|
// There seems to be no way to reproduce it.
|
||||||
if (! this._computeOffsetsRecursionGuard) {
|
if (! this._computeOffsetsRecursionGuard) {
|
||||||
this._computeOffsetsRecursionGuard = true;
|
this._computeOffsetsRecursionGuard = true;
|
||||||
this.conf.player.trackDimensionChanges();
|
this.videoData.player.trackDimensionChanges();
|
||||||
this._computeOffsetsRecursionGuard = false;
|
this._computeOffsetsRecursionGuard = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -832,7 +834,7 @@ class Resizer {
|
|||||||
if (! this.video) {
|
if (! this.video) {
|
||||||
this.logger.log('warn', 'debug', "[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
|
this.logger.log('warn', 'debug', "[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
|
||||||
|
|
||||||
this.conf.destroy();
|
this.videoData.destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -840,7 +842,7 @@ class Resizer {
|
|||||||
|
|
||||||
// save stuff for quick tests (before we turn numbers into css values):
|
// save stuff for quick tests (before we turn numbers into css values):
|
||||||
this.currentVideoSettings = {
|
this.currentVideoSettings = {
|
||||||
validFor: this.conf.player.dimensions,
|
validFor: this.videoData.player.dimensions,
|
||||||
// videoWidth: dimensions.width,
|
// videoWidth: dimensions.width,
|
||||||
// videoHeight: dimensions.height
|
// videoHeight: dimensions.height
|
||||||
}
|
}
|
||||||
@ -876,7 +878,7 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setStyleString (styleString) {
|
setStyleString (styleString) {
|
||||||
this.currentCssValidFor = this.conf.player.dimensions;
|
this.currentCssValidFor = this.videoData.player.dimensions;
|
||||||
const newCssString = this.prepareCss(styleString);
|
const newCssString = this.prepareCss(styleString);
|
||||||
|
|
||||||
// inject new CSS or replace existing one
|
// inject new CSS or replace existing one
|
||||||
|
Loading…
Reference in New Issue
Block a user