歌詞解析總結

前言

 

  目前經常使用歌詞文件有3種php

  • LRC
  • QRC
  • KRC

其中LRC是最經常使用的歌詞文件,千千靜聽、酷我音樂都是用LRC作歌詞解析的.它的格式很是簡單.解析容易可是,歌詞的精度只能控制到一行.html

QRC是QQ音樂的歌詞文件.其精度能夠控制到每一個字.它是無加密的.java

KRC是酷狗播放器專用歌詞文件,它經過了壓縮處理而且加密.它也能精確控制到每個字,同時還綁定了歌曲的信息,酷狗播放器打開時可以自動下載歌曲git

 

LRC歌詞解析

 

開頭的歌曲信息可能會有2種展示形式github

[00:02.37]三十而立
[00:03.12]
[00:03.80]做詞:唐孝凡
[00:04.55]做曲:唐孝凡
[00:05.18]演唱:唐孝凡
[00:06.43]出品:深圳小龍文化
[ar:藝人名]
[ti:曲名]
[al:專輯名]
[by:編者(指編輯LRC歌詞的人)]
[offset:時間補償值] 其單位是毫秒,正值表示總體提早,負值相反。這是用於整體調整顯示快慢的,(但多數的MP3可能不會支持這種標籤)。

第一種比較簡單,和正文歌詞解析相同.第二種須要寫額外的正則解析.segmentfault

其中時間標籤,形式爲「[mm:ss]」或「[mm:ss.ff]」(分鐘數:秒數.毫秒數),時間標籤需位於某行歌詞中的句首部分,一行歌詞能夠包含多個時間標籤(好比歌詞中的迭句部分)。當歌曲播放到達某一時間點時,MP3就會尋找對應的時間標籤並顯示標籤後面的歌詞文本,這樣就完成了「歌詞同步」的功能。

數組

開頭標識信息正則

_regAr = /\[ar:(.+)\]/, 
_regTi = /\[ti:(.+)\]/,
_regAl = /\[al:(.+)\]/,
_regBy = /\[by:(.+)\]/,
_regOffset = /\[offset:.+\]/,
_regTime = /\[\d+:\d+(\.\d+)?\]/g,
    

 

解析歌詞

 

僞代碼:數據結構

  1. 將歌詞轉換爲以行爲單位的數組
  2. 對每一行作正則匹配,包括頭信息和時間戳的匹配 
  3. 拿到匹配後的數據封裝爲想要的歌詞數據結構,若是要同步歌詞的話,最好封裝爲js對象,{時間 : 歌詞} ,便與查找
    var _analysisLrc = function(){

        var lrcObj = {},
            lrcArray = this.lrcStr.split("\\n");

        for(var i=0;i<lrcArray.length;i++){
            var lyric = decodeURIComponent(lrcArray[i]);
            var timeReg = /\[\d*:\d*((\.|\:)\d*)*\]/g;
            var timeRegExpArr = lyric.match(timeReg);
            if(!timeRegExpArr)continue;

            //保存標準歌詞數組
            var clause = lyric.replace(timeReg,'');
            this.lrcArray.push(clause);

            for(var k = 0,h = timeRegExpArr.length;k < h;k++) {
                var t = timeRegExpArr[k];
                var min = Number(String(t.match(/\[\d*/i)).slice(1)),
                    sec = Number(String(t.match(/\:\d*/i)).slice(1));
                var time = min * 60 + sec;

                //保存解析後的歌詞信息對象
                lrcObj[time] = {
                    txt : clause,
                    index : this.lrcArray.length - 1 
                }
            }
        }
        this.lrc = lrcObj;
    };

 

拖拽定位歌詞

 

僞代碼:工具

  1. 獲得歌詞數據對象{時間 : 歌詞} 
  2. 對於一個給定的時間m,尋找小於m而且離m最近的時間
        findLrc : function(second){
            //找到比當前時間小,且離得最近的時間
            //由於歌詞都是在時間以後的
            var min = 1000;
            for( var i in this.lrc){
                if ( i < second &&   Math.abs(second - i) < Math.abs(second - min) ){
                    min = i;
                }
            }
            return this.lrc[min]["index"];
        },

 

綜合上面的功能,我寫了個歌詞解析的小工具. 有興趣的能夠看下  https://github.com/Alan110/desire/tree/master/lrc-analysispost

 

 

參考資料:

 

歌詞解析

http://www.brafox.com/post/2015/HTML5/js解析lrc歌詞-製做滾動歌詞.html

酷狗QRC文件解析-java

酷狗QRC文件解析-php

相關文章
相關標籤/搜索