故障艺术风
Glitch Art
数字故障美学风格,通过RGB色彩通道分离、水平位移带、扫描线纹理、VHS追踪错误和数据损坏块,呈现赛博朋克式的视觉冲击和信号腐蚀质感。
配色方案
Primary
#00ffff
Secondary
#0a0a0a
Accent 1
#ff00ff
Accent 2
#ffff00
Accent 3
#ffffff
提示词
硬性 + 软性提示词
一键复制并生成 故障艺术风 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。
硬性提示词
高一致性,严格执行风格规则
STYLEKIT_STYLE_REFERENCE
style_name: 故障艺术风
style_slug: glitch-art
style_source: /styles/glitch-art
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# Glitch Art (故障艺术风) Design System
> 数字故障美学风格,通过RGB色彩通道分离、水平位移带、扫描线纹理、VHS追踪错误和数据损坏块,呈现赛博朋克式的视觉冲击和信号腐蚀质感。
## 核心理念
Glitch Art 是一种拥抱数字错误与技术故障的艺术形式,将系统崩溃和数据损坏转化为视觉表达。完美是数字世界的幻觉——我们在断裂的代码、丢失的帧和剧烈失同步的像素中发现美。
核心理念:
- RGB通道分离:将CMY三通道故意错位,产生色彩偏移阴影效果
- 水平位移带:通过clip-path随机裁切区域产生水平错位
- 扫描线纹理:CRT显示器的水平扫描线覆盖层
- VHS追踪错误:模拟老式录像带的追踪错误横线
- 数据损坏块:随机分布的半透明色彩块模拟数据丢失
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border
颜色: border-[#00ffff]/20
圆角: rounded-none
```
### 阴影
```
小: shadow-[2px_0_#ff00ff,-2px_0_#ffff00]
中: shadow-[3px_0_#ff00ff,-3px_0_#ffff00]
大: shadow-[6px_0_#ff00ff,-6px_0_#ffff00]
悬停: hover:shadow-[6px_0_#ff00ff,-6px_0_#ffff00]
聚焦: focus:shadow-[0_0_10px_#00ffff30,3px_0_#ff00ff20,-3px_0_#ffff0020]
```
### 交互效果
```
悬停位移: hover:translate-x-[1px] hover:translate-y-[1px]
过渡动画: transition-all duration-100 ease-in-out
按下状态: active:translate-x-[1px] active:translate-y-[1px]
```
### 字体
```
标题: font-mono font-bold uppercase tracking-widest
正文: font-mono
```
### 字号
```
Hero: text-6xl md:text-8xl lg:text-9xl
H1: text-3xl md:text-5xl
H2: text-2xl md:text-4xl
H3: text-lg md:text-xl
正文: 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
- `rounded-lg`
- `rounded-xl`
- `rounded-2xl`
- `rounded-full`
- `shadow-sm`
- `shadow-md`
- `shadow-lg`
- `shadow-xl`
- `font-serif`
- `font-sans`
- `bg-pink-50`
- `bg-pink-100`
- `bg-rose-50`
- `text-pink-400`
- `text-rose-400`
- `backdrop-blur-md`
- `backdrop-blur-sm`
### 禁止的模式
- 匹配 `^rounded-(?:lg|xl|2xl|full)$`
- 匹配 `^shadow-(?:sm|md|lg|xl)$`
- 匹配 `^font-(?:serif|sans)$`
- 匹配 `^bg-(?:pink|rose)-`
- 匹配 `^text-(?:green|brown|amber)-`
- 匹配 `^backdrop-blur-`
### 禁止原因
- `rounded-lg`: Glitch Art uses sharp edges (rounded-none only) for digital corruption aesthetic
- `shadow-sm`: Glitch Art uses RGB split shadows only, not soft box shadows
- `font-serif`: Glitch Art uses monospace fonts exclusively for terminal aesthetic
- `font-sans`: Glitch Art uses monospace fonts exclusively for terminal aesthetic
- `bg-pink-50`: Glitch Art uses pure black backgrounds with neon CMY accents only
- `backdrop-blur-md`: Glitch Art avoids frosted glass effects; uses scan lines and noise instead
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
rounded-none
font-mono font-bold uppercase tracking-widest
shadow-[3px_0_#ff00ff,-3px_0_#ffff00]
transition-all duration-100 ease-in-out
```
### 卡片必须包含
```
rounded-none
bg-[#0a0a0a]
border border-[#00ffff]/20
```
### 输入框必须包含
```
rounded-none
border border-[#00ffff]/30
bg-[#0a0a0a]
font-mono
text-[#00ffff]
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-none font-mono font-bold uppercase tracking-widest shadow-[3px_0_#ff00ff,-3px_0_#ffff00] transition-all duration-100 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-none bg-[#0a0a0a] border border-[#00ffff]/20 p-5 md:p-8">
<h3 class="font-mono font-bold uppercase tracking-widest text-lg md:text-xl">标题</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-none border border-[#00ffff]/30 bg-[#0a0a0a] font-mono text-[#00ffff] 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. 故障艺术着陆页
数字故障风格的着陆页,带RGB分离标题和数据损坏面板
```
Use Glitch Art style to create a cyberpunk terminal landing page:
1. Background: pure black with scan line overlay and VHS tracking error lines
2. Title: large mono font with 3-layer RGB channel split (cyan/magenta/yellow offsets)
3. Cards: dark panels with left border accent and displacement band top borders
4. Only use cyan, magenta, yellow on black -- no other colors
5. Include signal monitor panel with hex readouts and progress bars
6. All elements use sharp corners (rounded-none) and RGB split shadows
```软性提示词
保留风格方向,允许实现灵活
STYLEKIT_STYLE_REFERENCE
style_name: 故障艺术风
style_slug: glitch-art
style_source: /styles/glitch-art
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- 故障
- 像素
- RGB分离
- 扫描线
- 数字损坏
- 位移
## Prefer
- 全局使用等宽字体 font-mono,标题加粗 font-black + 全大写 uppercase + 宽字距 tracking-widest
- 用 Tailwind 任意值 text-shadow 模拟 RGB 色彩分离,如 [text-shadow:3px_0_#ff00ff,-3px_0_#00ffff]
- 所有状态切换使用 transition-none,营造帧丢失的断裂感
- 卡片使用粗左边框(border-l-4 ~ border-l-8)标记,hover 时切换边框颜色
## Avoid
- 禁止任何圆角——所有元素必须 rounded-none,棱角分明
- 禁止平滑过渡动画(duration-300、ease-in-out 等),动画应像丢帧一样突变
- 禁止使用柔和阴影(shadow-sm/md/lg)——阴影只能是纯色块偏移
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。设计哲学
Glitch Art 是一种拥抱数字错误与技术故障的艺术形式,将系统崩溃和数据损坏转化为视觉表达。完美是数字世界的幻觉——我们在断裂的代码、丢失的帧和剧烈失同步的像素中发现美。
核心理念: - RGB通道分离:将CMY三通道故意错位,产生色彩偏移阴影效果 - 水平位移带:通过clip-path随机裁切区域产生水平错位 - 扫描线纹理:CRT显示器的水平扫描线覆盖层 - VHS追踪错误:模拟老式录像带的追踪错误横线 - 数据损坏块:随机分布的半透明色彩块模拟数据丢失
必须做 / Do's
- +全局使用等宽字体 font-mono,标题加粗 font-black + 全大写 uppercase + 宽字距 tracking-widest
- +用 Tailwind 任意值 text-shadow 模拟 RGB 色彩分离,如 [text-shadow:3px_0_#ff00ff,-3px_0_#00ffff]
- +所有状态切换使用 transition-none,营造帧丢失的断裂感
- +卡片使用粗左边框(border-l-4 ~ border-l-8)标记,hover 时切换边框颜色
- +按钮 :active 状态使用 skew-x + scale-y 组合制造屏幕撕裂效果
- +背景叠加扫描线纹理覆盖层(repeating-linear-gradient 间隔 2-4px)
- +hover 时执行前景/背景色快速反转 + RGB 偏移放大至 6px 级别
禁止做 / Don'ts
- -禁止任何圆角——所有元素必须 rounded-none,棱角分明
- -禁止平滑过渡动画(duration-300、ease-in-out 等),动画应像丢帧一样突变
- -禁止使用柔和阴影(shadow-sm/md/lg)——阴影只能是纯色块偏移
- -禁止使用毛玻璃效果(backdrop-blur)或柔和渐变背景
- -禁止使用 CMY 三色以外的装饰色(粉色、自然色系、暖色调等)
- -禁止使用衬线或无衬线字体——只允许 monospace 等宽字体
组件模板
组件预览
按钮
故障风格按钮,带RGB通道分离阴影和撕裂 active 效果
<button className="group relative px-8 py-3 bg-[#0a0a0a] text-white font-mono font-black uppercase tracking-[0.2em] border-2 border-[#00ffff] shadow-[4px_4px_0_#ff00ff] hover:bg-[#00ffff] hover:text-[#0a0a0a] hover:shadow-[-4px_-4px_0_#ffff00] active:skew-x-[-15deg] active:scale-y-90 active:shadow-none transition-none overflow-hidden">
<span className="absolute inset-0 w-full h-[2px] bg-white opacity-0 group-hover:opacity-100 group-hover:animate-pulse top-1/2 -translate-y-1/2" />
<span className="relative z-10 group-hover:[text-shadow:2px_0_#ff00ff,-2px_0_#000000] transition-none">
EXECUTE.EXE
</span>
</button>全局样式
全局 CSS
/* Glitch Art Global Styles */
:root {
--glitch-cyan: #00ffff;
--glitch-magenta: #ff00ff;
--glitch-yellow: #ffff00;
--glitch-black: #0a0a0a;
--glitch-white: #ffffff;
}
/* Scan line overlay */
.glitch-scanlines::after {
content: "";
position: absolute;
inset: 0;
background: repeating-linear-gradient(
0deg,
transparent,
transparent 2px,
rgba(0, 255, 255, 0.03) 2px,
rgba(0, 255, 255, 0.03) 4px
);
pointer-events: none;
}
/* RGB split text effect using data-text attribute */
.glitch-rgb {
position: relative;
}
.glitch-rgb::before {
content: attr(data-text);
position: absolute;
top: 3px;
left: 5px;
color: var(--glitch-magenta);
opacity: 0.5;
clip-path: inset(0 0 50% 0);
}
.glitch-rgb::after {
content: attr(data-text);
position: absolute;
top: -3px;
left: -5px;
color: var(--glitch-yellow);
opacity: 0.3;
clip-path: inset(50% 0 0 0);
}
/* Horizontal displacement band */
.glitch-displace {
position: relative;
}
.glitch-displace::after {
content: "";
position: absolute;
left: -10px;
right: -10px;
top: 50%;
height: 3px;
background: var(--glitch-magenta);
opacity: 0.2;
transform: translateY(-50%);
pointer-events: none;
}
/* VHS tracking error */
.glitch-vhs::before {
content: "";
position: absolute;
left: 0;
right: 0;
height: 2px;
background: linear-gradient(90deg, transparent 20%, rgba(0, 255, 255, 0.08) 40%, rgba(255, 0, 255, 0.06) 60%, transparent 80%);
pointer-events: none;
}
/* Noise texture */
.glitch-noise::before {
content: "";
position: absolute;
inset: 0;
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.05'/%3E%3C/svg%3E");
pointer-events: none;
}无障碍
无障碍评分
基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。
综合评分
等级: C - 一般
对比度
| 场景 | 颜色 | 比率 | AA | AAA |
|---|---|---|---|---|
| Text on background | /#00ffff / #0a0a0a | 15.79:1 | ||
| Secondary text on background | /#ff00ff / #0a0a0a | 6.31:1 | ||
| Muted text on background | /#ffffff / #0a0a0a | 19.8:1 | ||
| Text on secondary background | /#00ffff / #111111 | 15.06:1 | ||
| Secondary text on secondary | /#ff00ff / #111111 | 6.02:1 | ||
| Button primary | /#0a0a0a / #00ffff | 15.79:1 | ||
| Text on accent 1 | /#00ffff / #00ffff | 1:1 | ||
| Alt text on accent 1 | /#ff00ff / #00ffff | 2.5:1 | ||
| Text on accent 2 | /#00ffff / #ff00ff | 2.5:1 | ||
| Alt text on accent 2 | /#ff00ff / #ff00ff | 1:1 | ||
| Text on accent 3 | /#00ffff / #ffff00 | 1.17:1 | ||
| Alt text on accent 3 | /#ff00ff / #ffff00 | 2.92:1 |
可读性
分数
82/100
字号
text-sm md:text-base
字重
font-mono font-bold uppercase tracking-widest
行高
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 的技能包