漫画风格
Comic Style
灵感源自漫画书和日式漫画的设计风格,浓重的墨线边框、网点填充、对话气泡、动作线和分镜面板布局,充满故事感和视觉冲击力。
配色方案
Primary
#1a1a1a
Secondary
#ffffff
Accent 1
#ff3333
Accent 2
#ffcc00
Accent 3
#3366ff
Accent 4
#33cc33
提示词
硬性 + 软性提示词
一键复制并生成 漫画风格 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。
硬性提示词
高一致性,严格执行风格规则
STYLEKIT_STYLE_REFERENCE
style_name: 漫画风格
style_slug: comic-style
style_source: /styles/comic-style
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# Comic Style (漫画风格) Design System
> 灵感源自漫画书和日式漫画的设计风格,浓重的墨线边框、网点填充、对话气泡、动作线和分镜面板布局,充满故事感和视觉冲击力。
## 核心理念
Comic Style 是一种源自漫画书和日式漫画的设计风格,通过浓重的墨线边框、半调网点、对话气泡和动态线条,将界面变成生动的漫画面板。
核心理念:
- 墨线感:使用粗重的黑色边框勾勒元素轮廓
- 网点效果:使用 halftone dots 模拟漫画印刷质感
- 动态感:通过速度线和动作线表达能量与运动
- 叙事性:每个区块都像漫画的一帧,讲述故事
- 情绪爆发:交互要像 POW! BAM! 一样夸张有力
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border-4
颜色: border-[#1a1a1a]
圆角: rounded-lg
```
### 阴影
```
小: shadow-[3px_3px_0px_0px_rgba(26,26,26,1)] md:shadow-[4px_4px_0px_0px_rgba(26,26,26,1)]
中: shadow-[4px_4px_0px_0px_rgba(26,26,26,1)] md:shadow-[6px_6px_0px_0px_rgba(26,26,26,1)]
大: shadow-[6px_6px_0px_0px_rgba(26,26,26,1)] md:shadow-[10px_10px_0px_0px_rgba(26,26,26,1)]
悬停: hover:shadow-[2px_2px_0px_0px_rgba(26,26,26,1)]
聚焦: focus:shadow-[4px_4px_0px_0px_rgba(26,26,26,1)]
```
### 交互效果
```
悬停位移: hover:translate-x-[2px] hover:translate-y-[2px]
过渡动画: transition-all duration-150
按下状态: active:translate-x-[4px] active:translate-y-[4px]
```
### 字体
```
标题: font-black uppercase tracking-wide
正文: font-sans font-bold
```
### 字号
```
Hero: text-5xl md:text-7xl lg:text-8xl
H1: text-4xl md:text-5xl
H2: text-2xl md:text-4xl
H3: text-xl md:text-2xl
正文: text-sm md:text-base
小字: text-xs md:text-sm
```
### 间距
```
Section: py-10 md:py-20 lg:py-28
容器: px-4 md:px-8 lg:px-12
卡片: p-4 md:p-6
```
---
## [FORBIDDEN] 绝对禁止
以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:
### 禁止的 Class
- `border`
- `border-[0.5px]`
- `border-gray-200`
- `border-gray-300`
- `border-slate-200`
- `shadow-sm`
- `shadow`
- `shadow-md`
- `text-gray-400`
- `text-gray-500`
- `text-gray-300`
- `bg-gray-50`
- `bg-gray-100`
- `bg-slate-50`
- `opacity-50`
- `opacity-60`
- `font-light`
- `font-normal`
### 禁止的模式
- 匹配 `^border-(?:gray|slate)-`
- 匹配 `^shadow-(?:sm|md|lg|xl)$`
- 匹配 `^text-(?:gray|slate)-(?:[3-5])`
- 匹配 `^bg-(?:gray|slate)-(?:[1-3])`
- 匹配 `^font-(?:light|thin|normal)$`
### 禁止原因
- `border-gray-200`: Comic style uses thick black ink borders (border-4 border-[#1a1a1a])
- `shadow-md`: Comic style uses hard-edge offset shadows, not blurred
- `text-gray-400`: Comic style uses bold high-contrast text, not subtle muted colors
- `font-light`: Comic style uses bold/black font weights for impact
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
rounded-lg
border-4 border-[#1a1a1a]
shadow-[4px_4px_0px_0px_rgba(26,26,26,1)]
hover:translate-x-[2px] hover:translate-y-[2px]
hover:shadow-[2px_2px_0px_0px_rgba(26,26,26,1)]
transition-all duration-150
font-black uppercase
```
### 卡片必须包含
```
rounded-lg
border-4 border-[#1a1a1a]
shadow-[4px_4px_0px_0px_rgba(26,26,26,1)]
bg-[#fffef0]
```
### 输入框必须包含
```
rounded-lg
border-4 border-[#1a1a1a]
font-bold
focus:shadow-[4px_4px_0px_0px_rgba(26,26,26,1)]
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 border-4 border-[#1a1a1a] shadow-[4px_4px_0px_0px_rgba(26,26,26,1)] hover:translate-x-[2px] hover:translate-y-[2px] hover:shadow-[2px_2px_0px_0px_rgba(26,26,26,1)] transition-all duration-150 font-black uppercase 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 border-4 border-[#1a1a1a] shadow-[4px_4px_0px_0px_rgba(26,26,26,1)] bg-[#fffef0] p-4 md:p-6">
<h3 class="font-black uppercase tracking-wide 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-4 border-[#1a1a1a] font-bold focus:shadow-[4px_4px_0px_0px_rgba(26,26,26,1)] 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. 漫画英雄页面
漫画风格的英雄介绍页
```
用 Comic Style 风格创建一个英雄介绍页,要求:
1. 使用漫画面板分镜布局
2. 粗墨线边框 border-4 border-black
3. 半调网点背景纹理(radial-gradient,opacity-10)
4. 对话气泡展示角色台词
5. 动作线表达能量和动态感
6. 鲜明的红黄蓝配色
7. 按钮 hover 时 scale-110 rotate(-3deg) 弹出 + 颜色翻转
```
### 2. 漫画作品展示
漫画风格的作品集
```
用 Comic Style 风格设计一个作品展示页,要求:
1. 每个作品用漫画面板包裹(border-4 border-black)
2. 粗黑色边框和硬边阴影(shadow-[8px_8px_0_#000])
3. 卡片 group-hover 时黄色 NEW! 标签从 scale-0 弹出
4. hover 时卡片阴影从 8px 扩大到 16px + -translate-y-2
5. 半调网点作为背景纹理
6. 点击时 active:shadow-none 瞬间墨水压迫感
```软性提示词
保留风格方向,允许实现灵活
STYLEKIT_STYLE_REFERENCE
style_name: 漫画风格
style_slug: comic-style
style_source: /styles/comic-style
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- 漫画
- manga
- 网点
- 对话气泡
- 分镜
- 动作线
## Prefer
- 使用粗黑色边框 border-4 border-black 模拟墨线
- 使用硬边阴影 shadow-[4px_4px_0_#000] 模拟印刷偏移
- 使用对话气泡形状展示信息
- 使用半调网点作为背景纹理
## Avoid
- 禁止使用柔和阴影 shadow-lg
- 禁止使用过细的边框 border
- 禁止使用渐变作为主要视觉效果
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。设计哲学
Comic Style 是一种源自漫画书和日式漫画的设计风格,通过浓重的墨线边框、半调网点、对话气泡和动态线条,将界面变成生动的漫画面板。
核心理念: - 墨线感:使用粗重的黑色边框勾勒元素轮廓 - 网点效果:使用 halftone dots 模拟漫画印刷质感 - 动态感:通过速度线和动作线表达能量与运动 - 叙事性:每个区块都像漫画的一帧,讲述故事 - 情绪爆发:交互要像 POW! BAM! 一样夸张有力
必须做 / Do's
- +使用粗黑色边框 border-4 border-black 模拟墨线
- +使用硬边阴影 shadow-[4px_4px_0_#000] 模拟印刷偏移
- +使用对话气泡形状展示信息
- +使用半调网点作为背景纹理
- +文字使用大写粗体 uppercase font-black
- +按钮使用夸张的悬停效果
- +hover 时 scale-110 + rotate(-3deg),像漫画音效气泡弹出
- +group-hover 时隐藏的 NEW! 标签从 scale-0 弹出 scale-100
- +active 时阴影瞬间归零,制造墨水压迫感
- +hover 时背景网点(radial-gradient)浮现(group-hover:opacity-20)
禁止做 / Don'ts
- -禁止使用柔和阴影 shadow-lg
- -禁止使用过细的边框 border
- -禁止使用渐变作为主要视觉效果
- -禁止使用过于正式的排版
- -禁止缺少动态感和能量感
- -禁止使用圆角(rounded-lg, rounded-xl),对话气泡除外
- -禁止使用过长的 duration(最长 duration-100)
组件模板
组件预览
按钮
漫画按钮,hover 夸张弹出 + 颜色翻转 + 网点浮现
<button className="
group relative px-8 py-3
bg-[#ff3333]
border-4 border-black
rounded-none
text-white font-black text-xl uppercase tracking-wider
shadow-[6px_6px_0_#000]
hover:scale-110 hover:-rotate-3
hover:bg-[#ffcc00] hover:text-black
hover:shadow-[10px_10px_0_#000]
active:scale-95 active:rotate-2
active:translate-x-2 active:translate-y-2
active:shadow-none
transition-all duration-100
overflow-hidden cursor-crosshair
">
<div className="absolute inset-0 bg-[radial-gradient(#000_20%,transparent_20%)] bg-[size:4px_4px] opacity-0 group-hover:opacity-10 pointer-events-none transition-opacity duration-100" />
<span className="relative z-10 block">CLICK!</span>
</button>全局样式
全局 CSS
/* Comic Style 全局样式 */
:root {
--comic-black: #1a1a1a;
--comic-white: #ffffff;
--comic-red: #ff3333;
--comic-yellow: #ffcc00;
--comic-blue: #3366ff;
--comic-green: #33cc33;
}
/* 半调网点背景 */
.comic-halftone {
background-image: radial-gradient(circle, var(--comic-black) 1px, transparent 1px);
background-size: 6px 6px;
}
/* 对话气泡 */
.comic-bubble {
position: relative;
background: white;
border: 4px solid var(--comic-black);
border-radius: 24px;
padding: 16px 20px;
}
.comic-bubble::after {
content: '';
position: absolute;
bottom: -20px;
left: 30px;
width: 0;
height: 0;
border-left: 12px solid transparent;
border-right: 12px solid transparent;
border-top: 20px solid var(--comic-black);
}
/* 动作线 */
.comic-speed-lines {
background: repeating-linear-gradient(
90deg,
transparent,
transparent 8px,
rgba(0, 0, 0, 0.05) 8px,
rgba(0, 0, 0, 0.05) 10px
);
}
/* 漫画面板边框 */
.comic-panel {
border: 4px solid var(--comic-black);
box-shadow: 6px 6px 0 var(--comic-black);
}
/* 漫画文字效果 */
.comic-text {
font-family: 'Comic Sans MS', 'Bangers', cursive, sans-serif;
font-weight: 900;
text-transform: uppercase;
}
/* 爆炸效果标签 — hover 时弹出 */
.comic-burst {
background: var(--comic-yellow);
border: 3px solid var(--comic-black);
font-weight: 900;
transform: rotate(-3deg) scale(0);
transition: transform 0.1s ease-out;
}
.group:hover .comic-burst {
transform: rotate(-3deg) scale(1);
}
/* Pop-art 按钮弹出 */
.comic-pop {
transition: all 0.1s ease-out;
cursor: crosshair;
}
.comic-pop:hover {
transform: scale(1.1) rotate(-3deg);
box-shadow: 10px 10px 0 var(--comic-black);
}
.comic-pop:active {
transform: scale(0.95) rotate(2deg) translate(4px, 4px);
box-shadow: none;
}无障碍
无障碍评分
基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。
综合评分
等级: C - 一般
对比度
| 场景 | 颜色 | 比率 | AA | AAA |
|---|---|---|---|---|
| Text on background | /#1a1a1a / #fffef0 | 17.14:1 | ||
| Secondary text on background | /#ffffff / #fffef0 | 1.02:1 | ||
| Muted text on background | /#4a4a4a / #fffef0 | 8.73:1 | ||
| Text on secondary background | /#1a1a1a / #1a1a1a | 1:1 | ||
| Secondary text on secondary | /#ffffff / #1a1a1a | 17.4:1 | ||
| Button primary | /#ffffff / #ef4444 | 3.76:1 | ||
| Text on accent 1 | /#1a1a1a / #ef4444 | 4.62:1 | ||
| Alt text on accent 1 | /#ffffff / #ef4444 | 3.76:1 | ||
| Text on accent 2 | /#1a1a1a / #3b82f6 | 4.73:1 | ||
| Alt text on accent 2 | /#ffffff / #3b82f6 | 3.68:1 | ||
| Text on accent 3 | /#1a1a1a / #facc15 | 11.36:1 | ||
| Alt text on accent 3 | /#ffffff / #facc15 | 1.53:1 | ||
| Text on accent 4 | /#1a1a1a / #22c55e | 7.64:1 | ||
| Alt text on accent 4 | /#ffffff / #22c55e | 2.28:1 |
可读性
分数
87/100
字号
text-sm md:text-base
字重
font-black uppercase tracking-wide
行高
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 的技能包