html怎么实现拖拽进度条同步音乐,js实现音频控制进度条功能

效果图:

56a92c7c00d47f750f52e1621e928d8d.png

代码如下:

音频控制进度条

body,div{padding: 0;margin: 0;}

.m-main{width:560px; height: 100%; margin: 3% auto; background-color:#30a5ff;}

.m-main video{display: none; }

.m-main .player {

width: 100%;

height: 150px;

position: relative;

bottom: 0px;

}

.m-main .player>a{display: inline-block; width: 20%; margin: 0 auto; padding: 5%; color: #FFF; text-align: center;}

.m-main .play-box {

width: 100%;

margin: 0 auto;

}

.m-main .play-box .left {

width: 100%;

float: left;

}

.m-main .play-box .left p.timeline { width: 70%;height: 10px; background-color: rgba(216, 216, 216, 0.5); border-radius: 5px; margin:30px auto 0; position: relative; z-index: 2; }

.m-main .play-box .left p.timeline span {position: relative; width: 0px; height: 10px; background-color: #FFF; border-radius: 5px; display: block; -webkit-transition: width ease-out 0.3s;-o-transition: width ease-out 0.3s;transition: width ease-out 0.3s;}

.m-main .play-box .left p.timeline span:after{content: ""; position: absolute; top: -4px; right:-0.6rem;width: 1.2rem; height:1.2rem; border-radius: 50%;background-color: #FFF;}

.m-main .play-box .left div.info { height: 26px; line-height: 26px; font-size: 14px; color: #000; position: relative; top: -18px; margin:0 10px; z-index: 1;color: #FFF;}

.m-main .play-box .left div.info .size { float: left; display: block;}

.m-main .play-box .left div.info .timeshow { float: right; display: block;}

播放

暂停

00:00

00:00

$(function(){

AudioControl('js-video')

function AudioControl(id){

// 音频控制进度条

var audio = document.getElementById(id);

$(audio).on('loadedmetadata',function(){

audio.pause();

// 进度条控制

$(document).on('touchend','.timeline',function(e){

var x = e.originalEvent.changedTouches[0].clientX-this.offsetLeft;

var X = x < 0 ? 0 : x ;

var W = $(this).width();

var place = X > W ? W : X;

audio.currentTime = (place/W).toFixed(2)*audio.duration

$(this).children().css({width:(place/W).toFixed(2)*100+"%"})

});

// 播放

$(document).on('click','#js-play',function(){

audio.play()

});

// 暂停

$(document).on('click','#js-pause',function(){

audio.pause()

});

})

setInterval(function () {

var currentTime = audio.currentTime;

setTimeShow(currentTime);

}, 1000);

// 设置播放时间

function setTimeShow(t) {

t = Math.floor(t);

var playTime = secondToMin(audio.currentTime);

$(".size").html(playTime);

$('.timeshow').text(secondToMin(audio.duration))

$('.timeline').children().css({width:(t/audio.duration).toFixed(4)*100+"%"})

}

// 计算时间

function secondToMin(s) {

var MM = Math.floor(s / 60);

var SS = s % 60;

if (MM < 10)

MM = "0" + MM;

if (SS < 10)

SS = "0" + SS;

var min = MM + ":" + SS;

return min.split('.')[0];

}

}

})

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值