九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
HTML5應(yīng)用——簡(jiǎn)易播放器

HTML5應(yīng)用——簡(jiǎn)易播放器

分類: HTML5 javascript 931人閱讀 評(píng)論(0) 收藏 舉報(bào)

           如今HTML已經(jīng)是比較熱門的了,各種關(guān)于HTML5的應(yīng)用程序、游戲、應(yīng)用商店等也如火如荼的展開了。各大主流瀏覽器也紛紛開始支持HTML5標(biāo)準(zhǔn),以備打贏新的一輪瀏覽器大戰(zhàn)。

           話不多說,不知道大家有沒有發(fā)現(xiàn),可以用比較新的版本的谷歌瀏覽器直接打開.mp3格式的音樂。自己可以試試:

 

      這是用谷歌瀏覽器直接打開mp3文件的情況。 其實(shí),許多新的瀏覽器都開始支持HTML5中<audio> <video>標(biāo)簽,使得一些格式的流媒體可以擺脫對(duì)插件的依賴。 下面我就以<audio>標(biāo)簽做一個(gè)簡(jiǎn)易的音樂播放器.


     <audio>控件可以通過一些內(nèi)置的JavaSceipt函數(shù)和特性進(jìn)行控制,以及進(jìn)行二次開發(fā)。例如load()、play()、pause()等控制音頻播放的函數(shù),paused、ended、currentTime、startTime等屬性等.

         對(duì)于這個(gè)簡(jiǎn)易播放器具有播放\暫停、快進(jìn)、快退等功能,結(jié)合<canvas>對(duì)象繪制圖形

      

  1. <%@language="javascript" %>  
  2. <html>  
  3. <head>  
  4. <title>PlayMusic</title>  
  5. <style type="text/css">  
  6.     div.s{position:absolute;left:100px;top:200px;width:600px;}  
  7.     audio{width:600px;position:absolute;left:0px;top:100px;}  
  8.     canvas{position:absolute;left:0px;top:40px;}  
  9.     marquee{position:absolute;left:250px;top:180px;}  
  10.     h1{color:Red;}  
  11.     h1.a{color:Green;position:absolute;left:200px;top:50px;}  
  12. </style>  
  13. </head>  
  14. <body>  
  15. <h1 class="a">歡迎使用HTML5播放器</h1>  
  16. <%  
  17.     var name = Request.QueryString("name");  
  18.     if (name == "")  
  19.         name = "";  
  20.   
  21.     name1 = "save_music\\" + name + ".mp3";  
  22.     //Response.Write(name);  
  23.       
  24.  %>  
  25.  <marquee behavior=scroll scrolldelay=200 scrollamount=30 width="300" ><h1><%=name %></h1></marquee>  
  26.  <div class="s">  
  27.  <canvas width="600" height="60" id="MusicCanvas"  onclick="dealclick()"></canvas>  
  28. <audio id="music" src=<%=name1 %> controls>  
  29. 您的瀏覽器不支持HTML5中的audio標(biāo)簽  
  30. </audio>  
  31. </div>  
  32. </body>  
  33. </html>  
  34. <script type="text/javascript">  
  35.     var c = document.getElementById("MusicCanvas");  
  36.     var ccon = c.getContext("2d");  
  37.     var toggle = document.getElementById("music");  
  38.     drawPS();  
  39.     drawQuick();  
  40.      
  41.     function drawPS() //flag=1表示播放命令,flag=0表示暫停  
  42.     {  
  43.         con.save();  
  44.         con.beginPath();  
  45.         var g = con.createRadialGradient(275, 30, 0, 275, 30, 25); //創(chuàng)建漸變顏色  
  46.         if (toggle.paused) //暫停狀態(tài)  
  47.         {  
  48.             g.addColorStop(0.2, "#1FD856"); //  
  49.             g.addColorStop(0.8, "black"); //  
  50.             toggle.play();  
  51.         }  
  52.         else //播放狀態(tài)  
  53.         {  
  54.             g.addColorStop(0.2, "red"); //黃  
  55.             g.addColorStop(0.8, "black"); //  
  56.             toggle.pause();  
  57.         }  
  58.         con.fillStyle = g;  
  59.         con.arc(275, 30, 25, 0, Math.PI * 2, true);  
  60.         con.fill();  
  61.         con.closePath();  
  62.         con.restore();  
  63.            
  64.     }  
  65.     function drawQuick() //  
  66.     {  
  67.         con.save();  
  68.         con.beginPath();  
  69.         con.fillStyle = "grey";  
  70.         con.fillRect(130, 10, 70, 40);  
  71.         con.fillStyle = "black";  
  72.         con.moveTo(130, 30);con.lineTo(145, 13);con.lineTo(165, 13);con.lineTo(150, 30);con.lineTo(165, 47);con.lineTo(145, 47);con.lineTo(130, 30);  
  73.         con.fill();  
  74.         con.moveTo(160, 30); con.lineTo(175, 13); con.lineTo(195, 13); con.lineTo(180, 30); con.lineTo(195, 47); con.lineTo(175, 47); con.lineTo(160, 30);  
  75.         con.fill();  
  76.         con.closePath();  
  77.         con.beginPath();  
  78.         con.fillStyle = "grey";  
  79.         var x = 350;  
  80.         con.fillRect(x, 10, 70, 40);  
  81.         x += 70;  
  82.         con.fillStyle = "black";  
  83.         con.moveTo(x, 30); con.lineTo(x - 15, 13); con.lineTo(x - 35, 13); con.lineTo(x - 20, 30); con.lineTo(x - 35, 47); con.lineTo(x - 15, 47); con.lineTo(x, 30);  
  84.         x -30;  
  85.         con.moveTo(x, 30); con.lineTo(x - 15, 13); con.lineTo(x - 35, 13); con.lineTo(x - 20, 30); con.lineTo(x - 35, 47); con.lineTo(x - 15, 47); con.lineTo(x, 30);  
  86.         con.fill();  
  87.         //con.moveTo(160, 40); con.lineTo(175, 23); con.lineTo(195, 23); con.lineTo(180, 40); con.lineTo(195, 57); con.lineTo(175, 57); con.lineTo(160, 40);  
  88.         con.fill();  
  89.         con.closePath();  
  90.         con.restore();  
  91.     }  
  92.     function dealclick()//處理敲擊事件  
  93.     {  
  94.         var x = event.clientX;  
  95.         var y = event.clientY;  
  96.         var flag = getPos(x, y);  
  97.         //alert(x.toString() + "  " + y.toString()+"  "+flag.toString());  
  98.         if(flag==0)  
  99.         return;  
  100.     switch (flag)//  
  101.     {  
  102.         case 1: drawPS(); break;  
  103.         case 2: quickOrslow(0); break;  
  104.         case 3: quickOrslow(1); break;  
  105.     }  
  106.     }  
  107.     function getPos(x, y) //  
  108.     {  
  109.        var px=100;  
  110.        var py=240;  
  111.        x-=px;  
  112.        y-=py;  
  113.        if (x >= 275 && x <= 325 && y >= 15 && y<= 65)  
  114.            return 1;  
  115.        if (x >= 130 && x <= 200 && y >= 20 && y <= 60)  
  116.            return 2;  
  117.        if (x >= 350 && x <= 420 && y >= 20 && y <= 60)  
  118.            return 3;  
  119.        return 0;  
  120.    }  
  121.    function quickOrslow(flag) //  
  122.    {  
  123.        var total = toggle.duration;  
  124.        var s = Math.ceil(total*0.05);  
  125.        if (flag == 1)//kuaijin  
  126.        {  
  127.            if (toggle.ended == true)  
  128.                return;  
  129.            var now = toggle.currentTime;  
  130.            if (total - now <= s)  
  131.                return;  
  132.            else  
  133.                toggle.currentTime = now + s;  
  134.        }  
  135.        else  //后退  
  136.        {  
  137.            var n = toggle.currentTime;  
  138.            if (n < s)  
  139.                return;  
  140.            else  
  141.                toggle.currentTime = n - s;  
  142.        }  
  143.    }  
  144.   
  145. </script>  
      這是全部的源代碼,當(dāng)然其中包含了一些ASP語(yǔ)句,適用于傳遞歌曲名的,可以不用考慮。
  1. drawPS()是控制播放與暫停的函數(shù),quickOrSlow()是控制快退的函數(shù)。  
  1. 當(dāng)然這個(gè)播放器是非常簡(jiǎn)陋的,但是通過加工美化,還是可以做出優(yōu)秀的播放器的,而且是沒有插件的。  

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
HTML5基礎(chǔ),第4部分:點(diǎn)睛之筆Canvas
簡(jiǎn)潔白色的HTML5時(shí)鐘代碼
JavaScript圖形實(shí)例:Canvas API
第一階段復(fù)習(xí)~HTML5基礎(chǔ)夯實(shí)
其實(shí)canvas真的很簡(jiǎn)單,復(fù)雜的部分其實(shí)是你的創(chuàng)意
canvas基礎(chǔ)教程
更多類似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服