宁静 发表于 2023-4-9 22:15

云雾山间 TO:小沫生日快乐

本帖最后由 宁静 于 2023-4-9 22:17 编辑 <br /><br /><style>
#papa {top:150px; left: -270px;width: 1400px; height: 711px; background: lightblue url('https://xlaj.cn/assets/file/zp/20230408162533.jpg') center/cover no-repeat; box-shadow: 3px 3px 20px #000; position: relative; z-index: 1; }
#lrc { position: absolute; left: 45%; top: 60px; transform: translate(-50%); height: 50px; font: bold 40px/50px sans-serif; background: transparent; color: gray; display: grid; place-items: center start; pointer-events: none;--motion: cover2; --state: running; --tt: 1s; }
#lrc::before, #lrc::after { position: absolute; content: ''; }
#lrc::before { content: attr(data-lrc); width: 0%; height: 100%; color: green; white-space: pre; overflow: hidden; animation: var(--motion) var(--tt) linear forwards var(--state); }
#lrc::after { width: 50px; height: 50px; left: -100px; border-radius: 50%; background: url('https://xlaj.cn/assets/file/zp/20230408162600.png') center/cover no-repeat; cursor: pointer; pointer-events: auto; animation: rot 4s infinite linear var(--state); }
#svg { position: absolute; font: bold 6em sans-serif; }
.text { fill: none; stroke-width: 3; stroke-dasharray: 0 300; stroke-dashoffset: 0; }
.text:nth-child(3n + 1) { stroke: Gray; animation: stroke1 30s ease-in-out infinite alternate; }
.text:nth-child(3n + 2) { stroke:         orange; animation: stroke2 30s ease-in-out infinite alternate; }
.text:nth-child(3n + 3) { stroke: Teal; animation: stroke3 30s ease-in-out infinite alternate; }
.text:hover { fill: teal; opacity: .45; }

@keyframes stroke1 { to { stroke-dashoffset: 1000; stroke-dasharray: 80 160; } }
@keyframes stroke2 { to { stroke-dashoffset: 1080; stroke-dasharray: 80 160; } }
@keyframes stroke3 { to { stroke-dashoffset: 1160; stroke-dasharray: 80 160; } }
@keyframes cover1 { to { width: 100%; } }
@keyframes cover2 { to { width: 100%; } }
@keyframes rot { to { transform: rotate(360deg); } }
#dt1{ position: absolute; width: 600px; height: 400px; top:200px;; left: 780px; }

</style>

<div id="papa">
        <svg id="svg" width="1400" height="800">
                <symbol id="s-text"><text text-anchor="middle" x="70%" y="75%" dy=".20em">小沫生日快乐</text></symbol>
                <use xlink:href="#s-text" class="text"></use>
                <use xlink:href="#s-text" class="text"></use>
                <use xlink:href="#s-text" class="text"></use>

<img id="dt1" src="https://xlaj.cn/assets/file/zp/20230408162718.gif" alt="" />


      <div id="lrc" data-lrc="HCPlayer">HCPlayer</div>
</div>
<audio id="aud" src="https://xlaj.cn/assets/file/zp/20230408193259.mp3" autoplay="autoplay" loop="loop"></audio>

<script>
let mKey = 0, mFlag = true;
let lrcAr = [
                ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
        ,
       
];
let mState = () => lrc.style.setProperty('--state', aud.paused ? 'paused' : 'running');
let showLrc = (time) => {let name = mFlag ? 'cover1' : 'cover2';lrc.innerHTML = lrcAr;lrc.dataset.lrc = lrcAr.replace(/<br>/, '\n');lrc.style.setProperty('--motion', name);lrc.style.setProperty('--tt', time + 's');lrc.style.setProperty('--state', 'running');mKey += 1;mFlag = !mFlag;};
let calcKey = () => {for (j = 0; j < lrcAr.length; j++) {if (aud.currentTime <= lrcAr) {mKey = j - 1;break;}}if (mKey < 0) mKey = 0;if (mKey > lrcAr.length - 1) mKey = lrcAr.length - 1;let time = lrcAr - (aud.currentTime - lrcAr);showLrc(time);};
aud.addEventListener('timeupdate', () => {for(let j = 0; j < lrcAr.length; j ++) {if (aud.currentTime >= lrcAr) {if (mKey === j) showLrc(lrcAr);else continue;}}});
aud.addEventListener('pause', () => mState());
aud.addEventListener('play', () => mState());
aud.addEventListener('seeked', () => calcKey());
lrc.onclick = () => aud.paused ? aud.play() :aud.pause();
</script>
<br><br><br><br><br><br><br><br><br><br>

宁静 发表于 2023-4-9 22:18

小沫生日快乐~~匆匆忙忙的送个别嫌弃@小沫

小沫 发表于 2023-4-9 22:23

来了来了,好漂亮啊。很喜欢若隐若现的蚂蚁线标题
播放器也喜欢,嵌入式,小按钮,融合了整个画面,
有点伤感歌曲也很喜欢,谢谢宁静那么晚还送帖{:10_401:}

浅笑 发表于 2023-4-9 22:25

漂的的帖子,小沫生日快乐

宁静 发表于 2023-4-9 22:27

小沫 发表于 2023-4-9 22:23
来了来了,好漂亮啊。很喜欢若隐若现的蚂蚁线标题
播放器也喜欢,嵌入式,小按钮,融合了整个画面,
有点伤 ...


小沫生日快乐~~幸福永远!{:10_401:}

小沫匆匆忙忙的,不嫌弃就好,

宁静 发表于 2023-4-9 22:31

浅笑 发表于 2023-4-9 22:25
漂的的帖子,小沫生日快乐

笑笑好,一起贺小沫生日快乐~~{:10_402:}

宁静 发表于 2023-4-9 22:32

小沫 发表于 2023-4-9 22:23
来了来了,好漂亮啊。很喜欢若隐若现的蚂蚁线标题
播放器也喜欢,嵌入式,小按钮,融合了整个画面,
有点伤 ...

是情歌{:9001:}

沉默 发表于 2023-4-9 22:34

宁静 发表于 2023-4-9 22:32
是情歌

情歌我喜欢的{:9022:}

沉默 发表于 2023-4-9 22:34

小沫 发表于 2023-4-9 22:23
来了来了,好漂亮啊。很喜欢若隐若现的蚂蚁线标题
播放器也喜欢,嵌入式,小按钮,融合了整个画面,
有点伤 ...

美女生日快乐

沉默 发表于 2023-4-9 22:37

今天我迟不过赶上了
页: [1] 2 3
查看完整版本: 云雾山间 TO:小沫生日快乐