three实现三维空气动力学流体模拟动画效果代码
代码语言:html
所属分类:三维
代码描述:three实现三维空气动力学流体模拟动画效果代码,记得点击smoke mode
代码标签: three 三维 空气 动力学 流体 模拟 动画
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Airflow Shaper - Three.js</title>
<style>
body { margin: 0; overflow: hidden; background-color: #000; font-family: 'Segoe UI', sans-serif; }
canvas { display: block; width: 100vw; height: 100vh; }
/* UI Panel Styles */
#ui-panel {
position: absolute;
top: 20px;
left: 20px;
width: 300px;
background: rgba(20, 20, 25, 0.9);
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
color: #eee;
box-shadow: 0 4px 20px rgba(0,0,0,0.5);
display: flex;
flex-direction: column;
max-height: 90vh;
user-select: none;
transition: width 0.3s, opacity 0.3s;
--ui-size-scale: 1;
}
#ui-panel.is-collapsed {
width: 40px;
height: 40px;
overflow: hidden;
background: transparent;
border: none;
}
/* Handles for dragging */
.panel-handle {
height: 24px;
background: rgba(255, 255, 255, 0.05);
cursor: move;
display: flex;
align-items: center;
justify-content: center;
}
.panel-handle::after {
content: '';
width: 40px;
height: 4px;
background: rgba(255,255,255,0.2);
border-radius: 2px;
}
#ui-handle { border-top-left-radius: 8px; border-top-right-radius: 8px; }
#ui-handle-bottom { border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; cursor: move; }
/* Scrollable Content */
.panel-content {
flex: 1;
overflow-y: auto;
padding: 10px 16px;
}
#ui-panel.is-collapsed .panel-content,
#ui-panel.is-collapsed .panel-handle { display: none; }
/* Toggle Button */
#collapse-toggle {
position: absolute;
top: 0; left: 0;
width: 40px; height: 40px;
background: rgba(40,40,50,0.8);
border: 1px solid rgba(255,255,255,0.2);
color: white;
border-radius: 50%;
cursor: pointer;
z-index: 10;
display: flex;
align-items: center;
justify-content: center;
font-size: 18px;
}
#collapse-toggle:hover { background: #445; }
/* Sections */
.panel-section { margin-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 8px; }
.panel-section:last-child { border-bottom: none; }
.panel-heading {
font-size: 12px;
text-transform: uppercase;
letter-spacing: 1px;
color: #88a;
margin-bottom: 8px;
cursor: pointer;
display: flex;
justify-content: space-between;
}
.panel-heading::after { content: '▼'; font-size: 10px; }
.panel-section.is-collapsed .control-group { display: none; }
.panel-section.is-collapsed .panel-heading::after { content: '◀'; }
/* Controls */
.control-row { display: flex; gap: 8px; margin-bottom: 8px; }
button {
flex: 1;
background: #333642;
border: 1px solid #4a4d5a;
color: #ddd;
padding: 6px 10px;
border-radius: 4px;
cursor: pointer;
font-size: 12px;
transition: background 0.2s;
}
button:hover { background: #44495e; }
button:active { background: #555b75; }
.control-group { margin-bottom: 12px; }
label { display: flex; justify-content: space-between; font-size: 13px; margin-bottom: 4px; color: #ccc; }
/* Custom Range Slider */
input[type=range] {
-webkit-appearance: none;
width: 100%;
background: transparent;
}
input[type=range]::-webkit-slider-thumb {
-webkit-appearance: none;
height: 14px; width: 14px;
border-radius: 50%;
background: #fff;
cursor: pointer;
margin-top: -5px;
box-shadow: 0 0 5px rgba(0,0,0,0.5);
}
input[type=range]::-webkit-slider-runnable-track {
width: 100%;
height: 4px;
background: #444;
border-radius: 2px;
}
/* Color input */
input[type="color"] {
border: none; width: 100%; height: 24px; padding: 0; cursor: pointer; background: none;
}
/* Checkbox */
.checkbox-row { display: flex; align-items: center; gap: 10px; font-size: 13px; margin-top: 5px; }
</style>
<!-- Import Maps for Three.js via CDN -->
<script type="importmap">
{
"imports": {
"three": "https://unpkg.com/three@0.160.0/build/three.module.js",
"three/addons/": "https://unpkg.com/three@0.160.0/examples/jsm/"
}
}
</script>
</head>
<body>
<canvas id="app-canvas"></canvas>
<!-- UI Structure Recreated from Logic -->
<div id="ui-panel">
<button id="collapse-toggle" title="Toggle UI">≡</button>
<div id="ui-handle" class="panel-handle"></div>
<div class="panel-content">
<!-- Simulation Controls -->
<div class="panel-section">
<div class="panel-heading" aria-expanded="true">Simulation</div>
<div class="control-group">
<div class="control-row">
<button id="play-sim">Play</button>
<button id="pause-sim">Pause</button>
<button id="restart-sim">Restart</button>
</div>
</div>
</div>
<!-- Flow Settings -->
<div class="panel-section">
<div class="panel-heading" aria-expanded="true">Flow Params</div>
<div class="control-group">
<label>Speed <span id="flow-speed-value"></span></label>
<input type="range" id="flow-speed" min="0.1" max="10" step="0.1">
</div>
<div class="control-group">
<label>Length <span id="flow-length-value"></span></label>
<input type="range" id="flow-length" min="1" max="15" step="0.1">
</div>
<div class="control-group">
<label>Turbulence <span id="turbulence-value"></span></label>
<input type="range" id="turbulence-strength" min="0" max="2" step="0.01">
</div>
<div class="control-group">
<label>Recovery <span id="recovery-length-value"></span></label>
<input type="range" id="recovery-length" min="0.1" max="3" step="0.1">
</div>
<div class="control-group">
<label>Impact Buffer <span id="impact-buffer-value"></span></label>
<input type="range" id="impact-buffer" min="0.01" max="0.5" step="0.01">
</div>
</div>
<!-- Emitter Settings -->
<div class="panel-section">
<div class="panel-heading" aria-expanded="true">Emitter</div>
<div class="control-group">
<label>Density X <span id="density-x-value"></span></label>
<input type="range" id="density-x" min="5" max="50" step="1">
</div>
<div class="control-group">
<label>Density Y <span id="density-y-value"></span></label>
<input type="range" id="density-y" min="5" max="30" step="1">
</div>
</div>
<!-- Visuals -->
<div class="panel-section">
<div class="panel-heading" aria-expanded="true">Visuals</div>
<div class="control-group">
<label>Path Color</label>
<input type="color" id="path-color">
</div>
<div class="control-group">
<label>Obstructed Color</label>
<input type="color" id="obstructed-color">
&.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0