ホームページ ウェブフロントエンド H5 チュートリアル HTML5 は Audio タグを使用して歌詞同期の効果を実現します _html5 チュートリアル スキル

HTML5 は Audio タグを使用して歌詞同期の効果を実現します _html5 チュートリアル スキル

May 16, 2016 pm 03:51 PM
audio html5

HTML5 の最も強力な点は、メディア ファイルの処理です。たとえば、単純な vedio タグを使用してビデオ再生を実現できます。同様に、HTML5 にはオーディオ ファイルを処理するための対応するタグがあります。つまり、オーディオ タグ
HTML5 はリリースされてからかなりの時間が経ちますが、その中のオーディオ タグは一度しか使用されていません。このタグをページに挿入します。今回は、友人がいくつかのページを作成し、audio タグの使用を練習するのを手伝うのを利用しました。
まず、ページに audio タグを挿入する必要があります。後で end 属性を使用する必要があるため、この属性はループ再生の設定に使用しないことをお勧めします。 if ループが If ループに設定されている場合、終了属性は常に false になります。
autoplay='autoplay' は、読み込み後にページが自動的に音楽を再生するように設定します。preload 属性と autoplay 属性は同じ効果を持ちます。autoplay 属性がタグ内にある場合、preload 属性は無視されます。
controls='controls' は、音楽を表示するためのコントロール バーを設定します。

XML/HTML コードコンテンツをクリップボードにコピー
  1. <オーディオ src=「音楽/イエスタデイ・ワンス・モア」 .mp3" id="aud" 自動再生=「自動再生」 コントロール=「コントロール」 プリロード="自動">
  2. お使いのブラウザはオーディオ属性をサポートしていません。ブラウザを変更して閲覧してください。
  3. 音声>

このタグを取得すると、おめでとうございます。あなたのページで音楽を再生できるようになります。ただ、それではページが単調になってしまうので、ページ内に歌詞を同期して表示したり、再生する音楽も選択できるように工夫しました。したがって、この効果を実現するには、まず歌詞ファイルを lrc 形式でダウンロードし、次に音楽をフォーマットする必要があります。冒頭の音楽ファイルはこんな感じだったので


各歌詞を 2 桁の配列に挿入する必要があります。
歌詞をフォーマットするためのコードをここに添付します。

XML/HTML コードコンテンツをクリップボードにコピー
  1. //歌詞同期部分
  2. 関数 parseLyric(text) {
  3. //テキストを行ごとに分割し、配列
  4. に格納します
  5. var lines = text.split('n'),
  6. //時刻の一致に使用される正規表現。一致結果は [xx:xx.xx] に似ています。
  7. パターン = /[d{2}:d{2}.d{2}]/g,
  8. //最終結果を保存する配列
  9. 結果 = [];
  10. //時間を置かずに行を削除します
  11. while (!pattern.test(lines[0])) {
  12. = 行.slice(1); };
  13. //「n」を使用して上記の配列を生成すると、結果の最後の要素は空の要素になり、ここで削除されます
  14. lines[lines.length - 1]
  15. .length
  16. === 0 && lines.pop(); lines.forEach(function(v /*配列要素の値*/ , i /*要素のインデックス*/ , a /*配列自体*/ ) {
  17. //時刻を抽出 [xx:xx.xx]
  18. var
  19. time
  20. =
  21. v.match(pattern), //歌詞を抽出
  22. v
  23. value
  24. = v.replace(pattern, ''); //1 行に複数の時間が含まれる可能性があるため、時間は [xx:xx.xx][xx:xx.xx][xx:xx.xx] の形式になる場合があります。さらに離れて time.forEach(function(v1, i1, a1) {
  25. //時間内の角括弧を削除すると、xx:xx.xx が得られます
  26. var
  27. t
  28. =
  29. v1
  30. .slice(1, -1).split(':'); //結果を最終配列にプッシュします result.push([parseInt(t[0], 10) * 60 parseFloat(t[1]), value]);
  31. });
  32. });
  33. //最後に、保存後に歌詞が正常に表示されるように、結果配列の要素を時間で並べ替えます
  34. result.sort(function(a, b) {
  35. a[0] - b[0] を返す
  36. ;
  37. });
  38. 結果を返す
  39. }
  40. この時点で、各音楽の歌詞を簡単に使用できるようになります。音楽を正常に切り替えるために、歌詞を取得してページに同期して表示する機能が必要です。コードは以下に添付されています。
  41. XML/HTML コード
  42. コンテンツをクリップボードにコピー
  1. function fn(sgname){
  2. $.get('music/' sgname '.lrc',function(data){
  3. var str=parseLyric(データ);
  4. for(var
  5. i=0,li;i<str.length;i ){
  6. li=$('<li>' str[i][1] 'li>');
  7. $('#gc ul').append(li);
  8. }
  9. $('#aud')[0]
  10. .ontimeupdate=function(){//videoオーディオの現在の再生位置が変更されるとトリガーされます
  11. for (var
  12. i = 0, l = str.length; i < l; 🎜> if (this.currentTime /*現在の再生時間*/
  13. > str[i][0]) { //ページへ表示
  14. $('#gc ul').css('top',-i*40 200 'px'); //歌詞を上に移動します
  15. $('#gc ul li').css('color','#fff');
  16. $('#gc ul li:nth-child(' (i 1) ')').css('color','red') //現在再生されている歌詞を強調表示します
  17. }
  18. }
  19. if(this.ended){ //現在再生中の音楽の再生が終了したかどうかを判定します
  20. var
  21. songslen=$('.songs_list li').length for(var
  22. i= 0,val;i<ソングレン;i ){
  23. val=$('.songs_list li:nth-child(' (i 1) ')').text(); > if(val
  24. ==sgname){ i
  25. =(i==(songslen-1))?1:i 2; > sgname
  26. =$('.songs_list li:nth-child(' i ')').text(); //音楽が終了したら切り替えます音楽を演奏しています
  27. $('#gc ul').empty(); //歌詞をクリア
  28. $('#aud').attr('src','music/' sgname '.mp3');
  29. fn(sgname)
  30. 戻る
  31. }
  32. }
  33. }
  34. };
  35. });
  36. } fn($('.songs_list li:nth-child(1)').text());
  37. これで、音楽の歌詞が通常どおり同期してページに表示されるようになりました。ただし、まだ不足しているものが 1 つあります。それは、このリスト内の音楽をクリックして音楽を再生できるようにすることです。以下にコードを添付します。
  38. HTML コード
XML/HTML コード

コンテンツをクリップボードにコピー

  1. <div class="songs_cnt" >
  2. <ul クラス="songs_list" >
  3. <>昨日もう一度もう一度 >
  4. <>あなたは美しいです >
  5. ul>
  6. <ボタン クラス="sel_song" >ポイント<br/>< br/>ボタン>
  7. div>
  8. <div id="gc" >
  9. <ul>ul>
  10. div>

css代码

XML/HTML コード复制コンテンツ到剪贴板
  1. #gc{
  2. 幅: 400px;    
  3. 高さ: 400ピクセル;    
  4. 背景: 透明。    
  5. マージン: 100px 自動;    
  6. 色: #fff;    
  7. フォントサイズ: 18px;    
  8. オーバーフロー: 非表示;    
  9. 位置: 相対。    
  10. }
  11. #gc ul{
  12. 位置: 絶対;    
  13. トップ: 200ピクセル;    
  14. }
  15. #gc ul li{
  16. text-align: center;    
  17. 高さ: 40px;    
  18. 行の高さ: 40px;    
  19. }
  20. .songs_cnt{
  21. float: 左;    
  22. margin-top: 200px;    
  23. 位置: 相対。    
  24. }
  25. .songs_list{
  26. 背景色: rgba(0,0,0,.2);    
  27. border-radius: 5px;    
  28. float: 左;    
  29. 幅: 250px;    
  30. パディング: 15px;    
  31. margin-left: -280px;    
  32. }
  33. .songs_list li{
  34. 高さ: 40px;    
  35. 行の高さ: 40px;    
  36. フォントサイズ: 16px;    
  37. カラー: rgba(255,255,255,.8);    
  38. カーソル: ポインタ;    
  39. }
  40. .songs_list li:hover{
  41. フォントサイズ: 20px;    
  42. 色: rgba(255,23,140,​​.6);    
  43. }
  44. .sel_song{
  45. 位置: 絶対;    
  46. トップ: 50%;    
  47. 幅: 40px;    
  48. 高さ: 80px;    
  49. margin-top: -40px;    
  50. フォントサイズ: 16px;    
  51. text-align: center;    
  52. 背景色: 透明;    
  53. ボーダー: 1px solid #2DCB70;    
  54. フォントの太さ: 太字;    
  55. カーソル: ポインタ;    
  56. border-radius: 3px;    
  57. フォントファミリー: サンセリフ;    
  58. 遷移:すべて 2;    
  59. -moz-transition:all 2;    
  60. -webkit-transition:all 2s;    
  61. -o-transition:all 2s;    
  62. }
  63. .sel_song:hover{
  64. 色: #fff;    
  65. 背景色: #2DCB70;    
  66. }
  67. .songs_list li.active{
  68. 色: #f00;    
  69. }

js代码

XML/HTML コード复制コンテンツ到剪贴板
  1. $('.songs_list li:nth-child(1)').addClass('active');    
  2. $('.songs_cnt').mouseenter(function () {
  3. var e=event||window.event;    
  4. var tag= e.target||e.srcElement;    
  5. if(tag.nodeName=='BUTTON'){
  6. $('.songs_list').animate({'marginLeft':'0px'},'slow');    
  7. }
  8. });    
  9. $('.songs_cnt').mouseleave(function () {
  10. $('.songs_list').animate({'marginLeft':'-280px'},'slow');    
  11. });    
  12. $('.songs_list li').each(function () {
  13. $(this).click(function () {
  14. $('#aud').attr('src','music/' $(this).text() '.mp3');    
  15. $('#gc ul').empty();    
  16. fn($(this).text());    
  17. $('.songs_list li').removeClass('active');    
  18. $(this).addClass('active');    
  19. });    
  20. })

はい、ここまで来ました。この歌のシンク効果にはいくつかの機能上の違いはありますが、HTML5 を使用したオーディオ マークによる歌のシンクの効果については、今日もここに到達しました。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTMLの表の境界線 HTMLの表の境界線 Sep 04, 2024 pm 04:49 PM

HTML の表の境界線に関するガイド。ここでは、HTML でのテーブルの境界線の例を示しながら、テーブル境界線を定義する複数の方法について説明します。

HTML のネストされたテーブル HTML のネストされたテーブル Sep 04, 2024 pm 04:49 PM

これは、HTML でのネストされたテーブルのガイドです。ここでは、テーブル内にテーブルを作成する方法をそれぞれの例とともに説明します。

HTML 左マージン HTML 左マージン Sep 04, 2024 pm 04:48 PM

HTML マージン左のガイド。ここでは、HTML margin-left の概要とその例、およびそのコード実装について説明します。

HTML テーブルのレイアウト HTML テーブルのレイアウト Sep 04, 2024 pm 04:54 PM

HTML テーブル レイアウトのガイド。ここでは、HTML テーブル レイアウトの値と例および出力について詳しく説明します。

Klipsch、8Kサポート、12個のスピーカー、ルームコレクションを備えたFlexus Core 300フラッグシップサウンドバーを発表 Klipsch、8Kサポート、12個のスピーカー、ルームコレクションを備えたFlexus Core 300フラッグシップサウンドバーを発表 Sep 05, 2024 am 10:16 AM

Klipsch Flexus Core 300はシリーズの最上位モデルで、同社のサウンドバーラインナップではすでに発売されているFlexus Core 200の上に位置します。クリプシュ氏によると、これはサウンドをさまざまな環境に適応できる世界初のサウンドバーだという。

HTML入力プレースホルダー HTML入力プレースホルダー Sep 04, 2024 pm 04:54 PM

HTML 入力プレースホルダーのガイド。ここでは、コードと出力とともに HTML 入力プレースホルダーの例について説明します。

HTML 内のテキストの移動 HTML 内のテキストの移動 Sep 04, 2024 pm 04:45 PM

HTML でのテキストの移動に関するガイド。ここでは、概要、マーキー タグが構文でどのように機能するか、および実装例について説明します。

HTML 順序付きリスト HTML 順序付きリスト Sep 04, 2024 pm 04:43 PM

HTML 順序付きリストのガイド。ここでは、HTML 順序付きリストと型の導入とその例についても説明します。

See all articles