中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 多媒體制作 > FLASH打造LRC歌詞播放器
用flash從百度搜索中找歌詞 回到列表 ActionScript 3.0 概要
 FLASH打造LRC歌詞播放器

作者:HBrO 時間: 2006-01-09 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 FLASH打造LRC歌詞播放器 [1]
第 2 頁 FLASH打造LRC歌詞播放器 [2]
第 3 頁 FLASH打造LRC歌詞播放器 [3]
第 4 頁 FLASH打造LRC歌詞播放器 [4]

標準歌詞文件范例:

[ti:黑色幽默]
[ar:周杰倫]
[al:Jap]
[by:歌詞吾愛http://www.51lrc.com]
[offset:400]
[00:02.00]詞/曲:周杰倫
[00:05.49]歌詞吾愛
[00:09.48]http://www.51lrc.com
[00:15.84]難過 是因為悶了很久
[00:21.18]是因為想了太多
[00:24.91]是心理起了作用
[00:30.89]你說 苦笑常常陪著你
[00:36.13]在一起有點勉強
[00:39.83]該不該現(xiàn)在休了我
[02:45.62][00:44.86]不想太多
[02:47.71][00:47.41]我想一定是我聽錯弄錯搞錯
[02:53.55][00:53.28]拜托 我想是你的腦袋有問題
[03:00.53][01:00.11]隨便說說
[03:04.49][01:02.47]其實我早已經(jīng)猜透看透不想多說
[03:12.19][01:09.94]只是我怕眼淚撐不住
[03:16.31][01:15.77]不懂 你的黑色幽默
[03:23.51][01:23.25]想通 卻又再考倒我
[03:30.61][01:30.63]說散 你想很久了吧?
[03:37.92][01:37.72]我不想拆穿你
[03:46.16][01:45.85]當作 是你開的玩笑
[03:53.54][01:53.22]想通 卻又再考倒我
[04:16.74][04:01.06][02:00.76]說散 你想很久了吧?

[04:23.15]我的認真敗給黑色幽默

結(jié)構(gòu)分析:
1、文件頭是記錄歌詞信息的文字,下面就是時間跟歌詞內(nèi)容的信息了。
2、每一行都是由一到幾個用中括號標記的時間值及該時間要顯示的歌詞內(nèi)容組成。
如:[04:07.94][02:07.79]敗給你的黑色幽默,代表在2分7秒79跟4分7秒94都顯示"敗給你的黑色幽默"這句歌詞。

了解了LRC文件的結(jié)構(gòu)后,就可以利用AS強大的字符串處理功能,把里頭包含的一些變量值提取出來。

從范例可見:
歌詞文件以行為單位,所以先把文本每行的字符串分別存于一個變量中,但是變量數(shù)目不確定,所以就把變量存于數(shù)組中。

在LOADLYRICS函數(shù)里追加代碼:

var OriginLyrics=new Array();//創(chuàng)建一個存放每行歌詞的數(shù)組對象
OriginLyrics=lyricsString.split(chr(10))//把字符串分析為數(shù)組,分隔符為chr(10)+chr(13)(關(guān)于這個分隔符,筆者其實還是比較模糊,筆者開始不知道歌詞在換行的時候是用了回車符還是換行符.這個分隔符CHR(10)是筆者經(jīng)過多次嘗試后得出來的).
for (var i in originLyrics) {
if (originLyrics[i] == "") {
originLyrics.splice(i, 1);
}
}//歌詞文件里可能有些行是沒內(nèi)容的,這些先刪除,以免對后面的分析造成影響。

但是,我們還發(fā)現(xiàn),有些行是多個時間,只有一句歌詞.其實這是LRC的壓縮格式,為了統(tǒng)一,我們還需要對這些壓縮的部分進行"解壓",使得每行的組成都是一個時間對應一句歌詞。

所以,再定義一個新數(shù)組originLyricsBreak,放置解壓后的歌詞:

下面將以歌詞"[04:07.94][02:07.79]敗給你的黑色幽默"為例,解釋解壓歌詞的代碼:

var originLyricsBreak=new Array();
for (var i in originLyrics) {
var originLyricsUnit = originLyrics[i].split("]");//把每行處理為長度為N的數(shù)組,里頭包含(N-1)個時間信息和一個歌詞信息.
//例句中的歌詞將分為一個長度為3的數(shù)組:三項的內(nèi)容:[04:07.94,[02:07.79,和敗給你的黑色幽默
for (i=0; i<=originLyricsUnit.length-2; i++) {//數(shù)組下標最大值等于(數(shù)組長度-1),這里之用originLyricsUnit.length-2,是因為要把數(shù)組的時間信息枚舉出來,而最后一項是歌詞信息
originLyricsBreak.unshift(originLyricsUnit[i]+"]"+originLyricsUnit[originLyricsUnit.length-1]);//往ORIGINLYRICSBREAK數(shù)組添加一個歌詞項,其中包括一個時間信息和相應的歌詞內(nèi)容
}
//經(jīng)過一次循環(huán)后,ORIGINLYRICSBREAK添加了兩項:
//"[04:07.94]敗給你的黑色幽默"
//"[02:07.79]敗給你的黑色幽默"
}

這樣所列出來的歌詞時間順序是亂的,所以先進行一下排序:
originLyricsBreak.sort();
接下來就對每行歌詞進行時間和歌詞內(nèi)容的提取操作:定義一個數(shù)組LYRICSTEXT存放歌詞內(nèi)容,定義一個數(shù)組TIMESTRING存放時間。

for (var i = originLyricsBreak.length-1; i>=0; i--) {
var tempText = originLyricsBreak[i].split("]")[1]; // 在時間標記"]"的位置,把每行拆分為長度為2的數(shù)組.數(shù)組第一項為時間"[02:07.79",第二項為歌詞內(nèi)容"敗給你的黑色幽默",在這里取第二項:歌詞內(nèi)容
lyricsText.unshift(tempText);//往LYRICSTEXT添加歌詞內(nèi)容項
var tempTimeString = originLyricsBreak[i].split("]")[0].slice(1);//取上述數(shù)組的時間信息"02:07.79",SLICE(1)把"["去掉,
timeString.unshift(tempTimeString);//并添加到時間數(shù)組.
timeValue.unshift(convertToTime(tempTimeString));//因為在TIMESTRING中,它是分:秒.毫秒的形式,不能直接運算,所以要轉(zhuǎn)換為數(shù)字的形式.convertToTime是自定義函數(shù),在下面將會介紹.
}
在LOADLYRICS函數(shù)外定義convertToTime函數(shù):
function convertToTime(str) {
var times = str.split(":");//如果STR為02:07.79,TIMES數(shù)組則有兩項:"02"和"07.79"
return parseInt(times[0])*60+parseFloat(times[1]);//結(jié)果等于2*60+7.79=127.79
}

至此,LRC的分析已經(jīng)完成,下一步就是要讓歌詞同步地顯示出來。

出處:藍色理想
責任編輯:moby

上一頁 FLASH打造LRC歌詞播放器 [1] 下一頁 FLASH打造LRC歌詞播放器 [3]

◎進入論壇Flash專欄版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
Google 視頻下載工具
flash留言本梯度教程(附源)
Accordion組件的使用實例
歌詞同步關(guān)鍵技術(shù)
用flash從百度搜索中找歌詞
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/41個記錄/頁 轉(zhuǎn)到 頁 共4個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2