极光
<style>#papa { margin-left: calc(50% - 593px); width: 1024px; height: 640px; display: grid; place-items: center; background: #0b1a3a; box-shadow: 3px 3px 20px #000; overflow: hidden; position: relative; z-index: 1; }
#papa::before, #papa::after { position: absolute; content: ''; width: 120%; height: 100%; background: radial-gradient(circle at 100% 100%, transparent 45%, #bd63c1 55%, #53e5a6 65%, transparent 85%); transform: rotate(25deg) scaleX(1.4); mix-blend-mode: color-dodge; filter: url(#wave); }
#papa::after { width: 50%; height: 100%;left: 65%; }
#mplayer { position: absolute; bottom: 5px; left: 5px; }
#btnwrap { display: block; fill: hsla(30, 20%, 80%, .9); cursor: pointer; }
#btnwrap:hover { fill: hsla(90, 100%, 100%, .9); }
#tmsg { fill: hsla(30, 100%, 90%, .9); stroke: none; font: bold 1em sans-serif; }
#lrc { --motion: cover1; --tt: 1s; --state: running; position: absolute; bottom: 20px; font: bold 2.4em sans-serif; color: hsl(100, 100%, 90%); -webkit-background-clip: text; filter: drop-shadow(1px 1px 2px hsla(0, 100%, 0%, .85)); z-index: 999; }
#lrc::before { position: absolute; content: attr(data-lrc); width: 20%; height: 100%; color: transparent; overflow: hidden; white-space: pre; background: linear-gradient(180deg, hsla(19, 48%, 22%, .35), hsla(19, 28%, 42%, .65)); filter: inherit; -webkit-background-clip: text; animation: var(--motion) var(--tt) linear forwards; animation-play-state: var(--state); }
.star { --delay: 0s; position: absolute; width: 2px; height: 2px; background: white; transition: all .8s; opacity: .8; animation: flash linear .8s var(--delay) infinite alternate; }
@keyframes cover1 { from { width: 0; } to { width: 100%; } }
@keyframes cover2 { from { width: 0; } to { width: 100%; } }
@keyframes flash { to { opacity: .1; } }
</style>
<div id="papa">
<svg id="mplayer" width="120" height="120">
<g id="mama" transform="rotate(-90, 60, 60)" style="cursor: pointer;">
<circle id="track" cx="60" cy="60" r="50" fill="none" stroke-width="10" stroke="hsla(100, 20%, 80%, .65)" />
<circle id="prog" cx="60" cy="60" r="50" fill="none" stroke-width="10" stroke="hsla(100,50%,50%,.55)" />
</g>
<g id="btnwrap">
<path id="btnplay" d="M 50 50,50 70,70, 60 z"></path>
<path id="btnpause" d="M 52 50,52 70,57 70,57 50,52 50 z M 60 50,60 70,65 70,65 50,60 50 z" style="display: none;"></path>
<path d="M 57 50,60 50,60 70,57 70 z" fill="transparent" />
</g>
<path id="curPath" d="M 20 70 Q 60 0 100 70" fill="none" stroke="none"/>
<path id="durPath" d="M 20 55 Q 60 110 100 55" fill="none" stroke="none"/>
<g id="tmsg">
<text x="34" y="0"><textPath id="curMsg" xlink:href="#curPath" dominant-baseline="text-after-edge">00:00</textPath></text>
<text x="29" y="0"><textPath id="durMsg" xlink:href="#durPath" dominant-baseline="text-before-edge">00:00</textPath></text>
</g>
<defs>
<filter id="wave">
<feTurbulence basefrequency="0.003 0.003" id="turbulence" numoctaves="3" result="noise" seed="16" />
<feDisplacementMap id="displacement" in2="noise" in="SourceGraphic" scale="96" />
</filter>
</defs>
</svg>
<div id="lrc" data-lrc="花潮论坛lrc在线">花潮论坛lrc在线</div>
<img src="https://638183.freep.cn/638183/t22/webp/star.webp" alt="" style="position: absolute; right: 20px; top: 20px; animation: flash linear 1s infinite alternate;" />
</div>
<audio id="aud" src="https://music.163.com/song/media/outer/url?id=1401064029.mp3" loop autoplay></audio>
<script>
(function() {
(function() {let total = 200;let ww = papa.offsetWidth, hh = papa.offsetHeight;Array.from({length: total}).forEach( (ele,k) => {ele = document.createElement('span');ele.className = 'star';ele.style.cssText += `--delay: ${Math.random() * 10}s;left: ${Math.random() * ww}px;top: ${Math.random() * hh}px;box-shadow: ${Math.random() * 100}px ${Math.random() * 50}px 0 white;`;papa.appendChild(ele);});})();
let mKey = 0,mFlag = true,cc = {x: 1 * track.getAttribute('cx'),y: 1 * track.getAttribute('cy'),len: track.getTotalLength(),};
let lrcAr = [,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,];
prog.style.strokeDasharray = prog.style.strokeDashoffset = cc.len;
btnwrap.onclick = () => aud.paused ? aud.play() : aud.pause();
mama.onclick = (e) => {let deg = Math.atan2(e.offsetY - cc.y, e.offsetX - cc.x) * 180 / Math.PI;deg += (e.offsetX < cc.x && e.offsetY < cc.y) ? 450 : 90;aud.currentTime = aud.duration * deg / 360;};
aud.addEventListener('pause', () => mState());
aud.addEventListener('play', () => mState());
aud.addEventListener('seeked', () => calcKey());
aud.addEventListener('timeupdate', () => {prog.style.strokeDashoffset = cc.len - cc.len * aud.currentTime / aud.duration;curMsg.textContent = toMin(aud.currentTime);durMsg.textContent = toMin(aud.duration);for (j = 0; j < lrcAr.length; j++) {if (aud.currentTime >= lrcAr) {if (mKey === j) showLrc(lrcAr);else continue;}}});
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);};
let mState = () => aud.paused ? (btnplay.style.display = 'block', btnpause.style.display = 'none', lrc.style.setProperty('--state', 'paused')) : (btnplay.style.display = 'none', btnpause.style.display = 'block', lrc.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;};papa.oncontextmenu = () => false;})();
document.title = '于果 - 极光';
</script>
自己做出来的底图很梦幻。
小星星也好看,一闪一闪的,还有一颗漂亮的闪烁的大星,黑黑又出新效果{:4_187:} 为什么不同位置上的小星星会闪烁不同颜色?感觉右下哪里的星星带点红,是被背景影响的么? 地板的配色真美,没想到颜色过渡和变化过程会有这么美的色调{:4_199:} 欣赏音画佳作! 相约爱晚亭 发表于 2022-11-15 10:18
欣赏音画佳作!
感谢支持 红影 发表于 2022-11-15 09:21
自己做出来的底图很梦幻。
小星星也好看,一闪一闪的,还有一颗漂亮的闪烁的大星,黑黑又出新效果{:4_187: ...
这些都是之前尝试过。这个极光背景,还是不能满意。 红影 发表于 2022-11-15 09:22
为什么不同位置上的小星星会闪烁不同颜色?感觉右下哪里的星星带点红,是被背景影响的么?
是的。原理有二:
一是,小不点且纯色的东东,自身颜色容易被“入侵”,周边颜色对它的影响很大;
二是,星星用了 opacity,能透出底色,底色对它们也会有影响。 红影 发表于 2022-11-15 09:24
地板的配色真美,没想到颜色过渡和变化过程会有这么美的色调
就是有点遗憾的,弄不出逼真的极光,怎么看怎么像是云层被极光染色了 马黑黑 发表于 2022-11-15 11:17
这些都是之前尝试过。这个极光背景,还是不能满意。
样子不咋样,但色彩配得极漂亮{:4_199:} 马黑黑 发表于 2022-11-15 11:19
是的。原理有二:
一是,小不点且纯色的东东,自身颜色容易被“入侵”,周边颜色对它的影响很大;
原来是这样,倒是得到了意外的效果呢,很不错{:4_187:} 马黑黑 发表于 2022-11-15 11:20
就是有点遗憾的,弄不出逼真的极光,怎么看怎么像是云层被极光染色了
已经很像了呢,要求别太高{:4_173:} 红影 发表于 2022-11-15 15:31
已经很像了呢,要求别太高
CSS能耐还是有限的,做大极光难点,做小小的极光可能还行 红影 发表于 2022-11-15 15:30
原来是这样,倒是得到了意外的效果呢,很不错
你也可以试试在纯黑色的背景里布局一些小白点,看看效果 红影 发表于 2022-11-15 15:29
样子不咋样,但色彩配得极漂亮
滤镜的结果 马黑黑 发表于 2022-11-15 18:17
CSS能耐还是有限的,做大极光难点,做小小的极光可能还行
这个图图截取一块还真的像{:4_173:} 马黑黑 发表于 2022-11-15 18:18
你也可以试试在纯黑色的背景里布局一些小白点,看看效果
估计就不会有变色的感觉了。 马黑黑 发表于 2022-11-15 18:19
滤镜的结果
哦,这滤镜很神奇啊。{:4_187:} 红影 发表于 2022-11-15 18:57
哦,这滤镜很神奇啊。
多种滤镜呢,svg的,HTML的,配合使用 红影 发表于 2022-11-15 18:56
估计就不会有变色的感觉了。
试了你会惊艳你自己