css+js实现圆圈圆环琴弦波动弹奏声音动画效果代码
代码语言:html
所属分类:动画
代码描述:css+js实现圆圈圆环琴弦波动弹奏声音动画效果代码,点击任意地方波动琴弦。
代码标签: css js 圆圈 圆环 琴弦 波动 弹奏 声音 动画
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,400;0,500;0,700;0,900;1,400;1,500;1,700;1,900&display=swap" rel="stylesheet">
<style>
html, body {
height: 100vh;
background-color: black;
overflow: hidden;
font-family: "Noto Sans", sans-serif;
}
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
canvas {
height: 100vh;
width: 100vw;
position: relative;
z-index: 9;
}
#logo {
position: fixed;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
z-index: 4;
opacity: 0.08;
white-space: nowrap;
pointer-events: none;
}
#logo > img {
height: 3.2vmin;
}
#background-image,
#background-filter {
height: 100%;
width: 100%;
position: fixed;
top: 0px;
left: 0px;
}
#background-image {
z-index: 1;
background-image: url("//repo.bfw.wiki/bfwrepo/image/6462b7138ecf4.png");
background-size: cover;
background-position: center;
opacity: 0.6;
filter: blur(4px) grayscale(30%);
}
#background-filter {
z-index: 2;
background: radial-gradient(rgb(0 0 0 / 60%) 50%, transparent);
}
#control-bar-wrapper {
width: 100%;
display: flex;
justify-content: center;
position: fixed;
top: 0px;
left: 0px;
z-index: 10;
padding: 0.5rem;
}
.toggle {
background-color: rgb(255 255 255 / 10%);
backdrop-filter: blur(5px);
padding: 0.5rem;
border-radius: 0.25rem;
height: 2rem;
border: none;
outline: none;
cursor: pointer;
}
.toggle:is(:hover, :focus-visible) {
background-color: rgb(255 255 255 / 15%);
}
.toggle > i {
color: white;
display: none;
height: 1rem;
width: 1rem;
font-size: 0.6rem;
line-height: 1rem;
text-align: center;
}
.toggle[data-toggled="true"] > i.on {
display: block;
}
.toggle[data-toggled="false"] > i.off {
display: block;
}
#sound-message {
position: fixed;
top: 36%;
left: 50%;
translate: -50% -50%;
z-index: 3;
padding: 0.75rem;
background-color: rgb(255 255 255 / 5%);
border-radius: 0.4rem;
transition: opacity 1000ms;
pointer-events: none;
}
body:has(#sound-toggle[data-toggled="true"]) #sound-message {
opacity: 0;
}
#sound-message > p {
color: white;
font-size: 0.9rem;
white-space: nowrap;
}
</style>
</head>
<body >
<div id="control-bar-wrapper">
<div id="control-bar">
<button id="sound-toggle" class="toggle" type="button" data-toggled="false" onClick="handleSoundToggle()" title="Toggle Pulse">
<i class="fa-solid fa-music-slash off"></i>
<i class="fa-solid fa-music on"></i>
</button>
</div>
</div>
<div id="background-image"></div>
<div id="background-filter"></div>
.........完整代码请登录后点击上方下载按钮下载查看
网友评论0