查看: 231|回复: 18

[特效] 私人侦探

[复制链接]
发表于 2024-11-17 07:29 | 显示全部楼层 |阅读模式

评分

6

查看全部评分

点评
回复

使用道具

 楼主| 发表于 2024-11-17 07:30 | 显示全部楼层

代码

<style>
	#mydiv { margin: 30px 0 30px calc(50% - 602px); width: 1024px; height: 640px; background: url('https://638183.freep.cn/638183/t24/webp2/inspector.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: calc(50% - 164px); cursor: pointer; filter: drop-shadow(-5px -5px 10px cyan); animation: rot 8s linear infinite var(--state); }
	#msvg:hover { filter: hue-rotate(60deg); }
	#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=1843020840" autoplay loop></audio>
	<video id="vid" src="https://bpic.588ku.com/video_listen/588ku_video/22/11/04/16/01/57/video6364c6f5e3503.mp4" autoplay loop muted></video>
	<svg id="msvg" width="300" height="300"></svg>
	<span id="fsbtn"></span>
</div>
 
<script  type="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 = 140, deg = 360 / tt, rad = Math.PI / 180 * deg, pstr = 'M150 150';
var stop = `
	<stop offset="0" stop-color="green" />
	<stop offset="1" stop-color="cyan" />
`;

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.marker('m1', 20, 20, 10, 10);
dr.circle(10,10,10,'fuchsia').addTo('m1');
dr.gradient('radialGradient', {id: 'rg', r: .8}, stop);
dr.path(pstr, 'url(#rg)').set('fill-rule', 'evenodd').style('marker-mid: url(#m1)');

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>

评分

5

查看全部评分

点评
回复

使用道具

发表于 2024-11-17 10:15 | 显示全部楼层

谢谢凡哥老师分享代码!
点评
回复

使用道具

发表于 2024-11-17 10:16 | 显示全部楼层
指纹,好听好看,欣赏凡哥老师带来的精美佳作!
点评
回复

使用道具

发表于 2024-11-17 10:16 | 显示全部楼层
问好凡哥老师感谢你的精彩!
点评
回复

使用道具

发表于 2024-11-17 10:16 | 显示全部楼层
祝凡哥老师创作愉快,周末快乐!
点评
回复

使用道具

发表于 2024-11-17 10:16 | 显示全部楼层
期待凡哥老师更多佳作分享!
点评
回复

使用道具

发表于 2024-11-17 11:31 | 显示全部楼层
周末休闲,欣赏老师的精美作品。。
无论是色彩,音乐,整体效果都是完美之作。。
点评
回复

使用道具

发表于 2024-11-17 11:33 | 显示全部楼层
这个小播是纯代码绘制,通过各种计算得出这么漂亮的图案,四周和中心点是加了标记,
使用了绿色和青色渐变,绿色0.8青色0.2,感觉青色在边缘不太明显。。
触碰小播会变色,这是给了个色相60的滤镜,变色之后的颜色也非常漂亮
点评
回复

使用道具

发表于 2024-11-17 11:35 | 显示全部楼层
视频的使用很绝,丁达尔光效在这里给作品增添了神秘、科幻之感~~
这个视频的LOGO在正中间,通过遮罩挖去中间一小块,刚好去掉LOGO,显出小播。
经老师手处理过的效果就是很不一样。。。
点评
回复

使用道具

您需要登录后才可以回帖 登录 | 中文注册

本版积分规则

手机版|千山论坛 ( 冀ICP备2024055714号 )

GMT+8, 2025-6-11 13:17

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表