jquery 实现实时歌词更新

最近自己写了个移动端音乐播放器,用了很多框架,也踩了很多坑,感觉比较复杂的就是计算歌词实时播放了,大概给整理了一下:

布局

(歌词都是后台数据获取,方便理解我把所有歌词都一一列出来)

<section>
    <figure>
        <img id="animat" src="img/img3.jpg"/>
    </figure>
    <div class="lyric">
        <div class="lrc-list">
            <p data-play="audio-t-0" data-index="0">逃跑计划 </p>
            <p data-play="audio-t-1" data-index="1">一万次悲伤 </p>
            <p data-play="audio-t-2" data-index="2">oh honey </p>
            <p data-play="audio-t-3" data-index="3">我脑海里全都是你 </p>
            <p data-play="audio-t-8" data-index="4">oh无法抗拒的心情 </p>
            <p data-play="audio-t-13" data-index="5">难以呼吸</p>
            <p data-play="audio-t-15" data-index="6">tonight </p>
            <p data-play="audio-t-17" data-index="7">是否又要错过一个夜晚</p>
            <p data-play="audio-t-23" data-index="8">是否还要掩饰最后的期待 </p>
            <p data-play="audio-t-29" data-index="9">oh tonight </p>
            <p data-play="audio-t-30" data-index="10">一万次悲伤 </p>
            <p data-play="audio-t-33" data-index="11">依然会有意义</p>
            <p data-play="audio-t-35" data-index="12">我一直在最温暖的地方等你</p>
            <p data-play="audio-t-40" data-index="13">似乎只能这样停留一个方向</p>
            <p data-play="audio-t-46" data-index="14">已不能改变</p>
            <p data-play="audio-t-51" data-index="15">每一颗眼泪是遗忘的光 </p>
            <p data-play="audio-t-57" data-index="16">最昏暗的地方也变得明亮</p>
            <p data-play="audio-t-61" data-index="17">我奔涌的暖流寻找你的海洋 </p>
            <p data-play="audio-t-67" data-index="18">我注定这样</p>
            <p data-play="audio-t-73" data-index="19">oh honey </p>
            <p data-play="audio-t-75" data-index="20">你目光里充满忧郁 </p>
            <p data-play="audio-t-81" data-index="21">就像经历一遍飞行难以逃避</p>
            <p data-play="audio-t-87" data-index="22">tonight </p>
            <p data-play="audio-t-89" data-index="23">是否还要错过这个夜晚</p>
            <p data-play="audio-t-91" data-index="24">是否还要熄灭所有的期待</p>
            <p data-play="audio-t-95" data-index="25">tonight</p>
            <p data-play="audio-t-100" data-index="26">一万次悲伤</p>
            <p data-play="audio-t-102" data-index="27">依然会有意义</p>
            <p data-play="audio-t-106" data-index="28">我一直在最后的地方等你</p>
            <p data-play="audio-t-109" data-index="29">似乎只能这样</p>
            <p data-play="audio-t-114" data-index="30">停留一个方向</p>
            <p data-play="audio-t-120" data-index="31">已不能改变</p>
            <p data-play="audio-t-123" data-index="32">每一颗眼泪是遗忘的光</p>
            <p data-play="audio-t-130" data-index="33">最昏暗的地方也变得明亮</p>
            <p data-play="audio-t-135" data-index="34">我奔涌的暖流寻找你的海洋</p>
            <p data-play="audio-t-141" data-index="35">我注定这样</p>
            <p data-play="audio-t-155" data-index="36">一万次悲伤 </p>
            <p data-play="audio-t-189" data-index="37">依然会有意义</p>
            <p data-play="audio-t-192" data-index="38">我一直在最后的地方等你</p>
            <p data-play="audio-t-197" data-index="39">似乎只能这样</p>
            <p data-play="audio-t-200" data-index="40">停留一个方向 </p>
            <p data-play="audio-t-204" data-index="41">已不能改变</p>
            <p data-play="audio-t-208" data-index="42">每一颗眼泪是遗忘的光</p>
            <p data-play="audio-t-213" data-index="43">最昏暗的地方也变得明亮</p>
            <p data-play="audio-t-218" data-index="44">我奔涌的暖流寻找你的海洋</p>
            <p data-play="audio-t-225" data-index="45">我注定这样</p>
            <p data-play="audio-t-236" data-index="46">oh honey </p>
            <p data-play="audio-t-238" data-index="47">我脑海里全都是你 </p>
            <p data-play="audio-t-243" data-index="48">oh无法抗拒的心情 </p>
            <p data-play="audio-t-247" data-index="49">难以呼吸</p>
        </div>
    </div>      
</section>

PS : 给每一句歌词都自定义两个属性,data-play属性为了计算什么时候显示该句歌词,它的属性值audio-t- “num” 是表示这句歌词在num秒的时候高亮显示; data-index为了计算什么时候歌词往上走,就按顺序定义就行。
以下是静态效果图:

Paste_Image.png

(效果图没有歌词是因为左滑才出现歌词)

左滑出现歌词

$('figure').on("swipeLeft" , function(){
    $('figure').css('display' , 'none');
    $('.lyric').css('display' , 'block').addClass("animated slideInRight");
})
$('.lyric').on("swipeRight" , function(){
    $('.lyric').css('display' , 'none');
    $('figure').css('display' , 'block').addClass("animated slideInLeft");
})

歌词出现:

Paste_Image.png

重点来了

function lyricPlay(){
    var timer2;
    var $cur = null;
    var $lrcbox = $(".lrc-list");
    $lrcwrap = $lrcbox.parent();
    clearInterval(timer2);
    timer2 = setInterval( function(){
        var time = Math.ceil( $('audio')[0].currentTime); //currentTime 是获取音乐实时播放时间
        $cur = $("audio-t-"+time).selector;//拿到自定义属性data-play
        $('p' , $lrcbox ).each(function(){ //循环拿到p
            var playT =  $(this).data('play');//当前播放元素属性值
                if( playT == $cur  ){ 
                   //给符合条件歌词加上高亮并删除兄弟元素的class名
                    $(this).stop().addClass('acitve').siblings().removeClass('acitve');
                }else{
                    return;
                }
            var index = $(this).data("index");    //当前元素下标
            var lineHeight =$(this).height() ;    //一行歌词高度
            var boxHeight = $lrcwrap.height(); //歌词显示区域高度
            var screensize = boxHeight / lineHeight; //一屏显示多少句歌词
            var half = Math.floor(screensize / 2);   //半屏歌词数量
            //当前歌词超过半屏
            if(index > half){
                //计算出超过的高度 减去 一行歌词的高度
                var top = (half - index) * lineHeight + lineHeight
                $lrcbox.css({
                    "top" : parseInt(top) + "px"
                });
            }
        })
    } , 1000)
}
lyricPlay();

效果如下:

Paste_Image.png

当然以上方法都只是我自己的想法,不足之处欢迎指点。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,082评论 4 62
  • 教程一:视频截图(Tutorial 01: Making Screencaps) 首先我们需要了解视频文件的一些基...
    90后的思维阅读 4,689评论 0 3
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,988评论 25 707
  • 当一只雏鸟要孵化出来的时候,如果有人替它把蛋壳弄破,那只小鸟就会死去。雏鸟必须自己设法把蛋壳啄破,进入这...
    君君Love阅读 244评论 0 0
  • 文/祝小妞 第一次觉得父母老了,是在大一第一次回家。现在再想,好多的细节都已经记不清了,只记得那时母亲瘦了、头发白...
    祝小妞阅读 775评论 20 41