js+css实现ai生成的音乐曲子调子试听下载wav、midi文件代码
代码语言:html
所属分类:多媒体
代码描述:js+css实现ai生成的音乐曲子调子试听下载wav、midi文件代码,这是ai生成的曲子。
代码标签: js css ai 生成 音乐 曲子 调子 试听 下载 wav midi 文件 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>欢快旋律工坊</title>
<script src="https://cdn.tailwindcss.com"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css">
<link href="https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap" rel="stylesheet">
<style>
:root {
--bg: #0B0B12;
--card: #13131F;
--card2: #1A1A2B;
--accent: #FF6B35;
--accent2: #FFB84D;
--accent3: #06D6A0;
--text: #F0F0F5;
--muted: #7A7A9E;
--border: #2A2A40;
}
* { margin:0; padding:0; box-sizing:border-box; }
body {
font-family: 'Nunito', sans-serif;
background: var(--bg);
color: var(--text);
min-height: 100vh;
overflow-x: hidden;
}
h1, h2, h3 { font-family: 'Fredoka One', cursive; }
/* 背景动画 */
.bg-orbs {
position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
}
.bg-orbs .orb {
position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.12;
animation: orbFloat 12s ease-in-out infinite alternate;
}
.bg-orbs .orb:nth-child(1) { width:500px;height:500px;background:var(--accent);top:-10%;left:-5%;animation-delay:0s; }
.bg-orbs .orb:nth-child(2) { width:400px;height:400px;background:var(--accent2);bottom:-10%;right:-5%;animation-delay:-4s; }
.bg-orbs .orb:nth-child(3) { width:350px;height:350px;background:var(--accent3);top:40%;left:50%;animation-delay:-8s; }
@keyframes orbFloat {
0% { transform: translate(0,0) scale(1); }
50% { transform: translate(30px,-40px) scale(1.1); }
100% { transform: translate(-20px,30px) scale(0.95); }
}
.main-container { position: relative; z-index: 1; max-width: 900px; margin: 0 auto; padding: 24px 16px; }
/* 可视化Canvas */
#vizCanvas {
width: 100%; height: 260px; border-radius: 16px;
background: linear-gradient(180deg, rgba(19,19,31,0.9), rgba(11,11,18,0.95));
border: 1px solid var(--border);
display: block;
}
/* 进度条 */
.progress-wrap {
position: relative; height: 6px; background: var(--card2); border-radius: 3px;
cursor: pointer; margin-top: 12px; overflow: hidden;
}
.progress-fill {
height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent2));
border-radius: 3px; width: 0%; transition: width 0.1s linear;
}
/* 按钮基础 */
.btn-icon {
width: 52px; height: 52px; border-radius: 50%; border: none; cursor: pointer;
display: flex; align-items: center; justify-content: center; font-size: 20px;
transition: all 0.2s ease;
}
.btn-icon:hover { transform: scale(1.1); }
.btn-icon:active { transform: scale(0.95); }
.btn-play {
background: linear-gradient(135deg, var(--accent), #FF8F5E);
color: #fff; box-shadow: 0 4px 20px rgba(255,107,53,0.35);
}
.btn-play:hover { box-shadow: 0 6px 30px rgba(255,107,53,0.5); }
.btn-stop {
background: var(--card2); color: var(--muted); border: 1px solid var(--border);
}
.btn-stop:hover { color: var(--text); border-color: var(--muted); }
/* 导出按钮 */
.btn-export {
padding: 12px 24px; border-radius: 12px; border: 1px solid var(--border);
background: var(--card2); color: var(--text); font-family: 'Nunito',sans-serif;
font-weight: 700; font-size: 15px; cursor: pointer;
transition: all 0.25s ease; display: flex; align-items: center; gap: 8px;
}
.btn-export:hover {
background: var(--card); border-color: var(--accent); color: var(--accent);
box-shadow: 0 4px 16px rgba(255,107,53,0.15).........完整代码请登录后点击上方下载按钮下载查看















网友评论0