司南 - 吹灭小山河
<style>#papa { left: -214px; width: 1024px; height: 640px; box-shadow: 3px 3px 20px #000; background: lightblue url('https://638183.freep.cn/638183/Pic/2022/xsh.webp') no-repeat center/cover; user-select: none; position: relative; z-index: 2; }
#btnwrap { position: absolute; right: 20px; top: 20px; width: 100px; height: 100px; display: grid; place-items: center; }
#btnwrap span { position: absolute; transition: all 1.2s; }
#h5player { width: 100px; height: 100px; border-radius: 50%; background: tan conic-gradient(from 0deg, red, green, red 1%, snow 0); mask: radial-gradient(transparent 60%, red 61%, red 0); -webkit-mask: radial-gradient(transparent 60%, red 61%, red 0); }
#btnplay { left: 15px; width: 20px; height: 20px; background: #eee; clip-path: polygon(0 0, 0% 100%, 100% 50%); cursor: pointer; }
#btnplay:hover { background: tomato; }
#btnpause { left: 20px; width: 2px; height: 20px; border-style: solid; border-width: 0px 4px; border-color: transparent #eee; display: none; cursor: pointer; }
#btnpause:hover{ border-color: transparent tomato; }
#tmsg { left: 40px; font: normal 16px sans-serif; color: #ddd; }
#lrctext { position: absolute; right: 140px; top: 50px; font: bold 1.5em sans-serif; color: tomato; text-shadow: 1px 1px 1px #000; transition: 1.2s; }
#lrctext:hover, #tmsg:hover { color: orange; }
</style>
<div id="papa">
<div id="btnwrap">
<span id="h5player"></span><span id="btnplay"></span><span id="btnpause"></span>
<span id="tmsg">00:00<br>00:00</span>
</div>
<div id="lrctext">lrc歌词</div>
</div>
<script>
let aud = new Audio();
let lrcAr = [
['0.00','吹灭小山河 - 国风堂 / 司南'],
['5.02','词:季知拙'],
['10.04','曲:WH宇恒'],
['15.06','曾羡慕闲云野鹤作客人间'],
['19.00','寄情于天地有灵草木无邪'],
['22.04','此生不做万人杰'],
['25.01','赴一株水仙白头约'],
['29.04','当如愿往来山川出入云烟'],
['32.06','萦怀却朝寡夕淡悲欢难辨'],
['35.10','贪过了新鲜便无聊'],
['38.09','倒头梦大千'],
['42.05','始忆依稀烂醉间'],
['44.08','想开怀抱明月'],
['46.06','却潦倒他一身缠绵'],
['49.03','少年轻狂都散尽'],
['51.08','笑敢与他换名姓发誓言'],
['57.06','这天下风情千万般'],
['60.00','值得觊觎一眼'],
['62.03','桃花醒自然'],
['63.04','星斗睡河汉'],
['65.02','不必再舍近求远'],
['66.08','就在他山眉海目间寻风月'],
['71.05','何须问生平长短'],
['73.07','应问何人相伴'],
['75.08','千万人赴宴'],
['77.00','千万人退却'],
['78.08','独他极力上前'],
['80.07','争得你一席并肩'],
['98.09','待重逢秉烛游夜一种悠闲'],
['102.04','人间是万象横看竖成诗篇'],
['106.00','好风比酒还讨人醉'],
['108.06','欠它两碗钱'],
['112.03','手上正挈的灯盏'],
['114.08','他绘海纳百川'],
['116.05','随烛火苗乍明乍现'],
['119.01','任你挑灯看河山'],
['121.06','随手指得哪一座改日看'],
['127.03','这天下风情千万般'],
['129.08','值得觊觎一眼'],
['132.01','桃花醒自然'],
['133.02','星斗睡河汉'],
['134.09','不必再舍近求远'],
['136.06','就在他山眉海目间寻风月'],
['141.02','何须问生平长短'],
['143.04','应问何人相伴'],
['145.05','千万人赴宴'],
['146.08','千万人退却'],
['148.05','独他极力上前'],
['150.06','争得你一席并肩'],
['154.06','此心也曾渴慕千山'],
['157.00','如今爱等风闲'],
['159.02','临窗听雨夜'],
['160.04','笔忆话梦谈'],
['162.04','当年万里觅风月夜航船'],
['165.00','如今江南也不眼馋'],
['168.05','在他山眉海目间'],
['170.06','寻到风花雪月'],
['172.08','温柔而凛冽'],
['173.10','在心上撒野'],
['175.02','覆盖了所有的'],
['177.06','山河岁月天地远']
];
aud.src = 'https://music.163.com/song/media/outer/url?id=1412559986.mp3';
aud.autoplay = true;
aud.loop = true;
btnplay.onclick = () => aud.play();
btnpause.onclick = () => aud.pause();
h5player.onmousemove = (e) => h5player.style.cursor =isHover(e.offsetX, e.offsetY) ? 'pointer' : 'default';
h5player.onclick = (e) => {
if (isHover(e.offsetX, e.offsetY)) {
let deg = Math.atan2(e.offsetY - 50, e.offsetX - 50) * 180 / Math.PI;
deg += (e.offsetX < 50 && e.offsetY < 50) ?450 : 90;
aud.currentTime = aud.duration * deg / 360;
}
}
aud.addEventListener('pause', () => btnstate());
aud.addEventListener('play',() => btnstate());
aud.addEventListener('timeupdate', () => {
tmsg.innerHTML = toMin(aud.currentTime) + '<br>' + toMin(aud.duration);
h5player.style.background = 'conic-gradient(from 0deg, red, green, red ' + aud.currentTime / aud.duration * 100 + '%, snow 0)';
for (j = 0; j < lrcAr.length;j ++) {
if (aud.currentTime >= lrcAr) lrctext.innerHTML = lrcAr;
}
});
let isHover = (x,y) => Math.pow(x - 50, 2) + Math.pow(y - 50, 2) >= Math.pow(40, 2);
let btnstate = () => aud.paused ? (btnplay.style.display = 'block', btnpause.style.display = 'none') : (btnplay.style.display = 'none', btnpause.style.display = 'block');
let toMin = (val)=> {
if (!val) return '00:00';
val = Math.floor(val);
let min = parseInt(val / 60), sec = parseFloat(val % 60);
if (min < 10) min = '0' + min;
if (sec < 10) sec = '0' + sec;
return min + ':' + sec;
}
</script>
原创代码:
<style>
#papa { left: -214px; width: 1024px; height: 640px; box-shadow: 3px 3px 20px #000; background: lightblue url('https://638183.freep.cn/638183/Pic/2022/xsh.webp') no-repeat center/cover; user-select: none; position: relative; z-index: 2; }
#btnwrap { position: absolute; right: 20px; top: 20px; width: 100px; height: 100px; display: grid; place-items: center; }
#btnwrap span { position: absolute; transition: all 1.2s; }
#h5player { width: 100px; height: 100px; border-radius: 50%; background: tan conic-gradient(from 0deg, red, green, red 1%, snow 0); mask: radial-gradient(transparent 60%, red 61%, red 0); -webkit-mask: radial-gradient(transparent 60%, red 61%, red 0); }
#btnplay { left: 15px; width: 20px; height: 20px; background: #eee; clip-path: polygon(0 0, 0% 100%, 100% 50%); cursor: pointer; }
#btnplay:hover { background: tomato; }
#btnpause { left: 20px; width: 2px; height: 20px; border-style: solid; border-width: 0px 4px; border-color: transparent #eee; display: none; cursor: pointer; }
#btnpause:hover{ border-color: transparent tomato; }
#tmsg { left: 40px; font: normal 16px sans-serif; color: #ddd; }
#lrctext { position: absolute; right: 140px; top: 50px; font: bold 1.5em sans-serif; color: tomato; text-shadow: 1px 1px 1px #000; transition: 1.2s; }
#lrctext:hover, #tmsg:hover { color: orange; }
</style>
<div id="papa">
<div id="btnwrap">
<span id="h5player"></span><span id="btnplay"></span><span id="btnpause"></span>
<span id="tmsg">00:00<br>00:00</span>
</div>
<div id="lrctext">lrc歌词</div>
</div>
<script>
let aud = new Audio();
let lrcAr = [
['0.00','吹灭小山河 - 国风堂 / 司南'],
['5.02','词:季知拙'],
['10.04','曲:WH宇恒'],
['15.06','曾羡慕闲云野鹤作客人间'],
['19.00','寄情于天地有灵草木无邪'],
['22.04','此生不做万人杰'],
['25.01','赴一株水仙白头约'],
['29.04','当如愿往来山川出入云烟'],
['32.06','萦怀却朝寡夕淡悲欢难辨'],
['35.10','贪过了新鲜便无聊'],
['38.09','倒头梦大千'],
['42.05','始忆依稀烂醉间'],
['44.08','想开怀抱明月'],
['46.06','却潦倒他一身缠绵'],
['49.03','少年轻狂都散尽'],
['51.08','笑敢与他换名姓发誓言'],
['57.06','这天下风情千万般'],
['60.00','值得觊觎一眼'],
['62.03','桃花醒自然'],
['63.04','星斗睡河汉'],
['65.02','不必再舍近求远'],
['66.08','就在他山眉海目间寻风月'],
['71.05','何须问生平长短'],
['73.07','应问何人相伴'],
['75.08','千万人赴宴'],
['77.00','千万人退却'],
['78.08','独他极力上前'],
['80.07','争得你一席并肩'],
['98.09','待重逢秉烛游夜一种悠闲'],
['102.04','人间是万象横看竖成诗篇'],
['106.00','好风比酒还讨人醉'],
['108.06','欠它两碗钱'],
['112.03','手上正挈的灯盏'],
['114.08','他绘海纳百川'],
['116.05','随烛火苗乍明乍现'],
['119.01','任你挑灯看河山'],
['121.06','随手指得哪一座改日看'],
['127.03','这天下风情千万般'],
['129.08','值得觊觎一眼'],
['132.01','桃花醒自然'],
['133.02','星斗睡河汉'],
['134.09','不必再舍近求远'],
['136.06','就在他山眉海目间寻风月'],
['141.02','何须问生平长短'],
['143.04','应问何人相伴'],
['145.05','千万人赴宴'],
['146.08','千万人退却'],
['148.05','独他极力上前'],
['150.06','争得你一席并肩'],
['154.06','此心也曾渴慕千山'],
['157.00','如今爱等风闲'],
['159.02','临窗听雨夜'],
['160.04','笔忆话梦谈'],
['162.04','当年万里觅风月夜航船'],
['165.00','如今江南也不眼馋'],
['168.05','在他山眉海目间'],
['170.06','寻到风花雪月'],
['172.08','温柔而凛冽'],
['173.10','在心上撒野'],
['175.02','覆盖了所有的'],
['177.06','山河岁月天地远']
];
aud.src = 'https://music.163.com/song/media/outer/url?id=1412559986.mp3';
aud.autoplay = true;
aud.loop = true;
btnplay.onclick = () => aud.play();
btnpause.onclick = () => aud.pause();
h5player.onmousemove = (e) => h5player.style.cursor =isHover(e.offsetX, e.offsetY) ? 'pointer' : 'default';
h5player.onclick = (e) => {
if (isHover(e.offsetX, e.offsetY)) {
let deg = Math.atan2(e.offsetY - 50, e.offsetX - 50) * 180 / Math.PI;
deg += (e.offsetX < 50 && e.offsetY < 50) ?450 : 90;
aud.currentTime = aud.duration * deg / 360;
}
}
aud.addEventListener('pause', () => btnstate());
aud.addEventListener('play',() => btnstate());
aud.addEventListener('timeupdate', () => {
tmsg.innerHTML = toMin(aud.currentTime) + '<br>' + toMin(aud.duration);
h5player.style.background = 'conic-gradient(from 0deg, red, green, red ' + aud.currentTime / aud.duration * 100 + '%, snow 0)';
for (j = 0; j < lrcAr.length;j ++) {
if (aud.currentTime >= lrcAr) lrctext.innerHTML = lrcAr;
}
});
let isHover = (x,y) => Math.pow(x - 50, 2) + Math.pow(y - 50, 2) >= Math.pow(40, 2);
let btnstate = () => aud.paused ? (btnplay.style.display = 'block', btnpause.style.display = 'none') : (btnplay.style.display = 'none', btnpause.style.display = 'block');
let toMin = (val)=> {
if (!val) return '00:00';
val = Math.floor(val);
let min = parseInt(val / 60), sec = parseFloat(val % 60);
if (min < 10) min = '0' + min;
if (sec < 10) sec = '0' + sec;
return min + ':' + sec;
}
</script>
本帖播放器HTML文档,要求放置于 position 设定为 relative 的父元素。以下HTML代码的完整性在帖子代码中应保持原样:
<div id="btnwrap">
<span id="h5player"></span><span id="btnplay"></span><span id="btnpause"></span>
<span id="tmsg">00:00<br>00:00</span>
</div>
其中,id 为 btnwrap 的 div 是播放器的归拢元素,它在CSS中已经设定为绝对定位,所有播放器部件(歌词除外)将跟随它进行物理定位。要部署播放器在帖子中的物理位置,请两两配套更改其 left、right ↔ top、bottom 属性。
lrc歌词所在元素的位置设定独立于播放器,更改相关属性请修改CSS中的 #lrctext 选择器对应属性。
JS代码,能修改的部分主要是歌词与进度颜色,若在CSS中修改了播放器的尺寸,则JS代码中,如下一行中的红色数字,要相应改为 btnwrap 的宽高尺寸的一半(其下子元素可能也需要更改相关CSS属性):
let deg = Math.atan2(e.offsetY - 50, e.offsetX - 50) * 180 / Math.PI;
本帖背景图片来源于网络,除使用中设定了显示尺寸,未做任何改动 播放器中的播放、暂停按钮,播放按钮用 clip-path 剪裁做成,暂停按钮用边框模拟。 这个圆圈播放器还加了播放按钮,真是越来越完善了{:4_187:} 黑黑朋友下午好!我没听过这支歌曲,但很好听,节奏欢快、婉转动听。 梦油 发表于 2022-8-30 17:11
黑黑朋友下午好!我没听过这支歌曲,但很好听,节奏欢快、婉转动听。
司南唱的歌速度偏快 这个是昨天后来修改的那个吧,果然黑黑每天有精彩{:4_199:} 马黑黑 发表于 2022-8-30 18:46
司南唱的歌速度偏快
是的,我也感觉到了。 梦油 发表于 2022-8-30 20:12
是的,我也感觉到了。
去年,看过一部电视剧,有她的演唱,所以记得 小辣椒 发表于 2022-8-30 19:30
这个是昨天后来修改的那个吧,果然黑黑每天有精彩
还行的吧 就是没听懂唱的是啥了 绿叶清舟 发表于 2022-8-30 20:25
就是没听懂唱的是啥了
没听懂就看看歌词 马黑黑 发表于 2022-8-30 20:26
没听懂就看看歌词
没文化啊,现在的很多新歌,歌词大多是看不懂的了 绿叶清舟 发表于 2022-8-30 20:29
没文化啊,现在的很多新歌,歌词大多是看不懂的了
这个歌词,如果度过金庸琼瑶,一点都不会感到陌生 马黑黑 发表于 2022-8-30 20:31
这个歌词,如果度过金庸琼瑶,一点都不会感到陌生
他俩的看过不少的啊,咋没感觉有联系的啊 制作得真漂亮,还付代码与讲解,老黑真好!{:4_199:} 加林森 发表于 2022-8-31 19:16
制作得真漂亮,还付代码与讲解,老黑真好!
{:5_108:} 马黑黑 发表于 2022-8-31 19:18
{:4_191:}
页:
[1]