mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-19 03:48:18 -07:00
165 lines
3.8 KiB
JavaScript
165 lines
3.8 KiB
JavaScript
(function () {
|
|
|
|
function vlcRenderer(type) {
|
|
|
|
var self = this;
|
|
|
|
function onEnded() {
|
|
$(self).trigger('ended');
|
|
}
|
|
|
|
function onTimeUpdate() {
|
|
$(self).trigger('timeupdate');
|
|
}
|
|
|
|
function onVolumeChange() {
|
|
$(self).trigger('volumechange');
|
|
}
|
|
|
|
function onPlaying() {
|
|
$(self).trigger('playing');
|
|
}
|
|
|
|
function onPlay() {
|
|
$(self).trigger('play');
|
|
}
|
|
|
|
function onPause() {
|
|
$(self).trigger('pause');
|
|
}
|
|
|
|
function onClick() {
|
|
$(self).trigger('click');
|
|
}
|
|
|
|
function onDblClick() {
|
|
$(self).trigger('dblclick');
|
|
}
|
|
|
|
function onError() {
|
|
|
|
var errorCode = this.error ? this.error.code : '';
|
|
console.log('Media element error code: ' + errorCode);
|
|
|
|
$(self).trigger('error');
|
|
}
|
|
|
|
var playerState = {};
|
|
|
|
self.currentTime = function (val) {
|
|
|
|
if (val != null) {
|
|
AndroidVlcPlayer.sendVlcCommand("setposition", val.toString());
|
|
return;
|
|
}
|
|
|
|
return playerState.currentTime;
|
|
};
|
|
|
|
self.duration = function (val) {
|
|
|
|
if (playerState) {
|
|
return playerState.duration;
|
|
}
|
|
|
|
return null;
|
|
};
|
|
|
|
self.stop = function () {
|
|
AndroidVlcPlayer.sendVlcCommand("stop", null);
|
|
};
|
|
|
|
self.pause = function () {
|
|
AndroidVlcPlayer.sendVlcCommand("pause", null);
|
|
};
|
|
|
|
self.unpause = function () {
|
|
AndroidVlcPlayer.sendVlcCommand("unpause", null);
|
|
};
|
|
|
|
self.volume = function (val) {
|
|
if (playerState) {
|
|
if (val != null) {
|
|
AndroidVlcPlayer.sendVlcCommand("setvolume", (val * 100).toString());
|
|
return;
|
|
}
|
|
|
|
return playerState.volume;
|
|
}
|
|
};
|
|
|
|
self.setCurrentSrc = function (val) {
|
|
|
|
if (!val) {
|
|
self.destroy();
|
|
return;
|
|
}
|
|
|
|
if (type == 'audio') {
|
|
AndroidVlcPlayer.playAudioVlc(val);
|
|
} else {
|
|
AndroidVlcPlayer.playVideoVlc(val);
|
|
}
|
|
|
|
playerState.currentSrc = val;
|
|
};
|
|
|
|
self.currentSrc = function () {
|
|
if (playerState) {
|
|
return playerState.currentSrc;
|
|
}
|
|
};
|
|
|
|
self.paused = function () {
|
|
|
|
if (playerState) {
|
|
return playerState.paused;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
self.destroy = function () {
|
|
|
|
AndroidVlcPlayer.destroyVlc();
|
|
playerState = {};
|
|
};
|
|
|
|
self.setPoster = function (url) {
|
|
};
|
|
|
|
self.report = function (eventName, duration, position, isPaused, volume) {
|
|
|
|
var state = playerState;
|
|
console.log('Vlc: ' + eventName + ' - ' + position + ' - ' + duration);
|
|
state.duration = duration;
|
|
state.currentTime = position;
|
|
state.isPaused = isPaused;
|
|
state.volume = (volume || 0) / 100;
|
|
|
|
if (eventName == 'playbackstop') {
|
|
onEnded();
|
|
}
|
|
else if (eventName == 'volumechange') {
|
|
onVolumeChange();
|
|
}
|
|
else if (eventName == 'positionchange') {
|
|
onTimeUpdate();
|
|
}
|
|
else if (eventName == 'paused') {
|
|
onPause();
|
|
}
|
|
else if (eventName == 'unpaused') {
|
|
onPlaying();
|
|
}
|
|
else if (eventName == 'playing') {
|
|
onPlaying();
|
|
}
|
|
};
|
|
|
|
window.AudioRenderer.Current = self;
|
|
}
|
|
|
|
window.AudioRenderer = vlcRenderer;
|
|
|
|
})(); |