|
|

楼主 |
发表于 2022-11-1 07:29
|
显示全部楼层
本帖最后由 马黑黑 于 2022-11-1 20:58 编辑
参考代码(全)- <style>
- #papa {
- --state: paused;
- margin: auto;
- width: 1262px;
- height: 710px;
- background: #666 url('https://638183.freep.cn/638183/t22/webp/sumk.webp') no-repeat center/cover;
- box-shadow: 3px 3px 20px #000;
- display: grid;
- place-items: center;
- opacity: .95;
- position: relative;
- z-index: 1;
- }
- #papa::before {
- position: absolute;
- content: '';
- left: 0;
- top: 0;
- bottom: 0;
- right: 0;
- background: #000;
- opacity: .0;
- animation: darker linear 1.2s infinite alternate;
- transition: all 1.2s;
- animation-play-state: var(--state);
- }
- #mplayer {
- position: absolute;
- display: grid;
- grid-template-areas: 'cur btnplay dur''prog prog prog';
- gap: 4px;
- place-items: end center;
- font-size: 14px;
- bottom: 20px;
- }
- #cur {
- grid-area: cur;
- color: snow;
- }
- #dur {
- grid-area: dur;
- color: snow;
- }
- #btnplay {
- grid-area: btnplay;
- display: grid;
- grid-auto-flow: column;
- place-items: end center;
- gap: 0 4px;
- height: 60px;
- cursor: pointer;
- }
- #btnplay>span {
- background: red;
- width: 4px;
- transition: .6s;
- opacity: .95;
- }
- #prog {
- --ww: 0px;
- grid-area: prog;
- width: 300px;
- height: 12px;
- border-radius: 6px;
- background: snow;
- opacity: .65;
- cursor: pointer;
- position: relative;
- }
- #prog::before {
- position: absolute;
- content: '';
- width: var(--ww);
- height: 12px;
- border-radius: 6px;
- background: snow linear-gradient(90deg, green, red);
- opacity: .65;
- }
- #lrc {
- --motion: cover1;
- --tt: 5s;
- position: absolute;
- top: 20px;
- font: bold 2.4em sans-serif;
- color: hsl(0, 10%, 90%);
- -webkit-background-clip: text;
- filter: drop-shadow(1px 1px 2px hsla(0, 0%, 0%, .95));
- }
- #lrc::before {
- position: absolute;
- content: attr(data-lrc);
- width: 20%;
- height: 100%;
- color: transparent;
- overflow: hidden;
- white-space: nowrap;
- background: linear-gradient(180deg, hsla(60, 0%, 0%, .45), hsla(60, 100%, 50%, .75));
- filter: inherit;
- -webkit-background-clip: text;
- animation: var(--motion) var(--tt) linear forwards;
- animation-play-state: var(--state);
- }
- @keyframes cover1 {
- from { width: 0; }
- to { width: 100%; }
- }
- @keyframes cover2 {
- from { width: 0; }
- to { width: 100%; }
- }
- @keyframes darker {
- from { opacity: 0; }
- to { opacity: .45; }
- }
- </style>
- <div id="papa">
- <div id="lrc" data-lrc="花潮lrc在线">花潮lrc在线</div>
- <div id="mplayer">
- <div id="cur">00:00</div>
- <div id="btnplay"></div>
- <div id="dur">00:00</div>
- <div id="prog"></div>
- </div>
- <audio id="aud" src="https://music.163.com/song/media/outer/url?id=1968070479.mp3" loop autoplay></audio>
- </div>
- <script>
- (function() {
- let mKey = 0,
- mFlag = true;
- let lrcAr = [
- [0.1, "宿命", 21.3],
- [21.39, "演唱:祁松涛", 11.0],
- [32.4, "雨不知花开", 5.6],
- [39.57, "宿命是寂寞", 5.8],
- [45.96, "撒满晚秋摇曳的一瞬间", 6.1],
- [53.19, "起舞后只等凋落", 7.7],
- [63.24, "夜不知烟火", 5.8],
- [70.44, "失去的自我", 6.3],
- [76.86, "遥上星空灿烂的那一刻", 6.4],
- [84.12, "或许在等谁记得", 8.2],
- [93.24, "我将时间上锁留住蹉跎", 8.0],
- [101.49, "把一生都交给你去挥霍", 6.0],
- [107.85, "等白发苍苍时再听你说", 8.0],
- [115.95, "这一遭你不后悔曾走过", 5.7],
- [124.14, "我将爱的轮廓布满星河", 7.8],
- [132.24, "数不清我的思念有几颗", 6.0],
- [138.72, "就算有一天我不再闪烁", 7.8],
- [146.91, "拼了命此生只为你而活", 6.2],
- [186, "我将时间上锁留住蹉跎", 7.6],
- [194.22, "把一生都交给你去挥霍", 5.8],
- [200.49, "等白发苍苍时再听你说", 8.0],
- [208.68, "这一遭你不后悔曾走过", 6.3],
- [216.87, "我将爱的轮廓布满星河", 7.6],
- [225, "数不清我的思念有几颗", 6.2],
- [231.39, "就算有一天我不再闪烁", 7.7],
- [239.58, "拼了命此生只为你而活", 6.1],
- [246.96, "拼了命此生只为你而活", 11.3]
- ];
- for (j = 0; j < 20; j++) {
- let pinpu = document.createElement('span');
- pinpu.className = 'pinpu';
- pinpu.style.cssText += `height: ${Math.floor(Math.random()*50) + 10}px; background: #${Math.random().toString(16).substr(-6)};`;
- btnplay.appendChild(pinpu);
- }
- btnplay.onclick = () => aud.paused ? aud.play() : aud.pause();
- prog.onclick = (e) => aud.currentTime = aud.duration * e.offsetX / prog.offsetWidth;
- aud.addEventListener('seeked', () => calcKey());
- aud.addEventListener('pause', () => mState());
- aud.addEventListener('play', () => mState());
- aud.addEventListener('timeupdate', () => {
- let prg = aud.currentTime * prog.offsetWidth / aud.duration < 6 ? 6 : aud.currentTime * prog.offsetWidth / aud.duration;
- prog.style.setProperty('--ww', prg + 'px');
- cur.innerText = toMin(aud.currentTime);
- dur.innerText = toMin(aud.duration);
- setPinpu();
- for (j = 0; j < lrcAr.length; j++) {
- if (aud.currentTime >= lrcAr[j][0]) {
- cKey = j;
- if (mKey === j) showLrc(lrcAr[j][2]);
- else continue;
- }
- }
- });
- let calcKey = () => {
- for (j = 0; j < lrcAr.length; j++) {
- if (aud.currentTime <= lrcAr[j][0]) {
- mKey = j - 1;
- break;
- }
- }
- if (mKey < 0) mKey = 0;
- if (mKey > lrcAr.length - 1) mKey = lrcAr.length - 1;
- let time = lrcAr[mKey][2] - (aud.currentTime - lrcAr[mKey][0]);
- showLrc(time);
- };
- let showLrc = (time) => {
- let name = mFlag ? 'cover1' : 'cover2';
- lrc.innerHTML = lrc.dataset.lrc = lrcAr[mKey][1];
- lrc.style.setProperty('--motion', name);
- lrc.style.setProperty('--tt', time + 's');
- lrc.style.setProperty('--state', 'running');
- mKey += 1;
- mFlag = !mFlag;
- };
- let mState = () => aud.paused ? (lrc.style.setProperty('--state', 'paused'), papa.style.setProperty('--state', 'paused')) : (lrc.style.setProperty('--state', 'running'), papa.style.setProperty('--state', 'running'));
- 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;
- };
- let setPinpu = () => {
- let eles = document.querySelectorAll('.pinpu');
- eles.forEach((item) => item.style.height = `${Math.floor(Math.random()*50) + 10}px`);
- };
- })();
- </script>
复制代码
|
评分
-
| 参与人数 1 | 威望 +50 |
金钱 +100 |
经验 +50 |
收起
理由
|
小辣椒
| + 50 |
+ 100 |
+ 50 |
赞一个! |
查看全部评分
|