導航:首頁 > 編程語言 > js讀取lrc

js讀取lrc

發布時間:2025-02-12 09:09:24

① 關於播放器中的功能(歌詞同步),急求VB.NET代碼!!

思路很簡單可以定義一個結構LyricStructure Lyric
Dim Time As Single
Dim Content As String
End Structure聲明一個列表 Private Lyrics As New List(Of Lyric)然後以文本方式把歌詞文件讀入一個變數 並對它進行分析 分別把時間和歌詞內容存入一個Lyric,並加入Lyrics中。代碼如下:(假設歌曲文件的路徑為path)Dim LrcPath As String== IO.Path.GetDirectoryName(cPath) & "/" & IO.Path.GetFileNameWithoutExtension(cPath) & ".lrc"If IO.File.Exists(LrcPath= True Then AnalysisLyric() Private Sub AnalysisLyric()
Lyrics.Clear() '先清空列表
Dim tm As Byte
Dim sr As New IO.StreamReader(LrcPath, System.Text.Encoding.Default) '讀取歌詞文件
Do While sr.EndOfStream = False '判斷是否處於文件流末尾
Dim tmpStr As String = sr.ReadLine '讀取一行
If tmpStr.Length < 5 Then Continue Do '長度小於5則跳過,進行下一次循環
Select Case Mid(tmpStr, 2, 2) '判斷第2-3個字元 因為歌詞里的注釋都是[ti:***]類似的結構
Case "ti"
lTitle = Mid(tmpStr, 5, tmpStr.Length - 5)
Case "ar"
lArtist = Mid(tmpStr, 5, tmpStr.Length - 5)
Case "al"
lAlbum = Mid(tmpStr, 5, tmpStr.Length - 5)
Case "by"
lAuthor = Mid(tmpStr, 5, tmpStr.Length - 5)
Case Else '如果不為以上的內容 則為歌詞正文,進行以下操作
If Not Mid(tmpStr, 1, 6) Like "?##:##" Then Continue Do
Dim time(-1) As String '因為有時歌詞是以[00:00.00][00:00.00]**** 這樣歌詞把多個時間存放在一起的 ,所以定義一個數組來存放歌詞
Do '因為不確定時間的個數,所以此處必須循環判斷
tm = InStr(tmpStr, "]") '因為歌詞時間有時是[00:00.00]形式,有時是[00:00]形式,所以不能單純的截取第幾個字元 ,我是根據查找']'字元來進行判斷的
ReDim Preserve time(time.GetUpperBound(0) + 1) 為time數組重新分配大小
time(time.GetUpperBound(0)) = Mid(tmpStr, 1, tm) 'time.GetUpperBound(0)返回數組的第一維的最大下標
tmpStr = IIf(tmpStr.Length = tm, " ", Mid(tmpStr, tm + 1)) '歌詞內容
Loop While Mid(tmpStr, 1, 6) Like "?##:##" '如果截取剩下的部分依然匹配的話繼續循環
For Each t In time '為每個時間都創建一個Lyric變數
Dim ln As Lyric
ln.Time = SwitchTime(Mid(t, 2, t.Length - 2))
ln.Content = tmpStr
Lyrics.Add(ln)
Next
End Select
Loop
sr.Close() 關閉流
Sort() '把所有Lyric按時間順序排序
End Sub Private Function SwitchTime(ByVal time As String) As Single 『這個函數是用來把00:00.00格式的時間轉化成以秒數顯示的數值
Dim tm As Single
Dim minute As Single = Val(Mid(time, 1, 2))
Dim second As Single = Val(Mid(time, 4, 5))
tm = minute * 60 + second
Return tm
End Function Private Sub Sort()
For i = 0 To Lyrics.Count - 2
For j = i To Lyrics.Count - 1
If Lyrics(i).Time > Lyrics(j).Time Then
Dim tm As Lyric = Lyrics(i)
Lyrics(i) = Lyrics(j)
Lyrics(j) = tm
End If
Next
Next
End Sub 接下來是顯示歌詞的問題了 ,只要有每句歌詞和對應的時間,那麼問題就好辦了。你可以用Windows Media Player控制項返回的時間和每句歌詞的時間做比較,來判斷應該顯示那一句。代碼是很久前寫的 ,那時沒加註釋,都是剛剛加上去的喲,你可以根據你的實際情況自己修改,有什麼不懂的地方可以繼續問我哈~~

② 我需要一個js正則來解析歌詞文件

var str='[00:00.91]春暖花開[00:01.64]演唱:那英[00:03.01][00:21.23]如果你渴求一滴水\n';

str=str.replace(/\]\[/g,'] [');//"]["沒有空格會影響匹配結果

var arr=str.match(/(\[\d{2}:\d{2}\.\d{2}\])(.[^\[\]]*)?/g);
var time=[],txt=[];

for(var i=0;i<arr.length;i++){
/^(\[\d{2}:\d{2}\.\d{2}\])(.[^\[\]]*)?$/.exec(arr[i]);
time.push(RegExp.$1);
txt.push(RegExp.$2);
}

alert(arr);
alert(time);
alert(txt);

③ 如何用原生js或者jq或者css3製作會動的歌詞

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Player</title>
<style type="text/css">
#audio-wrapper{
border:1px solid;
text-align:center;
}
.activated{
color:#33b;
font-weight:bold;
background:#ddf;
}
#lrc{
text-align:center;
width:360px;
height:400px;
overflow:hidden;
border:2px solid #ddd;
box-shadow:2px 2px 2px silver;
}
.lyrics-container{
position:relative;
width:99%;
height:80%;
border:1px solid red;
overflow:hidden;
}
.lyrics-container2{
position:absolute;
width:355px;
}
#lrc p{
text-indent:0;
margin:0;
padding:6px;
}
.music-title,.album,.artist{
margin:0;
padding:4px;
text-indent:0;
text-align:left;
}
</style>
<script type="text/javascript" src="js/jquery-2.1.4.min.js"></script>
</head>
<body>
<div id="#audio-wrapper">
<p><audio src="data/aimei.mp3" controls></audio></p>
</div>
<div id="lrc"></div>
<script type="text/javascript">
$(document).ready(function(){
var $lrc = $('#lrc');
var html ='';
$('audio').on('play',function(){
var start = new Date();
if($lrc.html() == ''){
$.ajax({
url:'data/aimei.xml',
type:'get',
dataType:'xml',
success:function(data){
html += '<div class="info">';
if($(data).find('TITLE').length > 0){
html += '<p class="music-title">歌曲:' + $(data).find('TITLE').text()+'</p>';
}
if($(data).find('ALBUM').length > 0){
html += '<p class="album">專輯:' + $(data).find('ALBUM').text()+'</p>';
}
if($(data).find('ARTIST').length > 0){
html += '<p class="artist">演唱:' + $(data).find('ARTIST').text()+'</p>';
}
html += '</div>';
html += '<div class="lyrics-container">'
html += '<div class="lyrics-container2">'
$(data).find('LRC').each(function(){
html += '<p class="lyrics" tag="'+ $(this).attr('TAG') +'">' + $(this).text() +'</p>';
});
html += '</div></div>';
$lrc.html(html);
//alert($(data).find('LRC').length);
}
});
}
var timer = setInterval(function(){
var now = new Date();
var elapsed = now - start;
if($lrc.find('.lyrics').length){
$lrc.find('.lyrics').each(function(){
var isOK = elapsed - $(this).attr('tag');
if(isOK < 13 && isOK > 0){
$lrc.find('.lyrics').removeClass('activated');
$(this).addClass('activated');
if($(this).prevAll('.lyrics').length > 3){
$('.lyrics-container2').animate({
'top':'-=30px'
});
//console.log($(this).prevAll('.lyrics').length);
}
}
});
}
},10);
});
});
</script>
</body>
</html>

閱讀全文

與js讀取lrc相關的資料

熱點內容
守護永恆的愛新版本 瀏覽:714
系統文件被隱藏 瀏覽:516
初中烏龜編程軟體叫什麼 瀏覽:261
iphone6關閉簡訊預覽 瀏覽:379
什麼天氣預報app准確率高 瀏覽:562
有什麼放單的淘客網站 瀏覽:669
為什麼蘋果app無法下載應用程序 瀏覽:724
各種各樣的工具圖片大全 瀏覽:586
遇夢app怎麼錄歌 瀏覽:309
電腦怎麼重新連接網路 瀏覽:662
如何建bat文件 瀏覽:15
蘋果微信搖色子輔助器 瀏覽:649
圖片的字模糊怎麼變清晰用什麼app 瀏覽:180
貼吧文件區在哪 瀏覽:968
港版lgg4軟體版本 瀏覽:540
編程軟體如何上傳文件 瀏覽:520
阜陽交通運輸局網站多少 瀏覽:435
bt電腦怎麼打開文件 瀏覽:886
快手直播伴侶安卓手機版 瀏覽:899
yy其他版本下載軟體 瀏覽:814

友情鏈接