ÏÂÃæ½éÉÜÒ»ÏÂͨ¹ýjqueryºÍcss×Ô¶¨Òåvideo²¥·Å¿Ø¼þ¡£
Html5 VideoÊÇÏÖÔÚhtml5×îÁ÷ÐеŦÄÜÖ®Ò»,µÃµ½ÁË´ó¶àÊý×îа汾µÄä¯ÀÀÆ÷Ö§³Ö.°üÀ¨IE9,Ò²ÊÇÈç´Ë.²»Í¬µÄä¯ÀÀÆ÷ÌṩÁ˲»Í¬µÄÔÉú̬ä¯ÀÀÆ÷ÊÓÆµ¿Õ¼ä.ÎÒÃÇÖÆ×÷×Ô¶¨ÒåÊÓÆµ¿Ø¼þΪÁËÔÚËùÓеÄä¯ÀÀÆ÷ÖÐÓÐÒ»¸öÏàͬµÄHtml5ÊÓÆµ¿Ø¼þ¶ø²»ÊÜĬÈÏÊÓÆµ¿Ø¼þµÄ¿ØÖÆ.
ʵ¼ÊÉÏ,×Ô¶¨ÒåÊÓÆµ¿Ø¼þ²¢²»À§ÄÑ.±¾ÎĽ«¸æËßÄãÈçºÎÓÃjQuery×Ô¶¨ÒåÊÓÆµ¿Ø¼þ,Ï£Íû¶ÔÄãÓÐÓÃ!
HTML5 Video »ù´¡±êÇ©¡¡¡¡Your browser does not support the video tag.
ÐÒÔ˵ÄÊÇHTML5 Video µÄApi¿ÉÒÔÓÃJavaScript·ÃÎÊ,²¢Ê¹ÓÃËûÃÇÀ´×÷Ϊ¿ØÖÆÊÓÆµµÄý½é.
¡¡¡¡ÔÚ±àÂë֮ǰÈÃÎÒ¼òµ¥µÄ½éÉÜÒ»ÏÂjQueryÊÇÈçºÎ»ñÈ¡video±êÇ©µÄ.
¡¡¡¡ÔÚJavaScriptÖÐÎÒÃÇʹÓÃgetElementById('videoID')À´»ñÈ¡Video±êÇ©,×÷Ϊ½á¹û,ÎÒÃÇ»á»ñÈ¡µ½Ò»¸öDom¶ÔÏó.µ«ÊÇÕâ²»Êǵȼ۵ÄjQuery¶ÔÏó.$("videoID")»á·µ»ØÒ»¸öjQuery¶ÔÏó.²»ÊÇDom¶ÔÏó.Õâ¾ÍÊÇΪʲôÔÚ½«Æäת»»ÎªDom¶ÔÏó֮ǰÎÒÃDz»ÄÜÖ±½ÓʹÓÃjQueryÑ¡ÔñÆ÷µ÷ÓÃ/ʹÓÃHtml5 VideoµÄDomÊôÐԺ͹¦ÄÜ.¡¡¡¡
video = document.getElementById('videoID'); video = $('#videoID').get(0); video = $('#videoID')[0]; video = $('#videoID');
¡¡Video Play/Pause Controls ²¥·Å/ÔÝÍ£ °´Å¥¡¡¡¡ºÃµÄ,ÕâÊÇËùÓеĽéÉÜ.ÏÖÔÚÈÃÎÒÃÇÀ´±àÂë.Ê×ÏÈ,ÎÒÃÇÒª´´½¨Ò»¸ö¼òµ¥µÄ²¥·Å/ÔÝÍ£°´Å¥.¡¡¡¡
Play/Pause
ÎÒÃÇ¿ÉÒÔÇáËɵĿØÖÆHtml5 VideoµÄ²¥·ÅÓëÔÝͣ״̬.
//Play/Pause control clicked $('.btnPlay').on('click', function() { if(video[0].paused) { video[0].play(); } else { video[0].pause(); } return false; };
ÏÔʾÊÓÆµ²¥·Åʱ¼äºÍ³ÖÐøÊ±¼äHtml5 VideoÖ§³ÖÊÓÆµ»Ø·Å.ÕâÀïÎÒÃÇÒªÏÔʾÊÓÆµµÄµ±Ç°²¥·Åʱ¼äºÍ×Üʱ¼ä.
Current play time: Video duration:
ΪÁ˵õ½ÊÓÆµµÄ×Üʱ¼ä,ÎÒÃÇҪȷ±£ÊÓÆµÔªÊý¾ÝÒѾ¼ÓÔØ.Õâ¸öʱºòÎÒÃÇÒªÓõ½Html5 VideoµÄloadedmetadataʼþ.
¡¡¡¡¶ÔÓÚµ±Ç°µÄÊÓÆµ²¥·Åʱ¼ä.ÎÒÃÇ¿ÉÒÔÓÃHtml5 Video timeupdateʼþÀ´±£Ö¤ËûµÄ¸üÐÂ.
//get HTML5 video time duration video.on('loadedmetadata', function() { $('.duration').text(video[0].duration); }); //update HTML5 video current play time video.on('timeupdate', function() { $('.current').text(video[0].currentTime); });
¡¡ÊÓÆµ½ø¶ÈÌõ¡¡¡¡ÔÚÕâÀïÎÒÃǽ«»á°Ñµ±Ç°²¥·Åʱ¼äºÍ×ܵÄʱ¼ä³¤¶Èת»»Îª¸üÈËÐÔ»¯µÄ½ø¶ÈÌõ.
.progressBar { position width height backgroud-color .timeBar { position top left width height background-color
ÏÂÃæµÄjs¾ÍÊÇͨ¹ýÊÓÆµµÄ×Üʱ¼äÓ뵱ǰʱ¼äµÄ¼ÆË㣬»ñµÃ²¥·Å½ø¶ÈÌõ¡£
//get HTML5 video time duration video.on('loadedmetadata', function() { $('.duration').text(video[0].duration)); }); //update HTML5 video current play time video.on('timeupdate', function() { maxduration = video[0].duration; percentage = 100 * currentPos / maxduration; //in % $('.timeBar').css('width', percentage+'%'); });
ÏÂÃæÊµÏÖ²¥·Å½ø¶ÈÌõµÄÍÏ×§£¬À´²¥·ÅÊÓÆµ
$('.progressBar').mousedown(function(e) { timeDrag = true; updatebar(e.pageX); }); $(document).mouseup(function(e) { if(timeDrag) { timeDrag = false; updatebar(e.pageX); } }); $(document).mousemove(function(e) { if(timeDrag) { updatebar(e.pageX); } }); updatebar = function(x) { var progress = $('.progressBar'); position = x - progress.offset().left; percentage = 100 * position / progress.width(); (percentage > 100) { percentage = 100; } if(percentage < 0) { percentage = 0; } //Update progress bar and video currenttime $('.timeBar').css('width', percentage+'%'); video[0].currentTime = maxduration * percentage / 100; };
½ø½×-ÏÔʾ»º³åÀ¸
ÎÒÃÇÐèÒª¸øÊÓÆµÖÆ×÷Ò»¸ö»º³åÀ¸ÈÃÓû§ÖªµÀÊÓÆµ¼ÓÔØÁ˶àÉÙ.
.progressBar { position width height backgroud-color .bufferBar { position top left width height background-color
Html5 Video»º³åÊôÐÔ½«·µ»ØÒ»¸ö¶ÔÏóµÄ»º´æ·¶Î§.Òò´Ë,ÎÒÃǽ«Ê¹Óûº´æÊý¾ÝµÄ×îºóÒ»¸öÖµ.
¡¡