/**
* @file big-play-button.js
* /
importieren Sie Button aus './button.js';
importiere Komponente aus './component.js';
importiere {isPromise, silencePromise} aus './utils/promise';
importiere * as browser aus './utils/browser.js';
/**
* Die anfängliche Wiedergabetaste, die angezeigt wird, bevor das Video abgespielt wurde. Das Verstecken der
* bigPlayButton" wird über CSS und den "Player"-Status realisiert.
*
* @erweitert Button
* /
class BigPlayButton extends Button {
constructor(spieler, optionen) {
super(Spieler, Optionen);
this.mouseused_ = false;
this.on('mousedown', (e) => this.handleMouseDown(e));
}
/**
* Erzeugt den Standard-DOM "Klassenname".
*
* @return {string}
* Der DOM `className` für dieses Objekt. Gibt immer „vjs-big-play-button“ zurück.
* /
buildCSSClass() {
return 'vjs-big-play-button';
}
/**
* Diese Funktion wird aufgerufen, wenn ein `BigPlayButton` "angeklickt" wird. Siehe {@link ClickableComponent}
* für genauere Informationen darüber, was ein Klick sein kann.
*
* @param {EventTarget~Event} event
* Das `Keydown`-, `Tap`- oder `Click`-Ereignis, das diese Funktion ausgelöst hat
* genannt.
*
* @listens tap
* @listens klicken
* /
handleClick(event) {
const playPromise = this.player_.play();
// vorzeitiges Beenden, wenn mit der Maus geklickt wird
if (this.mouseused_ && event.clientX && event.clientY) {
const sourceIsEncrypted = this.player_.usingPlugin('eme') &&
this.player_.eme.sessions &&
this.player_.eme.sessions.length > 0;
silencePromise(playPromise);
wenn (this.player_.tech(true) &&
// Wir haben einen Fehler in IE und Edge bei der Wiedergabe von DRM-Inhalten beobachtet, bei dem
// Der Aufruf von .focus() für das Videoelement führt dazu, dass das Video schwarz wird,
// also vermeiden wir es in diesem speziellen Fall
!((browser.IE_VERSION || browser.IS_EDGE) && sourceIsEncrypted)) {
this.player_.tech(true).focus();
}
rückkehr;
}
const cb = this.player_.getChild('controlBar');
const playToggle = cb && cb.getChild('playToggle');
if (!playToggle) {
this.player_.tech(true).focus();
rückkehr;
}
const playFocus = () => playToggle.focus();
if (isPromise(playPromise)) {
playPromise.then(playFocus, () => {});
} else {
this.setTimeout(playFocus, 1);
}
}
handleKeyDown(event) {
this.mouseused_ = false;
super.handleKeyDown(event);
}
handleMouseDown(event) {
this.mouseused_ = true;
}
}
/**
* Der Text, der über den Steuerelementen von "BigPlayButton" angezeigt werden soll. Zugefügt für die Lokalisierung.
*
* @Typ {String}
* @privat
* /
BigPlayButton.prototype.controlText_ = 'Video abspielen';
Component.registerComponent('BigPlayButton', BigPlayButton);
standard BigPlayButton exportieren;