Je n'arrive pas à obtenir le style correct sur les commandes du lecteur vidéo car rien ne semble s'aligner correctement.
J'ai essayé de placer les objets dans des divs et des lis, mais les choses ne semblent pas bouger ou s'aligner correctement.
Aucune suggestion?
Ce que j'ai jusqu'à présent: http://jsfiddle.net/pp6Wn/
var vid, playbtn, seekslider, curtimetext, durtimetext, mutebtn, volumeslider, fullscreenbtn;
function intializePlayer() {
// Set object references
vid = document.getElementById("my_video");
playbtn = document.getElementById("playpausebtn");
seekslider = document.getElementById("seekslider");
curtimetext = document.getElementById("curtimetext");
durtimetext = document.getElementById("durtimetext");
mutebtn = document.getElementById("mutebtn");
volumeslider = document.getElementById("volumeslider");
fullscreenbtn = document.getElementById("fullscreenbtn");
// Add event listeners
playbtn.addEventListener("click", playPause, false);
seekslider.addEventListener("change", vidSeek, false);
vid.addEventListener("timeupdate", seektimeupdate, false);
mutebtn.addEventListener("click", vidmute, false);
volumeslider.addEventListener("change", setvolume, false);
fullscreenbtn.addEventListener("click", toggleFullScreen, false);
}
window.onload = intializePlayer;
function playPause() {
if (vid.paused) {
vid.play();
playbtn.style.background = "url()";
playbtn.style.backgroundSize = "100% 100%";
} else {
vid.pause();
playbtn.style.background = "url()";
playbtn.style.backgroundSize = "100% 100%";
}
}
function vidSeek() {
var seekto = vid.duration * (seekslider.value / 100);
vid.currentTime = seekto;
}
function seektimeupdate() {
var nt = vid.currentTime * (100 / vid.duration);
seekslider.value = nt;
var curmins = Math.floor(vid.currentTime / 60);
var cursecs = Math.floor(vid.currentTime - curmins * 60);
var durmins = Math.floor(vid.duration / 60);
var dursecs = Math.floor(vid.duration - durmins * 60);
if (cursecs < 10) {
cursecs = "0" + cursecs;
}
if (dursecs < 10) {
dursecs = "0" + dursecs;
}
if (curmins < 10) {
curmins = "0" + curmins;
}
if (durmins < 10) {
durmins = "0" + durmins;
}
curtimetext.innerHTML = curmins + ":" + cursecs;
durtimetext.innerHTML = durmins + ":" + dursecs;
}
function vidmute() {
if (vid.muted) {
vid.muted = false;
mutebtn.innerHTML = "Mute";
} else {
vid.muted = true;
mutebtn.innerHTML = "Unmute";
}
}
function setvolume() {
vid.volume = volumeslider.value / 100;
}
function toggleFullScreen() {
if (vid.requestFullScreen) {
vid.requestFullScreen();
} else if (vid.webkitRequestFullScreen) {
vid.webkitRequestFullScreen();
} else if (vid.mozRequestFullScreen) {
vid.mozRequestFullScreen();
}
}
#video-container,
#playpausebtn,
#fullscreenbtn,
#mutebtn,
#curtimetext,
#durtimetext,
#seekslider,
#volumeslider {
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
#video-container {
position: relative;
}
div#video_controls_bar {
position: absolute;
background: #61676D;
bottom: 0;
left: 0;
right: 0;
margin: 0 auto 5% auto;
width: 60%;
height: 35px;
padding-top: 10px;
padding-bottom: 10px;
padding-right: 5%;
padding-left: 5%;
-webkit-border-radius: 12px;
-moz-border-radius: 12px;
border-radius: 12px;
opacity: 0;
-webkit-transition: opacity .3s;
-moz-transition: opacity .3s;
-o-transition: opacity .3s;
-ms-transition: opacity .3s;
transition: opacity .3s;
}
#video-container:hover #video_controls_bar {
opacity: 1;
}
button#playpausebtn {
background: url();
background-size: 100% 100%;
background-repeat: no-repeat;
width: 7%;
height: 30px;
cursor: pointer;
border: 0;
background-color: red;
}
button#playpausebtn:hover {
cursor: pointer;
}
button#fullscreenbtn {
background: url();
background-size: 100% 100%;
background-repeat: no-repeat;
width: 7%;
height: 40px;
cursor: pointer;
border: 0;
background-color: blue;
}
button#mutebtn {
width: 10%;
background-color: green;
}
#curtimetext,
#durtimetext {
width: 5%;
display: inline-block;
vertical-align: middle;
}
input#seekslider {
width: 35%;
height: 20px;
background-color: yellow;
}
input#volumeslider {
width: 10%;
background-color: red;
}
input[type='range'] {
-webkit-appearance: none !important;
background: #384047;
-webkit-border-radius: 12px;
-moz-border-radius: 12px;
border-radius: 12px;
}
input[type='range']::-webkit-slider-thumb {
-webkit-appearance: none !important;
background: #6CBB7C;
height: 20px;
width: 20px;
border-radius: 100%;
cursor: pointer;
}
input[type="range"]::-webkit-slider-thumb:hover {
-webkit-animation: Pulse 1s infinite;
}
@-webkit-keyframes Pulse {
from {
-webkit-box-shadow: 0 0 2px transparent;
}
50% {
-webkit-box-shadow: 0 0 10px #e74c3c;
}
to {
-webkit-box-shadow: 0 0 2px transparent;
}
}
@media screen and (max-width: 500px) {
#curtimetext,
#durtimetext {
display: none;
}
}
<div id="video-container">
<video id="my_video" width="100%" height="100%">
<source src="http://romain-menard.fr/cours_html5/sitedemo/src/small.mp4" type="video/mp4" />
<source src="video/movie.webm" type="video/webm" />
</video>
<!-- Video Controls -->
<div id="video_controls_bar">
<button id="playpausebtn"></button>
<span id="curtimetext">00:00</span>
<input id="seekslider" type="range" min="0" max="100" value="0" step="1"><span id="durtimetext">00:00</span>
<button id="mutebtn">Mute</button>
<input id="volumeslider" type="range" min="0" max="100" value="100" step="1">
<button id="fullscreenbtn"></button>
</div>
</div>
C'est l'effet que je vise
J'ai mis à jour votre jsfiddle pour résoudre ce problème pour vous, il fallait ajouter les éléments CSS suivants:
.class{
display: inline-block;
vertical-align: middle;
}
vous pouvez utiliser flex-box:
#video_controls_bar{
display: flex;
align-items: center; // All items vertically centered.
}