马黑黑 发表于 2024-11-16 11:18

宇宙尽头的碎片

<style>
        #mydiv { margin: 30px 0 30px calc(50% - 593px); width: 1024px; height: 640px; background: url('https://638183.freep.cn/638183/t24/4/yuvo.webp') no-repeat center/cover; box-shadow: 4px 4px 8px gray; z-index: 1; display: grid; place-items: center; position: relative; --state: running; }
        #msvg { position: absolute; left: 25%; top: 28%; cursor: pointer; filter: drop-shadow(-5px -5px 10px black); animation: rot 8s linear infinite var(--state); }
        #msvg:hover { filter: hue-rotate(160deg); }
        #vid { position: absolute; width: 100%; height: 100%; object-fit: cover; mix-blend-mode: screen; -webkit-mask: radial-gradient(transparent 20%, red); pointer-events: none; }
        #fsbtn { position: absolute; bottom: 15px; color: white; padding: 2px 6px; border: 2px solid snow; border-radius: 8px; user-select: none; cursor: pointer; transition: .5s; }
        @keyframes rot { to { transform: rotate(360deg); } }
</style>

<div id="mydiv">
        <audio id="aud" src="https://music.163.com/song/media/outer/url?id=2120744543" autoplay loop></audio>
        <video id="vid" src="https://bpic.588ku.com/video_listen/588ku_video/24/04/09/15/41/16/video6614f11c2f29d.mp4" autoplay loop muted></video>
        <svg id="msvg" width="300" height="300"></svg>
        <span id="fsbtn"></span>
</div>

<scripttype="module">
import fscreen from 'https://638183.freep.cn/638183/web/mod/fscreen.js';
import Dr from 'https://638183.freep.cn/638183/web/mod/svgdr.js';
var dr = Dr.dr('msvg');

var tt = 9, r1 = 150, r2 = 145, deg = 360 / tt, rad = Math.PI / 180 * deg, pstr = 'M150 150';
var stop = `
        <stop offset="0" stop-color="magenta" />
        <stop offset="1" stop-color="teal" />
`;

for(var i = 0; i < tt; i ++) {
        var x = r1 + r2 * Math.cos(rad * i), y = r1 + r2 * Math.sin(rad * i);
        pstr += `A60 30 ${deg * i} 0 0 ${x.toFixed(2)} ${y.toFixed(2)}A60 30 ${deg * i} 1 0 ${r1} ${r1}`;
}

dr.gradient('radialGradient', {id: 'rg', r: .8}, stop);
dr.path(pstr, 'url(#rg)').set('fill-rule', 'evenodd');

msvg.onclick = () => {
        aud.paused
                ? (aud.play(), vid.play(), msvg.style.setProperty('--state', 'running'))
                : (aud.pause(), vid.pause(), msvg.style.setProperty('--state', 'paused'));
};
fscreen.fs('mydiv', 'fsbtn');
aud.play().catch(_ => mState());
</script>

马黑黑 发表于 2024-11-16 11:19

<h2>代码:</h2>
<div id="hEdiv"><pre id="hEpre">
&lt;style&gt;
        #mydiv { margin: 30px 0 30px calc(50% - 593px); width: 1024px; height: 640px; background: url('https://638183.freep.cn/638183/t24/4/yuvo.webp') no-repeat center/cover; box-shadow: 4px 4px 8px gray; z-index: 1; display: grid; place-items: center; position: relative; --state: running; }
        #msvg { position: absolute; left: 25%; top: 28%; cursor: pointer; filter: drop-shadow(-5px -5px 10px black); animation: rot 8s linear infinite var(--state); }
        #msvg:hover { filter: hue-rotate(160deg); }
        #vid { position: absolute; width: 100%; height: 100%; object-fit: cover; mix-blend-mode: screen; -webkit-mask: radial-gradient(transparent 20%, red); pointer-events: none; }
        #fsbtn { position: absolute; bottom: 15px; color: white; padding: 2px 6px; border: 2px solid snow; border-radius: 8px; user-select: none; cursor: pointer; transition: .5s; }
        @keyframes rot { to { transform: rotate(360deg); } }
&lt;/style&gt;

&lt;div id="mydiv"&gt;
        &lt;audio id="aud" src="https://music.163.com/song/media/outer/url?id=2120744543" autoplay loop&gt;&lt;/audio&gt;
        &lt;video id="vid" src="https://bpic.588ku.com/video_listen/588ku_video/24/04/09/15/41/16/video6614f11c2f29d.mp4" autoplay loop muted&gt;&lt;/video&gt;
        &lt;svg id="msvg" width="300" height="300"&gt;&lt;/svg&gt;
        &lt;span id="fsbtn"&gt;&lt;/span&gt;
&lt;/div&gt;

&lt;scripttype="module"&gt;
import fscreen from 'https://638183.freep.cn/638183/web/mod/fscreen.js';
import Dr from 'https://638183.freep.cn/638183/web/mod/svgdr.js';
var dr = Dr.dr('msvg');

var tt = 9, r1 = 150, r2 = 145, deg = 360 / tt, rad = Math.PI / 180 * deg, pstr = 'M150 150';
var stop = `
        &lt;stop offset="0" stop-color="magenta" /&gt;
        &lt;stop offset="1" stop-color="teal" /&gt;
`;

for(var i = 0; i &lt; tt; i ++) {
        var x = r1 + r2 * Math.cos(rad * i), y = r1 + r2 * Math.sin(rad * i);
        pstr += `A60 30 ${deg * i} 0 0 ${x.toFixed(2)} ${y.toFixed(2)}A60 30 ${deg * i} 1 0 ${r1} ${r1}`;
}

dr.gradient('radialGradient', {id: 'rg', r: .8}, stop);
dr.path(pstr, 'url(#rg)').set('fill-rule', 'evenodd');

msvg.onclick = () =&gt; {
        aud.paused
                ? (aud.play(), vid.play(), msvg.style.setProperty('--state', 'running'))
                : (aud.pause(), vid.pause(), msvg.style.setProperty('--state', 'paused'));
};
fscreen.fs('mydiv', 'fsbtn');
aud.play().catch(_ =&gt; mState());
&lt;/script&gt;
</pre></div>

<script type="module">
import hlight from 'https://638183.freep.cn/638183/web/mod/helight.js';
hlight.hl(hEdiv, hEpre);
</script>

醉美水芙蓉 发表于 2024-11-16 11:39

醉美水芙蓉 发表于 2024-11-16 11:40

醉美水芙蓉 发表于 2024-11-16 11:41

泡沫 发表于 2024-11-16 12:02

渐变之美和数学之美,用代码演绎出如此完美的图案。
再用这个背景衬托一下,妥妥的宇宙之花,加了阴影后立体感更强。。漂亮{:4_173:}

泡沫 发表于 2024-11-16 12:30

视频震撼,音乐好听~~
花朵转动与视频向内的粒子飞舞动态,
好似看到了宇宙有一种莫明的神秘力量。。
完美的宇宙碎片

马黑黑 发表于 2024-11-16 12:33

泡沫 发表于 2024-11-16 12:30
视频震撼,音乐好听~~
花朵转动与视频向内的粒子飞舞动态,
好似看到了宇宙有一种莫明的神秘力量。。


{:4_173:}

马黑黑 发表于 2024-11-16 12:33

醉美水芙蓉 发表于 2024-11-16 11:39
欣赏老师带来漂亮播放器!

{:4_190:}

马黑黑 发表于 2024-11-16 12:33

醉美水芙蓉 发表于 2024-11-16 11:40
非常喜欢这个播放器,谢谢老师分享!

我等着看谁先用呢

马黑黑 发表于 2024-11-16 12:34

泡沫 发表于 2024-11-16 12:02
渐变之美和数学之美,用代码演绎出如此完美的图案。
再用这个背景衬托一下,妥妥的宇宙之花,加了阴影后立 ...

感谢支持

朵拉 发表于 2024-11-16 12:34

好看,震撼~~{:4_178:}

马黑黑 发表于 2024-11-16 12:43

朵拉 发表于 2024-11-16 12:34
好看,震撼~~

{:4_190:}

愤怒的葡萄 发表于 2024-11-16 12:56

非常漂亮的音画作品,宇宙真是无边无际。

樵歌 发表于 2024-11-16 13:18

二圣不是说空间是无限的么,有还有尽头,那尽头外面又是什么{:4_203:}

马黑黑 发表于 2024-11-16 13:25

樵歌 发表于 2024-11-16 13:18
二圣不是说空间是无限的么,有还有尽头,那尽头外面又是什么

宇宙是卷状的,没有内部外部

马黑黑 发表于 2024-11-16 13:25

愤怒的葡萄 发表于 2024-11-16 12:56
非常漂亮的音画作品,宇宙真是无边无际。

{:4_181:}

梦江南 发表于 2024-11-16 14:01

欣赏学习老师漂亮的播放器。问好!

小辣椒 发表于 2024-11-16 15:06

欣赏学习黑黑的新的教程分享{:4_187:}

红影 发表于 2024-11-16 16:57

这小播变色起来还挺爽快,一碰就变了,剧变,还好也不是聚变{:4_173:}
页: [1] 2 3
查看完整版本: 宇宙尽头的碎片