1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00

stop button in video player instead of now playing bar

This commit is contained in:
Techywarrior 2013-03-28 19:56:56 -07:00
parent 6761d5c3c9
commit 034a4c04b8
4 changed files with 93 additions and 24 deletions

View file

@ -843,15 +843,22 @@ progress {
bottom: -5px; bottom: -5px;
} }
@media all and (min-width: 650px) {
.itemVideo {
width: 270px;
}
}
.vjs-quality-button { .vjs-quality-button {
padding: 0 0.6em !important; padding: 0 0.6em !important;
width: auto !important; width: auto !important;
} }
.vjs-quality-button div { .vjs-quality-button div {
width: auto !important; width: auto !important;
background: none !important; background: none !important;
} }
.vjs-chapter-button div { .vjs-chapter-button div {
background-position: -100px -75px !important; background-position: -100px -75px !important;
@ -863,16 +870,21 @@ progress {
overflow-y: scroll; overflow-y: scroll;
} }
.vjs-chapter-button.vjs-menu-button ul li { .vjs-chapter-button.vjs-menu-button ul li {
width: auto; width: auto;
white-space: nowrap; white-space: nowrap;
font-size: 1.1em; font-size: 1.1em;
padding-right: 10px; padding-right: 10px;
} }
@media all and (min-width: 650px) { .vjs-default-skin .vjs-menu-button.vjs-stop-button {
float: left;
.itemVideo { background: none;
width: 270px; border: 0;
} }
.vjs-default-skin .vjs-menu-button.vjs-stop-button div {
background: url("images/media/stop.png");
height: 26px;
width: 26px;
margin: -.7em .5em auto 0;
} }

View file

@ -484,17 +484,17 @@ _V_.ResolutionMenuItem = _V_.MenuItem.extend({
// Change the source and make sure we don't start the video over // Change the source and make sure we don't start the video over
var currentSrc = this.player.tag.src; var currentSrc = this.player.tag.src;
var newSrc = currentSrc.replace(new RegExp("videoBitrate=[0-9]+","g"),"videoBitrate="+resolutions[this.options.src[0].res][0]); var src = parse_src_url(currentSrc);
newSrc = newSrc.replace(new RegExp("audioBitrate=[0-9]+","g"),"audioBitrate="+resolutions[this.options.src[0].res][1]); var newSrc = "/mediabrowser/"+src.Type+"/"+src.item_id+"/stream."+src.stream+"?audioChannels="+src.audioChannels+"&audioBitrate="+resolutions[this.options.src[0].res][1]+
newSrc = newSrc.replace(new RegExp("maxWidth=[0-9]+","g"),"maxWidth="+resolutions[this.options.src[0].res][2]); "&videoBitrate="+resolutions[this.options.src[0].res][0]+"&maxWidth="+resolutions[this.options.src[0].res][2]+"&maxHeight="+resolutions[this.options.src[0].res][3]+
newSrc = newSrc.replace(new RegExp("maxHeight=[0-9]+","g"),"maxHeight="+resolutions[this.options.src[0].res][3]); "&videoCodec="+src.videoCodec+"&audioCodec="+src.audioCodec;
if (this.player.duration() == "Infinity") { if (this.player.duration() == "Infinity") {
if (currentSrc.indexOf("StartTimeTicks") >= 0) { if (currentSrc.indexOf("StartTimeTicks") >= 0) {
var startTimeTicks = newSrc.match(new RegExp("StartTimeTicks=[0-9]+","g")); var startTimeTicks = currentSrc.match(new RegExp("StartTimeTicks=[0-9]+","g"));
var start_time = startTimeTicks[0].replace("StartTimeTicks=",""); var start_time = startTimeTicks[0].replace("StartTimeTicks=","");
newSrc = newSrc.replace(new RegExp("StartTimeTicks=[0-9]+","g"),"StartTimeTicks="+Math.floor(parseInt(start_time)+(10000000*current_time))); newSrc += "&StartTimeTicks="+Math.floor(parseInt(start_time)+(10000000*current_time));
}else { }else {
newSrc += "&StartTimeTicks="+Math.floor(10000000*current_time); newSrc += "&StartTimeTicks="+Math.floor(10000000*current_time);
} }
@ -683,6 +683,36 @@ _V_.ChapterMenuItem = _V_.MenuItem.extend({
} }
}); });
/*
JS for the stop button in video.js player
*/
/*
Define the base class for the stop button.
*/
_V_.StopButton = _V_.Button.extend({
kind: "stop",
className: "vjs-stop-button",
init: function(player, options) {
this._super(player, options);
},
buildCSSClass: function() {
return this.className + " vjs-menu-button " + this._super();
},
onClick: function() {
MediaPlayer.stop();
}
});
//convert Ticks to human hr:min:sec format //convert Ticks to human hr:min:sec format
function ticks_to_human(str) { function ticks_to_human(str) {
@ -700,3 +730,27 @@ function ticks_to_human(str) {
return time; return time;
}; };
//parse video player src URL
function parse_src_url(url) {
var src = url.replace("\?","\&");
var parts = src.split("/");
var len = parts.length-1;
var query = parts[len].split("&");
var array = new Array();
array['Type'] = parts[len-2];
array['item_id'] = parts[len-1];
for (i = 0; i < query.length; i++) {
if (i == 0) {
var pairs = query[i].split(".");
}else {
var pairs = query[i].split("=");
}
array[pairs[0]] = pairs[1];
}
return array;
}

View file

@ -316,6 +316,9 @@ var videoJSextension = {
*/ */
setup_video : function( $video, item ) { setup_video : function( $video, item ) {
// Add the stop button.
_V_.merge( _V_.ControlBar.prototype.options.components, { StopButton : {} } );
var vid_id = $video.attr( 'id' ), var vid_id = $video.attr( 'id' ),
available_res = ['high','medium','low'], available_res = ['high','medium','low'],
default_res, default_res,

View file

@ -1156,7 +1156,7 @@ $(function () {
var footerHtml = '<div id="footer" class="ui-bar-a">'; var footerHtml = '<div id="footer" class="ui-bar-a">';
footerHtml += '<div id="nowPlayingBar" style="display:none;">'; footerHtml += '<div id="nowPlayingBar" style="display:none;">';
footerHtml += '<button id="previousTrackButton" class="imageButton mediaButton" title="Previous Track" type="button"><img src="css/images/media/previoustrack.png" /></button>'; footerHtml += '<button id="previousTrackButton" class="imageButton mediaButton" title="Previous Track" type="button"><img src="css/images/media/previoustrack.png" /></button>';
footerHtml += '<button id="stopButton" class="imageButton mediaButton" title="Stop" type="button" onclick="MediaPlayer.stop();"><img src="css/images/media/stop.png" /></button>'; //footerHtml += '<button id="stopButton" class="imageButton mediaButton" title="Stop" type="button" onclick="MediaPlayer.stop();"><img src="css/images/media/stop.png" /></button>';
footerHtml += '<button id="nextTrackButton" class="imageButton mediaButton" title="Next Track" type="button"><img src="css/images/media/nexttrack.png" /></button>'; footerHtml += '<button id="nextTrackButton" class="imageButton mediaButton" title="Next Track" type="button"><img src="css/images/media/nexttrack.png" /></button>';
footerHtml += '<div id="mediaElement"></div>'; footerHtml += '<div id="mediaElement"></div>';
footerHtml += '<div id="mediaInfo"></div>'; footerHtml += '<div id="mediaInfo"></div>';