IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

modifier src video html 5 [API HTML5]


Sujet :

JavaScript

  1. #1
    Membre habitué
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2013
    Messages : 8
    Par défaut modifier src video html 5
    Bonjour,
    j'essaye de créer un outil pour remplacer une animation pas à pas en Flash par une série de vidéo appelées via la balise <video> de HTML 5.
    J'ai besoin que l'on puisse avancer ou reculer dans une "histoire" en avançant ou reculant dans ces vidéos sans que cela soit trop visible pour l'utilisateur. Ca doit s'activer par un clic sur une flèche à l'écran (compatibilité tablette et autres mobiles) et par les flèches gauche et droite du clavier.

    le fichier html :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title>Test Playlist</title>
    		<link rel="stylesheet" href="playlist.css">	
    		<script src="playlist.js"></script>	
    	</head>
    	<body>
    	   	<script>document.onkeydown = applyKey;</script>	
    		<div id="header">&nbsp;</div>
    		<div id="container" class="column">
    			<div id="center">
    				<video class="column" width="640" height="360" autoplay>
    				<source id="videoMPG" src="./medias/1.mp4" type="video/mp4">
    				<source id="videoOGG" src="./medias/1.ogv" type="video/ogg">
    					Your browser does not support the video tag.
    				</video>
    			</div>
    			<div id="left" class="column"><img src="./gauche.png" width="40" height="360" alt="backward" onClick="backward()" /></div>
    			<div id="right" class="column"><img src="./droite.png" width="40" height="360" alt="forward" onClick="forward()" /></div>
    		</div>
     
    		<div id="footer">&nbsp;</div>
     
       </body>
     
    </html>

    le contenu de playlist.js :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    //KEY_DOWN	= 40;
    //KEY_UP		= 38;
    KEY_LEFT	= 37;
    KEY_RIGHT	= 39;
     
     
     
    function checkEventObj ( _event_ ){
    	// --- IE explorer
    	if ( window.event )
    		return window.event;
    	// --- Netscape and other explorers
    	else
    		return _event_;
    }
     
    function applyKey (_event_){
     
    	// --- Retrieve event object from current web explorer
    	var winObj = checkEventObj(_event_);
     
    	var intKeyCode = winObj.keyCode;
    	var intAltKey = winObj.altKey;
    	var intCtrlKey = winObj.ctrlKey;
     
    	if ( intKeyCode == KEY_RIGHT ) {
    		forward();
    		}
    	if ( intKeyCode == KEY_LEFT) {
    		backward();
    		}
     
    }
       function forward(){
       var videoPlayerMPG;
       va videoPlayerOGG;
     
       var video_count;
     
       var spliter;
       var currentSplit;
       var tab;
       var currentVideo;
       var nextVideoMPG;
       var nextVideoOGG;
     
       videoPlayerMPG = document.getElementById("videoMPG");
       videoPlayerOGG = document.getElementById("videoOGG");
     
       spliter = videoPlayerMPG.src.split("/");
       currentSplit = spliter[spliter.length-1]
       tab = currentSplit.split(".");
       currentVideo = tab[0];
       currentVideo++;
       if (currentVideo == 4) currentVideo = 1;
       nextVideoMPG = "./medias/"+currentVideo+".mp4";
       videoPlayerMPG.src = nextVideoMPG;
       videoPlayerMPG.type = "video/mp4";
       nextVideoOGG = "./medias/"+currentVideoOGG+".ogv";
       videoPlayerOGG.src = nextVideoMPG;
       videoPlayerOGG.type = "video/ogg";
       }
       function backward(){
       var videoPlayerMPG;
       var videoPlayerOGG;
       var video_count;
     
       var spliter;
       var currentSplit;
       var tab;
       var currentVideo;
       var nextVideoMPG;
       var nextVideoOGG;
     
       videoPlayerMPG = document.getElementById("videoMPG");
       videoPlayerOGG = document.getElementById("videoOGG");
     
       spliter = videoPlayer.src.split("/");
       currentSplit = spliter[spliter.length-1]
       tab = currentSplit.split(".");
       currentVideo = tab[0];
       currentVideo--;
       if (currentVideo <= 1) currentVideo = 1;
       nextVideoMPG = "./medias/"+currentVideo+".mp4";
       videoPlayerMPG.src = nextVideoMPG;
       videoPlayerMPG.type = "video/mp4";
       nextVideoOGG = "./medias/"+currentVideoOGG+".ogv";
       videoPlayerOGG.src = nextVideoMPG;
       videoPlayerOGG.type = "video/ogg";
       }
    Rien ne se passe quand je clique ou que j'utilise les flèches du clavier.

    J'avais fait une première version fonctionnelle mais pas très propre et qui ne fonctionnait pas sur tous les navigateurs.

    cela fonctionnait avec dans le code html :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <video class="column" width="640" height="360" autoplay id="Video" src="./medias/1.mp4" type="video/mp4"  >Your browser does not support the video tag.</video>

    Donc sans les balise <source> qui sont pourtant très pratiques pour donner le choix au navigateur.

    Une petite aide pour fixer celà ?

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Une fois que tu as affecté les nouvelles valeurs aux balises <source>, il faut recharger la vidéo :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById('video').load();
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre habitué
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2013
    Messages : 8
    Par défaut
    Huum ca me semblait assez logique en effet, mais celà ne fonctionne toujours pas malheureusement :/ ca ne change même pas les src !

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Dans ce cas, c'est probablement l'affectation de tes src qui n'est pas correct.
    Il faudrait que tu regardes au niveau de la console ce qu'il se passe avec des console.log() et que tu vérifies que les chemins sont corrects.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Membre habitué
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2013
    Messages : 8
    Par défaut
    ok il y avait quelques petites erreures comme une "}" manquante et des variables mal écrites par endroit.

    Cela fonctionne très bien maintenant ! Merci Beaucoup

    je laisse pour ceux qui chercherait une solution similaire, le code terminé ici :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    //KEY_DOWN	= 40;
    //KEY_UP		= 38;
    KEY_LEFT	= 37;
    KEY_RIGHT	= 39;
     
    function checkEventObj ( _event_ ){
    	// --- IE explorer
    	if ( window.event )
    		return window.event;
    	// --- Netscape and other explorers
    	else
    		return _event_;
    }
     
    function applyKey (_event_){
     
    	// --- Retrieve event object from current web explorer
    	var winObj = checkEventObj(_event_);
     
    	var intKeyCode = winObj.keyCode;
    	var intAltKey = winObj.altKey;
    	var intCtrlKey = winObj.ctrlKey;
     
    	if ( intKeyCode == KEY_RIGHT ) {
    		forward();
    		}
    	if ( intKeyCode == KEY_LEFT) {
    		backward();
    		}
     
    }
       function forward(){
       var videoPlayerMPG;
       var videoPlayerOGG;
     
       var video_count;
     
       var spliter;
       var currentSplit;
       var tab;
       var currentVideo;
       var nextVideoMPG;
       var nextVideoOGG;
     
       videoPlayerMPG = document.getElementById("videoMPG");
       videoPlayerOGG = document.getElementById("videoOGG");
     
       spliter = videoPlayerMPG.src.split("/");
       currentSplit = spliter[spliter.length-1]
       tab = currentSplit.split(".");
       currentVideo = tab[0];
       currentVideo++;
       if (currentVideo == 4) currentVideo = 1;
       nextVideoMPG = "./medias/"+currentVideo+".mp4";
       videoPlayerMPG.src = nextVideoMPG;
       videoPlayerMPG.type = "video/mp4";
       nextVideoOGG = "./medias/"+currentVideo+".ogv";
       videoPlayerOGG.src = nextVideoOGG;
       videoPlayerOGG.type = "video/ogg";
       document.getElementById('video').load();
     
    }   
       function backward(){
       var videoPlayerMPG;
       var videoPlayerOGG;
       var video_count;
     
       var spliter;
       var currentSplit;
       var tab;
       var currentVideo;
       var nextVideoMPG;
       var nextVideoOGG;
     
       videoPlayerMPG = document.getElementById("videoMPG");
       videoPlayerOGG = document.getElementById("videoOGG");
     
       spliter = videoPlayerMPG.src.split("/");
       currentSplit = spliter[spliter.length-1]
       tab = currentSplit.split(".");
       currentVideo = tab[0];
       currentVideo--;
       if (currentVideo <= 1) currentVideo = 1;
       nextVideoMPG = "./medias/"+currentVideo+".mp4";
       videoPlayerMPG.src = nextVideoMPG;
       videoPlayerMPG.type = "video/mp4";
       nextVideoOGG = "./medias/"+currentVideo+".ogv";
       videoPlayerOGG.src = nextVideoOGG;
       videoPlayerOGG.type = "video/ogg";
       document.getElementById('video').load();
       }
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title>Test Playlist</title>
    		<link rel="stylesheet" href="playlist.css">	
    		<script src="./playlist.js"></script>
    	</head>
    	<body>
    	   	<script>document.onkeydown = applyKey;</script>	
    		<div id="header">&nbsp;</div>
    		<div id="container" class="column">
    			<div id="center">
    				<video class="column" width="640" height="360" autoplay id="video">
    				<source id="videoMPG" src="./medias/1.mp4" type="video/mp4">
    				<source id="videoOGG" src="./medias/1.ogv" type="video/ogg">
    					Your browser does not support the video tag.
    				</video>
    			</div>
    			<div id="left" class="column"><img src="./gauche.png" width="40" height="360" alt="precedent" onClick="backward()" /></div>
    			<div id="right" class="column"><img src="./droite.png" width="40" height="360" alt="suivant" onClick="forward()" /></div>
    		</div>
     
    		<div id="footer">&nbsp;</div>
     
       </body>
     
    </html>

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Outlook XP (2002) - Créer/modifier un formulaire HTML
    Par s.n.a.f.u dans le forum Outlook
    Réponses: 2
    Dernier message: 13/01/2008, 20h43
  2. [SQL] Modifier une table HTML et mettre à jour la base
    Par bart64 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 11/11/2007, 18h06
  3. Comment ouvrir et modifier un fichier html ?
    Par babeu dans le forum Framework .NET
    Réponses: 2
    Dernier message: 06/11/2006, 09h45
  4. Modifier contenu Video :
    Par pierreonxbox dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 25/10/2006, 15h33
  5. [SQL] Modifier un fichier HTML statique en cache avec rename()
    Par warpyou dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 19/09/2006, 10h32

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo