StyleKit
风格库模板社区生成器素材库GitHub
风格目录/视觉小说风

视觉小说风

Visual Novel

D
41/100较差

借鉴ADV视觉小说游戏UI的设计风格,半透明对话框面板、角色铭牌徽章、装饰性边角框线、分支选项按钮和存档界面,打造沉浸式交互故事体验。

视觉小说ADV对话框铭牌立绘选项游戏UI交互故事装饰边角
查看完整 Showcase →对比

配色方案

Primary

#4a5568

Secondary

#f7fafc

Accent 1

#6366f1

Accent 2

#ec4899

Accent 3

#10b981

提示词

硬性 + 软性提示词

一键复制并生成 视觉小说风 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。

硬性提示词

高一致性,严格执行风格规则

STYLEKIT_STYLE_REFERENCE
style_name: 视觉小说风
style_slug: visual-novel
style_source: /styles/visual-novel

# Hard Prompt

请严格遵守以下风格规则并保持一致性,禁止风格漂移。

## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。

## Style Rules
# Visual Novel (视觉小说风) Design System

> 借鉴ADV视觉小说游戏UI的设计风格,半透明对话框面板、角色铭牌徽章、装饰性边角框线、分支选项按钮和存档界面,打造沉浸式交互故事体验。

## 核心理念

Visual Novel 风格源于日本ADV(Adventure)视觉小说游戏的UI设计,强调叙事沉浸感和角色互动。

核心理念:
- ADV对话框系统:底部固定半透明暗色面板,承载角色对话文字
- 角色铭牌徽章:对话框上方的彩色小标签,标识说话角色
- 装饰性边角框线:对话面板四角的L形装饰线条,营造精致画框感
- 分支选项按钮:居中排列的毛玻璃按钮,代表故事分支
- 场景氛围渲染:通过天空渐变、剪影、柔光营造时间和情感氛围
- 存档界面设计:带装饰边角的暗色面板,包含输入框和操作按钮

---

## Token 字典(精确 Class 映射)

### 边框
```
宽度: border
颜色: border-[#4a5568]/10
圆角: rounded-lg
```

### 阴影
```
小:   shadow-sm
中:   shadow-md
大:   shadow-lg
悬停: hover:shadow-lg
聚焦: focus:shadow-[0_0_12px_#6366f120]
```

### 交互效果
```
悬停位移: hover:-translate-y-1
过渡动画: transition-all duration-300 ease-in-out
按下状态: active:scale-[0.98]
```

### 字体
```
标题: font-serif font-medium
正文: font-sans leading-relaxed
```

### 字号
```
Hero:  text-4xl md:text-6xl lg:text-7xl
H1:    text-3xl md:text-5xl
H2:    text-2xl md:text-3xl
H3:    text-xl md:text-2xl
正文:  text-sm md:text-base
小字:  text-xs md:text-sm
```

### 间距
```
Section: py-12 md:py-20 lg:py-28
容器:    px-4 md:px-8 lg:px-12
卡片:    p-5 md:p-8
```

---

## [FORBIDDEN] 绝对禁止

以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:

### 禁止的 Class
- `border-4`
- `border-8`
- `rounded-none`
- `font-mono`
- `shadow-[3px_0_`
- `shadow-[0_0_30px`
- `bg-[#0a0a0a]`
- `bg-black`
- `text-[#00ffff]`
- `text-[#ff00ff]`
- `uppercase tracking-widest`

### 禁止的模式
- 匹配 `^border-(?:4|8)$`
- 匹配 `^rounded-none$`
- 匹配 `^font-mono$`
- 匹配 `^shadow-\[\d+px_0_#`
- 匹配 `^bg-(?:black|\[#0a0a0a\])$`
- 匹配 `^text-\[#(?:00ffff|ff00ff)\]$`

### 禁止原因
- `border-4`: Visual Novel uses subtle, thin borders for its elegant aesthetic
- `rounded-none`: Visual Novel uses rounded-lg for soft UI panels, never sharp edges
- `font-mono`: Visual Novel uses serif for narrative text and sans-serif for UI, not monospace
- `bg-black`: Visual Novel uses light or semi-transparent dark backgrounds, never pure black
- `uppercase tracking-widest`: Visual Novel uses natural case text, not terminal-style uppercase

> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。

---

## [REQUIRED] 必须包含

### 按钮必须包含
```
rounded-lg
font-sans font-medium
transition-all duration-300 ease-in-out
```

### 卡片必须包含
```
rounded-lg
backdrop-blur-md
border
```

### 输入框必须包含
```
rounded-lg
border
font-sans
backdrop-blur-sm
focus:outline-none
```

---

## [COMPARE] 错误 vs 正确对比

### 按钮

[WRONG] **错误示例**(使用了圆角和模糊阴影):
```html
<button class="rounded-lg shadow-lg bg-blue-500 text-white px-4 py-2 hover:bg-blue-600">
  点击我
</button>
```

[CORRECT] **正确示例**(使用硬边缘、无圆角、位移效果):
```html
<button class="rounded-lg font-sans font-medium transition-all duration-300 ease-in-out bg-[#ff006e] text-white px-4 py-2 md:px-6 md:py-3">
  点击我
</button>
```

### 卡片

[WRONG] **错误示例**(使用了渐变和圆角):
```html
<div class="rounded-xl shadow-2xl bg-gradient-to-r from-purple-500 to-pink-500 p-6">
  <h3 class="text-xl font-semibold">标题</h3>
</div>
```

[CORRECT] **正确示例**(纯色背景、硬边缘阴影):
```html
<div class="rounded-lg backdrop-blur-md border p-5 md:p-8">
  <h3 class="font-serif font-medium text-xl md:text-2xl">标题</h3>
</div>
```

### 输入框

[WRONG] **错误示例**(灰色边框、圆角):
```html
<input class="rounded-md border border-gray-300 px-3 py-2 focus:ring-2 focus:ring-blue-500" />
```

[CORRECT] **正确示例**(黑色粗边框、聚焦阴影):
```html
<input class="rounded-lg border font-sans backdrop-blur-sm focus:outline-none px-3 py-2 md:px-4 md:py-3" placeholder="请输入..." />
```

---

## [TEMPLATES] 页面骨架模板

使用以下模板生成页面,只需替换 `{PLACEHOLDER}` 部分:

### 导航栏骨架
```html
<nav class="bg-white border-b-2 md:border-b-4 border-black px-4 md:px-8 py-3 md:py-4">
  <div class="flex items-center justify-between max-w-6xl mx-auto">
    <a href="/" class="font-black text-xl md:text-2xl tracking-wider">
      {LOGO_TEXT}
    </a>
    <div class="flex gap-4 md:gap-8 font-mono text-sm md:text-base">
      {NAV_LINKS}
    </div>
  </div>
</nav>
```

### Hero 区块骨架
```html
<section class="min-h-[60vh] md:min-h-[80vh] flex items-center px-4 md:px-8 py-12 md:py-0 bg-{ACCENT_COLOR} border-b-2 md:border-b-4 border-black">
  <div class="max-w-4xl mx-auto">
    <h1 class="font-black text-4xl md:text-6xl lg:text-8xl leading-tight tracking-tight mb-4 md:mb-6">
      {HEADLINE}
    </h1>
    <p class="font-mono text-base md:text-xl max-w-xl mb-6 md:mb-8">
      {SUBHEADLINE}
    </p>
    <button class="bg-black text-white font-black px-6 py-3 md:px-8 md:py-4 border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px] transition-all text-sm md:text-base">
      {CTA_TEXT}
    </button>
  </div>
</section>
```

### 卡片网格骨架
```html
<section class="py-12 md:py-24 px-4 md:px-8">
  <div class="max-w-6xl mx-auto">
    <h2 class="font-black text-2xl md:text-4xl mb-8 md:mb-12">{SECTION_TITLE}</h2>
    <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 md:gap-6">
      <!-- Card template - repeat for each card -->
      <div class="bg-white border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(0,0,0,1)] md:shadow-[8px_8px_0px_0px_rgba(0,0,0,1)] p-4 md:p-6 hover:shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:hover:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:-translate-y-1 transition-all">
        <h3 class="font-black text-lg md:text-xl mb-2">{CARD_TITLE}</h3>
        <p class="font-mono text-sm md:text-base text-gray-700">{CARD_DESCRIPTION}</p>
      </div>
    </div>
  </div>
</section>
```

### 页脚骨架
```html
<footer class="bg-black text-white py-12 md:py-16 px-4 md:px-8 border-t-2 md:border-t-4 border-black">
  <div class="max-w-6xl mx-auto">
    <div class="grid grid-cols-1 md:grid-cols-3 gap-8">
      <div>
        <span class="font-black text-xl md:text-2xl">{LOGO_TEXT}</span>
        <p class="font-mono text-sm mt-4 text-gray-400">{TAGLINE}</p>
      </div>
      <div>
        <h4 class="font-black text-lg mb-4">{COLUMN_TITLE}</h4>
        <ul class="space-y-2 font-mono text-sm text-gray-400">
          {FOOTER_LINKS}
        </ul>
      </div>
    </div>
  </div>
</footer>
```

---

## [CHECKLIST] 生成后自检清单

**在输出代码前,必须逐项验证以下每一条。如有违反,立即修正后再输出:**

### 1. 圆角检查
- [ ] 搜索代码中的 `rounded-`
- [ ] 确认只有 `rounded-none` 或无圆角
- [ ] 如果发现 `rounded-lg`、`rounded-md` 等,替换为 `rounded-none`

### 2. 阴影检查
- [ ] 搜索代码中的 `shadow-`
- [ ] 确认只使用 `shadow-[Xpx_Xpx_0px_0px_rgba(...)]` 格式
- [ ] 如果发现 `shadow-lg`、`shadow-xl` 等,替换为正确格式

### 3. 边框检查
- [ ] 搜索代码中的 `border-`
- [ ] 确认边框颜色是 `border-black`
- [ ] 如果发现 `border-gray-*`、`border-slate-*`,替换为 `border-black`

### 4. 交互检查
- [ ] 所有按钮都有 `hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px]`
- [ ] 所有卡片都有 hover 效果(阴影变色或位移)
- [ ] 都包含 `transition-all`

### 5. 响应式检查
- [ ] 边框有 `border-2 md:border-4`
- [ ] 阴影有 `shadow-[4px...] md:shadow-[8px...]`
- [ ] 间距有 `p-4 md:p-6` 或类似的响应式值
- [ ] 字号有 `text-sm md:text-base` 或类似的响应式值

### 6. 字体检查
- [ ] 标题使用 `font-black`
- [ ] 正文使用 `font-mono`

> CRITICAL: **如果任何一项检查不通过,必须修正后重新生成代码。**

---

## [EXAMPLES] 示例 Prompt

### 1. 视觉小说对话页面

ADV格式的交互对话页面,带铭牌和装饰边角

```
Use Visual Novel style to create an interactive story page:
1. Scene: full-screen sky gradient with character silhouettes at bottom
2. ADV dialog panel: semi-transparent dark panel at bottom with ornate L-shaped corner decorations
3. Character nameplate: colored badge above the dialog box text
4. Choice buttons: full-width frosted glass panels with hover glow and right arrow
5. Cards: scene chapter cards with header image area and nameplate badge overlapping the border
6. Form: save screen with ornate corner frame, dark backdrop, and dual-color labeled inputs
```

软性提示词

保留风格方向,允许实现灵活

STYLEKIT_STYLE_REFERENCE
style_name: 视觉小说风
style_slug: visual-novel
style_source: /styles/visual-novel

# Soft Prompt

保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。

## Style Signals
- 视觉小说
- ADV对话框
- 铭牌
- 立绘
- 选项
- 游戏UI

## Prefer
- 使用半透明暗色面板 bg-[#1a202c]/85 作为对话框
- 使用半透明亮色面板 bg-white/70 作为信息卡片
- 所有面板添加毛玻璃效果 backdrop-blur-md
- 使用衬线字体 font-serif 用于叙事/对话文本

## Avoid
- 禁止使用粗重的野蛮主义边框(border-4+)
- 禁止使用霓虹灯 RGB 分离阴影效果
- 禁止使用像素艺术风格或等宽字体用于主内容

## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。

设计哲学

Visual Novel 风格源于日本ADV(Adventure)视觉小说游戏的UI设计,强调叙事沉浸感和角色互动。

核心理念: - ADV对话框系统:底部固定半透明暗色面板,承载角色对话文字 - 角色铭牌徽章:对话框上方的彩色小标签,标识说话角色 - 装饰性边角框线:对话面板四角的L形装饰线条,营造精致画框感 - 分支选项按钮:居中排列的毛玻璃按钮,代表故事分支 - 场景氛围渲染:通过天空渐变、剪影、柔光营造时间和情感氛围 - 存档界面设计:带装饰边角的暗色面板,包含输入框和操作按钮

必须做 / Do's

  • +使用半透明暗色面板 bg-[#1a202c]/85 作为对话框
  • +使用半透明亮色面板 bg-white/70 作为信息卡片
  • +所有面板添加毛玻璃效果 backdrop-blur-md
  • +使用衬线字体 font-serif 用于叙事/对话文本
  • +使用无衬线字体 font-sans 用于UI标签和按钮
  • +添加角色铭牌徽章(彩色小标签 inline-block px-3 py-0.5 bg-[color] rounded-sm)
  • +对话面板添加L形装饰边角(border-l/t/r/b 组合)
  • +使用圆角 rounded-lg 保持柔和界面感

禁止做 / Don'ts

  • -禁止使用粗重的野蛮主义边框(border-4+)
  • -禁止使用霓虹灯 RGB 分离阴影效果
  • -禁止使用像素艺术风格或等宽字体用于主内容
  • -禁止使用纯黑背景 bg-black
  • -禁止使用全大写加宽字距的终端风格文字
  • -禁止使用直角 rounded-none(除铭牌 rounded-sm 外)

组件模板

组件预览

按钮

视觉小说选项按钮,毛玻璃分支选择

▶ "I should go to the rooftop and watch the sunset."
tsx
<button className="group relative w-full px-8 py-4 bg-[#1a202c]/60 backdrop-blur-md text-[#e2e8f0] font-sans text-lg text-left rounded-lg border border-[#6366f1]/30 hover:bg-[#6366f1]/20 hover:border-[#6366f1]/60 hover:text-white hover:-translate-y-0.5 active:translate-x-2 transition-all duration-300 ease-out overflow-hidden">
  {/* 选中高光扫过 */}
  <div className="absolute inset-0 bg-gradient-to-r from-transparent via-white/5 to-transparent -translate-x-full group-hover:translate-x-full transition-transform duration-700 ease-out" />
  <div className="flex items-center gap-3 relative z-10">
    <span className="opacity-0 -translate-x-2 group-hover:opacity-100 group-hover:translate-x-0 text-[#6366f1] transition-all duration-300">
      ▶
    </span>
    <span>"I should go to the rooftop and watch the sunset."</span>
  </div>
</button>

全局样式

全局 CSS

css
/* Visual Novel Global Styles */

:root {
  --vn-slate: #4a5568;
  --vn-light: #f7fafc;
  --vn-indigo: #6366f1;
  --vn-pink: #ec4899;
  --vn-emerald: #10b981;
  --vn-dark: #1a202c;
}

/* Dialog box fade-in */
.vn-dialog {
  animation: vnFadeUp 0.5s ease-out;
}
@keyframes vnFadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Text typewriter effect */
.vn-typewriter {
  overflow: hidden;
  border-right: 2px solid var(--vn-indigo);
  white-space: nowrap;
  animation: vnType 3s steps(40, end), vnBlink 0.75s step-end infinite;
}
@keyframes vnType {
  from { width: 0; }
  to { width: 100%; }
}
@keyframes vnBlink {
  from, to { border-color: transparent; }
  50% { border-color: var(--vn-indigo); }
}

/* Ornate corner decoration frame */
.vn-ornate-frame {
  position: relative;
}
.vn-ornate-frame::before,
.vn-ornate-frame::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  pointer-events: none;
}
.vn-ornate-frame::before {
  top: 8px;
  left: 8px;
  border-left: 2px solid rgba(99, 102, 241, 0.4);
  border-top: 2px solid rgba(99, 102, 241, 0.4);
}
.vn-ornate-frame::after {
  top: 8px;
  right: 8px;
  border-right: 2px solid rgba(99, 102, 241, 0.4);
  border-top: 2px solid rgba(99, 102, 241, 0.4);
}

/* Character nameplate badge */
.vn-nameplate {
  display: inline-block;
  padding: 2px 12px;
  border-radius: 2px;
  font-size: 0.75rem;
  font-weight: 600;
  color: white;
}

/* Choice button hover glow */
.vn-choice:hover {
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.15);
}

/* Scene gradient overlay */
.vn-scene-sunset {
  background: linear-gradient(180deg, #4a6fa5 0%, #7b9cc7 40%, #c4a882 70%, #e8c19a 100%);
}

无障碍

无障碍评分

基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。

41

综合评分

等级: D - 较差

对比度

分数: 24/100平均比率: 3.39:1
AA 未通过AAA 未通过
场景颜色比率AAAAA
Text on background
/#4a5568 / #f7fafc
7.18:1
Secondary text on background
/#6366f1 / #f7fafc
4.26:1
Muted text on background
/#4a5568 / #f7fafc
7.18:1
Button primary
/#ffffff / #6366f1
4.47:1
Text on accent 1
/#4a5568 / #6366f1
1.68:1
Alt text on accent 1
/#6366f1 / #6366f1
1:1
Text on accent 2
/#4a5568 / #ec4899
2.13:1
Alt text on accent 2
/#6366f1 / #ec4899
1.27:1
Text on accent 3
/#4a5568 / #10b981
2.97:1
Alt text on accent 3
/#6366f1 / #10b981
1.76:1

可读性

分数

82/100

字号

text-sm md:text-base

字重

font-serif font-medium

行高

default

评分基于 WCAG 2.1 标准。AA 级要求普通文本对比度 4.5:1、大文本 3:1;AAA 级要求普通文本 7:1、大文本 4.5:1。

IDE 集成

IDE 配置导出

下载 AI 编码助手的配置文件,使其按照此风格生成代码。

风格包

导出风格包

获取完整的可机器读取风格资源,包括 Design Tokens、Tailwind 预设、CSS 变量和 shadcn/ui 主题。

Metadata

Style metadata including version information

Design Tokens

Figma / Style Dictionary / Tokens Studio 兼容

Tailwind Preset

Tailwind CSS 主题预设,可直接在配置中引用

Global CSS

包含 CSS 变量和基础样式

shadcn Theme

shadcn/ui 主题配置

CSS Variables

纯 CSS 变量,适用于任何项目

SKILL.md

可加载到 Cursor / Claude Code / VS Code 的技能包

社区

评分与反馈

登录后评分
0 条评论
登录后才能发表评论。 去登录

StyleKit

精选网页设计风格库,帮助 AI 生成更好看的网站。

导航

风格库模板对比

资源

GitHub 仓库

(c) 2026 StyleKit. 开源项目。

基于 Editorial 风格构建