马黑黑 发表于 2024-11-18 12:52

Breath and Life

<style>
        #mydiv { margin: 30px 0 30px calc(50% - 593px); width: 1024px; height: 640px; background: url('https://638183.freep.cn/638183/t24/breath.jpg') no-repeat center/cover; box-shadow: 4px 4px 8px gray; z-index: 1; position: relative; --state: running; }
        #msvg { position: absolute; left: 50px; bottom: 50px; cursor: pointer; filter: drop-shadow(-5px -5px 10px silver); animation: rot 8s linear infinite var(--state); }
        #msvg:hover { filter: grayscale(1); }
        #vid { position: absolute; width: 100%; height: 100%; object-fit: cover; -webkit-mask: radial-gradient(transparent 20%, red); pointer-events: none; }
        #fsbtn { position: absolute; left: 150px; 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=3934523" autoplay loop></audio>
        <video id="vid" src="https://bpic.588ku.com/video_listen/588ku_video/23/07/03/10/53/43/video64a238371fe73.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');

dr.mask('m1');
dr.circle(150, 150, 150, 'black').animate('animate', {
        attributeName: 'fill',
        values: 'black;white;black',
        dur: '.5s',
        repeatCount: 'indefinite',
}).addTo('m1');
dr.image('https://638183.freep.cn/638183/t24/breath_s.jpg', 0, 0, 300, 300).set('mask', 'url(#m1)');

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

马黑黑 发表于 2024-11-18 12:52

<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/breath.jpg') no-repeat center/cover; box-shadow: 4px 4px 8px gray; z-index: 1; position: relative; --state: running; }
        #msvg { position: absolute; left: 50px; bottom: 50px; cursor: pointer; filter: drop-shadow(-5px -5px 10px silver); animation: rot 8s linear infinite var(--state); }
        #msvg:hover { filter: grayscale(1); }
        #vid { position: absolute; width: 100%; height: 100%; object-fit: cover; -webkit-mask: radial-gradient(transparent 20%, red); pointer-events: none; }
        #fsbtn { position: absolute; left: 150px; 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=3934523" autoplay loop&gt;&lt;/audio&gt;
        &lt;video id="vid" src="https://bpic.588ku.com/video_listen/588ku_video/23/07/03/10/53/43/video64a238371fe73.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');

dr.mask('m1');
dr.circle(150, 150, 150, 'black').animate('animate', {
        attributeName: 'fill',
        values: 'black;white;black',
        dur: '.5s',
        repeatCount: 'indefinite',
}).addTo('m1');
dr.image('https://638183.freep.cn/638183/t24/breath_s.jpg', 0, 0, 300, 300).set('mask', 'url(#m1)');

msvg.onclick = () =&gt; {
        aud.paused
                ? (aud.play(), vid.play(), msvg.style.setProperty('--state', 'running'), dr.play(true))
                : (aud.pause(), vid.pause(), msvg.style.setProperty('--state', 'paused'), dr.play(false));
};
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-18 12:55

本帖配套 svgdr教程·遮罩 - 马黑黑教程专版 - 花潮论坛 - Powered by Discuz! 做mask应用演示

马黑黑 发表于 2024-11-18 12:56

菇凉头像原始图片(400*400):


https://638183.freep.cn/638183/t24/breath_s.jpg

小辣椒 发表于 2024-11-18 13:03

哇塞,这个播放器人物转盘我平时最喜欢的{:4_173:}

小辣椒 发表于 2024-11-18 13:03

看看简单,不知道做做简单不简单,先收藏代码

梦江南 发表于 2024-11-18 13:42

好漂亮的人物圆转播放器。{:4_199:}

梦江南 发表于 2024-11-18 13:43

黑黑老师辛苦了!下午好!{:4_190:}

樵歌 发表于 2024-11-18 17:41

首先得有和平才有生存条件,然后自由呼吸,创造生命。
那人物播放器真棒!

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

樵歌 发表于 2024-11-18 17:41
首先得有和平才有生存条件,然后自由呼吸,创造生命。
那人物播放器真棒!

{:4_364:}

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

梦江南 发表于 2024-11-18 13:43
黑黑老师辛苦了!下午好!

{:4_190:}

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

小辣椒 发表于 2024-11-18 13:03
看看简单,不知道做做简单不简单,先收藏代码

简单简单

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

小辣椒 发表于 2024-11-18 13:03
哇塞,这个播放器人物转盘我平时最喜欢的

{:4_173:}

红影 发表于 2024-11-18 19:44

用透明和不透明来制作闪动,用灰度变化来设置鼠标触碰,这些都没想到呢{:4_173:}

红影 发表于 2024-11-18 19:52

图片取300 300 ,则遮罩层载体的圆取150 150在图片中心,再取150半径,设置透明,载体的尺寸和位置就设置好了,然后直接在载体里设置动态呢,让fill在black;white;black透明和不透明间用0.5秒变化,最后加上图片并使用载体,遮罩效果就出来了,真奇妙{:4_187:}

红影 发表于 2024-11-18 19:56

暂停控制好像和以前不一样,多了dr.play(true)和dr.play(false)呢。

花飞飞 发表于 2024-11-18 20:01

这个背景图有天高任鸟飞的感觉。。。
视频的光芒很炫目。。
小丫头也漂亮,万年不变的麻花辫好看{:4_173:}

红影 发表于 2024-11-18 20:02

去试了一下,把black;white;black换成black;pink;black也能闪烁,不过还是这样从透到完全不透更清晰,无论把white换成pink还是green,都不如white{:4_173:}

花飞飞 发表于 2024-11-18 20:04

这个小播遮罩黑白变化形成隐现动态,突出遮罩的特性,这个创意真是拍案叫绝。。。
触碰小播后灰度值拉满,这次滤镜换了一种。。

花飞飞 发表于 2024-11-18 20:05

音乐大气恢弘,好听,震撼。。{:4_173:}
页: [1] 2 3
查看完整版本: Breath and Life