這篇文章將為大家詳細(xì)講解有關(guān)Flex播放器如何同步顯示歌詞,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
站在用戶的角度思考問題,與客戶深入溝通,找到凌云網(wǎng)站設(shè)計與凌云網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋凌云地區(qū)。
Flex播放器同步顯示歌詞
播放歌曲時要同步顯示歌詞,首先必須要能解析出lrc格式的歌詞文本,之前我還準(zhǔn)備直接在網(wǎng)上匹配下載對應(yīng)歌詞,打開我機(jī)器的千千靜音在線匹配歌詞,然后用HTTPAnalyzerStdV監(jiān)視所有的http請求,發(fā)現(xiàn)它是請求這個ttlrcct.qianqian.com網(wǎng)站下載歌詞,本來還是直接套用千千靜音服務(wù)器下載歌詞,但是它的url參數(shù)全部加密了。后來又看了下酷狗音樂,它里面下載歌詞我都監(jiān)視不請求,考慮到就算我能在線找到下載歌詞的url地址,flash里發(fā)送遠(yuǎn)程請求也會有安全殺箱問題,所以最終放棄直接在網(wǎng)絡(luò)上下載歌詞的辦法,還是全部上傳到我網(wǎng)站上去。lrc歌詞其實就是一個文本格式的文件,在Flex播放器里面我們可以使用URLLoader去加載,代碼如下:
Java代碼
加載歌詞varlrcUrl:String=xml.item[currIndex].lrc; if(lrcUrl!=null&&lrcUrl!=""){varlrc:URLLoader=newURLLoader();//lrc.dataFormat=URLLoaderDataFormat.VARIABLES; lrc.load(newURLRequest(lrcUrl));lrc.addEventListener(Event.COMPLETE,LRC_Complete); lrc.addEventListener(IOErrorEvent.IO_ERROR,LRC_IOError);}lrcArr=null; outPutLRCString="";startIndexOf=0;txtLrc.text="";
然后在加載完成的事件里,我們能得到lrc文本字符串,這時候我們需要對字符串進(jìn)行處理,把它轉(zhuǎn)換成一個Array數(shù)組,函數(shù)方法如下:
publicfunctiongetLRCArray(lrc:String):Array{varlrcArr:Array=newArray;lrc+="\r";for(vari:int=0;i<lrc.length;i++){vartime:Number=0; if(lrc.charAt(i)==":"){time=Number(lrc.slice(i-2,i))*60+Number(lrc.slice(i+1,i+3)); if(String(time)!="NaN"){varj:uint=0;varstartIndex:uint=0;varendIndex:uint=0; do{j++;if(lrc.charAt(i+j)=="]"){startIndex=i+j+1;}}while(i+j<lrc.indexOf("\r",i))endIndex=lrc.indexOf("\r",i); if(startIndex!=0&&endIndex!=0){lrcArr.push([time,lrc.slice(startIndex,endIndex)]);}}}}returnlrcArr;}
解析歌詞返回的Array數(shù)組為多圍數(shù)組,數(shù)組里的每一項是為一個二圍數(shù)組,item[0]為當(dāng)前秒數(shù),item[1]為該秒顯示的歌詞(句),比如item[0]=歌曲名:你最近還好嗎、item[5]=演唱:S.H.E,就是代表第0秒顯示歌曲名:你最近還好嗎,而從第5秒起則顯示演唱:S.H.E,這樣通過getLRCArray方法就能得到歌曲所有的時間段顯示的歌詞拉。本例中把所有歌詞放在一個editable="false"不可修改的mx:TextArea文本域內(nèi)。
歌詞同步顯示的問題
歌詞能全部加載顯示了,問題是怎么隨著Flex播放器歌曲的播放而高亮顯示當(dāng)前行歌詞呢?不過還好Flex提供一個TextRange能對TextArea內(nèi)文本進(jìn)行選擇性的處理,你只需要設(shè)置beginIndex和endIndex就能自動匹配到TextArea中間區(qū)域的文本,我這里只是簡單的改變了一下顏色,不過我們從TextArea中找某一個句歌詞索引的時候需要注意歌詞有很多是重復(fù)的,所以我們需要用一個變量保存當(dāng)前歌詞播放位置索引startIndexOf,以確保我們高亮選擇到的歌詞是正確的。同時將TextArea滾動條設(shè)置到對應(yīng)的高度,主要的代碼如下:
//同步顯示歌詞if(lrcArr!=null&&lrcArr.length>0){varsec:Number=int(channel.position/1000); for(varj:int=0;j<lrcArr.length;j++){if(lrcArr[j][0]==sec){varcurrentLrc:String=lrcArr[j][1]; if(currentLrc!=this.currLrc.text){currLrc.text=currentLrc; //高亮顯示,先清空之前高亮部分vartr:TextRange=newTextRange(txtLrc);tr.color=this.getStyle("color"); varbeginIndex:int=this.outPutLRCString.indexOf(currentLrc,startIndexOf);startIndexOf+=currentLrc.length; varendIndex:int=beginIndex+currentLrc.length; tr.beginIndex=beginIndex;tr.endIndex=endIndex;if(tr.text!=""){tr.color="yellow";}//設(shè)置滾動條位置this.txtLrc.verticalScrollPosition=j*this.txtLrc.maxVerticalScrollPosition/lrcArr.length;if(lrcArr.length-j<=5)thisthis.txtLrc.verticalScrollPosition=this.txtLrc.maxVerticalScrollPosition;}break;}}} /加載歌詞varlrcUrl:String=xml.item[currIndex].lrc;if(lrcUrl!=null&&lrcUrl!=""){varlrc:URLLoader=newURLLoader(); //lrc.dataFormat=URLLoaderDataFormat.VARIABLES;lrc.load(newURLRequest(lrcUrl)); lrc.addEventListener(Event.COMPLETE,LRC_Complete); lrc.addEventListener(IOErrorEvent.IO_ERROR,LRC_IOError);}lrcArr=null;outPutLRCString="";startIndexOf=0;txtLrc.text="";
然后在加載完成的事件里,我們能得到lrc文本字符串,這時候我們需要對字符串進(jìn)行處理,把它轉(zhuǎn)換成一個Array數(shù)組,函數(shù)方法如下:
publicfunctiongetLRCArray(lrc:String):Array{varlrcArr:Array=newArray;lrc+="\r"; for(vari:int=0;i<lrc.length;i++){vartime:Number=0; if(lrc.charAt(i)==":"){time=Number(lrc.slice(i-2,i))*60+Number(lrc.slice(i+1,i+3)); if(String(time)!="NaN"){varj:uint=0;varstartIndex:uint=0;varendIndex:uint=0; do{j++;if(lrc.charAt(i+j)=="]"){startIndex=i+j+1;}}while(i+j<lrc.indexOf("\r",i))endIndex=lrc.indexOf("\r",i); if(startIndex!=0&&endIndex!=0){lrcArr.push([time,lrc.slice(startIndex,endIndex)]);}}}}returnlrcArr;}
解析歌詞返回的Array數(shù)組為多圍數(shù)組,數(shù)組里的每一項是為一個二圍數(shù)組,item[0]為當(dāng)前秒數(shù),item[1]為該秒顯示的歌詞(句),比如item[0]=歌曲名:你最近還好嗎、item[5]=演唱:S.H.E,就是代表第0秒顯示歌曲名:你最近還好嗎,而從第5秒起則顯示演唱:S.H.E,這樣通過getLRCArray方法就能得到歌曲所有的時間段顯示的歌詞拉。
關(guān)于“Flex播放器如何同步顯示歌詞”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
分享文章:Flex播放器如何同步顯示歌詞
瀏覽路徑:http://jinyejixie.com/article26/jjigjg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、搜索引擎優(yōu)化、網(wǎng)站營銷、定制開發(fā)、App設(shè)計、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)