|
|

楼主 |
发表于 2022-8-30 07:01
|
显示全部楼层
原创代码:
- <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[j][0]) lrctext.innerHTML = lrcAr[j][1];
- }
- });
- 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>
复制代码
|
评分
-
| 参与人数 1 | 威望 +50 |
金钱 +100 |
经验 +50 |
收起
理由
|
红影
| + 50 |
+ 100 |
+ 50 |
赞一个! |
查看全部评分
|