three实现玻璃立方体三维小球可交互炫酷网页代码
代码语言:html
所属分类:三维
代码描述:three实现玻璃立方体三维小球可交互炫酷网页代码
代码标签: three 玻璃 立方体 三维 小球 交互 炫酷 网页 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
:root {
--white: #ffffff;
--white-60: rgba(255, 255, 255, 0.6);
--white-30: rgba(255, 255, 255, 0.3);
--white-10: rgba(255, 255, 255, 0.08);
--gold: #ca8a04;
--gold-light: #fcd34d;
--z-canvas: 0;
--z-ui: 10;
--z-loader: 100;
/* ── Fluid spacing tokens ── */
--pad-h: clamp(16px, 3.5vw, 40px);
--pad-v: clamp(18px, 3vh, 36px);
}
html,
body {
width: 100%;
background: #000;
}
/* ─── CANVAS ─────────────────────────────────────────────── */
.webgl {
position: fixed;
inset: 0;
width: 100%;
height: 100%;
z-index: var(--z-canvas);
}
/* ─── LOADER ─────────────────────────────────────────────── */
#loader {
position: fixed;
inset: 0;
z-index: var(--z-loader);
background: #000;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 28px;
transition:
opacity 0.8s ease,
visibility 0.8s ease;
}
#loader.hidden {
opacity: 0;
visibility: hidden;
pointer-events: none;
}
.loader-ring {
width: 56px;
height: 56px;
position: relative;
}
.loader-ring svg {
width: 100%;
height: 100%;
transform: rotate(-90deg);
}
.loader-ring circle {
fill: none;
stroke: rgba(255, 255, 255, 0.12);
stroke-width: 1.5;
}
.loader-ring .progress {
stroke: var(--white);
stroke-linecap: round;
stroke-dasharray: 157;
stroke-dashoffset: 157;
animation: ring-fill 1.8s cubic-bezier(0.4, 0, 0.2, 1) 0.3s forwards;
}
@keyframes ring-fill {
to {
stroke-dashoffset: 0;
}
}
.loader-label {
font-family: "Space Grotesk", sans-serif;
font-size: 11px;
font-weight: 300;
letter-spacing: 0.25em;
text-transform: uppercase;
color: var(--white-60);
}
/* ─── VIGNETTE ───────────────────────────────────────────── */
#vignette {
position: fixed;
inset: 0;
z-index: 1;
background: radial-gradient(
ellipse at center,
transparent 30%,
rgba(0, 0, 0, 0.55) 100%
);
pointer-events: none;
}
/* ─── UI OVERLAY ─────────────────────────────────────────── */
#ui {
position: fixed;
inset: 0;
z-index: var(--z-ui);
pointer-events: none;
opacity: 0;
animation: fade-in 1s ease 2.4s forwards;
}
@keyframes fade-in {
to {
opacity: 1;
}
}
/* ─── TOP BAR ─────────────────────────────────────────────── */
.top-bar {
position: absolute;
top: var(--pad-v);
left: var(--pad-h);
right: var(--pad-h);
display: flex;
align-items: center;
justify-content: space-between;
}
.brand {
font-family: "Archivo", sans-serif;
font-size: clamp(11px, 1.2vw, 13px);
font-weight: 500;
letter-spacing: 0.12em;
text-transform: uppercase;
color: var(--white);
}
.brand span {
color: var(--white-30);
font-weight: 300;
margin-left: 4px;
letter-spacing: 0.06em;
}
.badge {
font-family: "Space Grotesk", sans-serif;
font-size: clamp(9px, 1vw, 10px);
font-weight: 400;
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--white-30);
border: 1px solid rgba(255, 255, 255, 0.1);
padding: 5px 12px;
border-radius: 100px;
}
/* ─── SIDE LABEL ─────────────────────────────────────────── */
.side-label {
position: absolute;
top: 50%;
right: 6px;
transform: translateY(-50%);
writing-mode: vertical-rl;
transform: translateY(-50%) rotate(180deg);
font-family: "Space Grotesk", sans-serif;
font-size: 10px;
font-weight: 300;
letter-spacing: 0.2em;
text-transform: uppercase;
color: var(--white-30);
white-space: nowrap;
user-select: none;
}
.side-label-left {
left: 6px;
right: auto;
writing-mode: vertical-lr;
transform: translateY(-50%);
}
/* ─── BOTTOM BAR ──────────────────────────────────────────── */
.bottom-bar {
position: absolute;
bottom: clamp(60px, 10vh, 100px);
left: var(--pad-h);
right: var(--pad-h);
display: flex;
align-items: flex-end;
justify-content: space-between;
gap: 16px;
}
.hero-title {
font-family: "Archivo", sans-serif;
font-size: clamp(28px, 7vw, 88px);
font-weight: 700;
line-height: 0.9;
letter-spacing: -0.03em;
color: var(--white);
text-transform: uppercase;
mix-blend-mode: difference;
flex-shrink: 0;
}
.hero-title .line-thin {
display: block;
font-weight: 300;
font-size: clamp(18px, 4.5vw, 56px);
letter-spacing: 0.06em;
color: var(--white-60);
mix-blend-mode: normal;
margin-bottom: 4px;
}
.hint-list {
list-style: none;
display: flex;
flex-direction: column;
gap: 10px;
align-items: flex-end;
}
.hint-list li {
display: flex;
align-items: center;
gap: 10px;
font-family: "Space Grotesk", sans-serif;
font-size: clamp(9px, 1.1vw, 11px);
font-weight: 300;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--white-30);
}
.........完整代码请登录后点击上方下载按钮下载查看















网友评论0