拼贴艺术风
Collage Art
杂志拼贴和混合材料美学,纸片剪切、多层叠加、撕纸边缘和混搭字体,营造充满创意和手工感的视觉冲击。
配色方案
Primary
#2d2d2d
Secondary
#f5f0e8
Accent 1
#e74c3c
Accent 2
#3498db
Accent 3
#f39c12
Accent 4
#9b59b6
提示词
硬性 + 软性提示词
一键复制并生成 拼贴艺术风 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。
硬性提示词
高一致性,严格执行风格规则
STYLEKIT_STYLE_REFERENCE
style_name: 拼贴艺术风
style_slug: collage-art
style_source: /styles/collage-art
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# Collage Art (拼贴艺术风) Design System
> 杂志拼贴和混合材料美学,纸片剪切、多层叠加、撕纸边缘和混搭字体,营造充满创意和手工感的视觉冲击。
## 核心理念
拼贴艺术风格源于达达主义和波普艺术的混合媒材传统,强调不同材料、字体和图像的碰撞与融合。
核心理念:
- 随机旋转:每个元素都有细微的 rotate transform(0.5-2deg),模拟手工粘贴的不精确感
- 和纸胶带装饰:使用 repeating-linear-gradient 条纹伪元素模拟半透明和纸胶带
- 混搭字体:同一页面交替使用 font-serif、font-sans、font-mono 营造杂志剪报感
- 撕纸边缘:polygon clip-path 创造不规则的锯齿状撕纸边缘
- 硬偏移阴影:shadow-[Npx_Npx_0px] 纯色偏移阴影创造纸片层叠的物理深度
- 纸张物理感:hover 时纸片被掀起(scale-105 + 旋转微调),active 时被按压在桌面(阴影骤减)
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border-2
颜色: border-[#2d2d2d]
圆角: rounded-none
```
### 阴影
```
小: shadow-[3px_3px_0px_#2d2d2d]
中: shadow-[5px_5px_0px_#2d2d2d]
大: shadow-[7px_7px_0px_#2d2d2d]
悬停: hover:shadow-[7px_7px_0px_#2d2d2d]
聚焦: focus:shadow-[3px_3px_0px_#2d2d2d]
```
### 交互效果
```
悬停位移: hover:translate-x-[1px] hover:translate-y-[1px]
过渡动画: transition-all duration-200 ease-in-out
按下状态: active:translate-x-[3px] active:translate-y-[3px] active:shadow-none
```
### 字体
```
标题: font-serif font-bold uppercase tracking-wider
正文: font-sans
```
### 字号
```
Hero: text-5xl md:text-7xl lg:text-8xl
H1: text-3xl 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-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-3xl`
- `rounded-full`
- `bg-gradient-to-r`
- `bg-gradient-to-b`
- `bg-gradient-to-br`
- `backdrop-blur`
- `backdrop-blur-sm`
- `backdrop-blur-md`
- `shadow-[0_`
### 禁止的模式
- 匹配 `^rounded-(?:lg|xl|2xl|3xl|full)$`
- 匹配 `^bg-gradient-`
- 匹配 `^backdrop-blur`
- 匹配 `^shadow-\[0_`
### 禁止原因
- `rounded-full`: Collage Art uses sharp corners (rounded-sm/rounded-none) for cut-paper feel
- `rounded-lg`: Collage Art uses rounded-sm or rounded-none, never soft corners
- `bg-gradient-to-r`: Collage Art uses flat solid color blocks, not smooth gradients
- `backdrop-blur`: Collage Art is opaque and layered paper, not translucent glass
- `shadow-[0_`: Collage Art uses hard offset shadows (Npx_Npx_0px), not soft blur shadows
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
rounded-sm
font-bold uppercase
border-2 border-[#2d2d2d]
transition-all duration-200 ease-in-out
```
### 卡片必须包含
```
rounded-none
bg-[#f5f0e8]
border-2 border-[#2d2d2d]
```
### 输入框必须包含
```
rounded-none
border-2 border-[#2d2d2d]
bg-[#f5f0e8]
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-sm font-bold uppercase border-2 border-[#2d2d2d] transition-all duration-200 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-[#f5f0e8] border-2 border-[#2d2d2d] p-5 md:p-8">
<h3 class="font-serif font-bold uppercase tracking-wider 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-none border-2 border-[#2d2d2d] bg-[#f5f0e8] 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. 拼贴艺术杂志页面
杂志拼贴风格的创意页面,带有旋转卡片、和纸胶带装饰和混搭字体
```
Use Collage Art style to create a zine-style page:
1. Background: aged paper #f5f0e8 with torn paper scrap decorations (clip-path polygon)
2. Hero: mixed fonts (serif title + sans subtitle + mono caption), random rotations on each line using rotate-[Xdeg] Tailwind class
3. Cards: hard offset shadows in different colors, each card rotated differently with rotate-[Xdeg]
4. Washi tape: repeating-linear-gradient stripe decorations, wrapped in group div for parallax effect
5. Buttons: rotated via rotate-[Xdeg], hover paper-lift effect (scale-105 + rotation change + shadow expand)
6. Form: mixed font labels (serif/sans/mono), dashed border textarea
7. Typography mixes serif, sans-serif, and monospace throughout
```软性提示词
保留风格方向,允许实现灵活
STYLEKIT_STYLE_REFERENCE
style_name: 拼贴艺术风
style_slug: collage-art
style_source: /styles/collage-art
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- 拼贴
- 剪贴
- 混合材质
- 多层
- 杂志
- 撕纸
## Prefer
- 使用混合字体(衬线 font-serif + 无衬线 font-sans + 等宽 font-mono 交替)
- 元素使用 Tailwind 任意值旋转 rotate-[Ndeg] 而非内联 style transform(避免与 hover 冲突)
- 使用硬偏移阴影 shadow-[Npx_Npx_0px_color] 营造层叠深度
- 添加 washi tape 装饰:repeating-linear-gradient 条纹色块
## Avoid
- 禁止使用平滑渐变(bg-gradient-to-*)
- 禁止使用柔和圆角(rounded-lg 以上)
- 禁止使用毛玻璃效果(backdrop-blur)
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。设计哲学
拼贴艺术风格源于达达主义和波普艺术的混合媒材传统,强调不同材料、字体和图像的碰撞与融合。
核心理念: - 随机旋转:每个元素都有细微的 rotate transform(0.5-2deg),模拟手工粘贴的不精确感 - 和纸胶带装饰:使用 repeating-linear-gradient 条纹伪元素模拟半透明和纸胶带 - 混搭字体:同一页面交替使用 font-serif、font-sans、font-mono 营造杂志剪报感 - 撕纸边缘:polygon clip-path 创造不规则的锯齿状撕纸边缘 - 硬偏移阴影:shadow-[Npx_Npx_0px] 纯色偏移阴影创造纸片层叠的物理深度 - 纸张物理感:hover 时纸片被掀起(scale-105 + 旋转微调),active 时被按压在桌面(阴影骤减)
必须做 / Do's
- +使用混合字体(衬线 font-serif + 无衬线 font-sans + 等宽 font-mono 交替)
- +元素使用 Tailwind 任意值旋转 rotate-[Ndeg] 而非内联 style transform(避免与 hover 冲突)
- +使用硬偏移阴影 shadow-[Npx_Npx_0px_color] 营造层叠深度
- +添加 washi tape 装饰:repeating-linear-gradient 条纹色块
- +使用 polygon clip-path 创造撕纸边缘效果
- +保持陈旧纸张色 bg-[#f5f0e8] 作为底色
- +大胆使用对比色块(红/蓝/黄/紫)
- +使用实线和虚线边框模拟剪切痕迹
- +hover 时纸片上浮 -translate-y-2 + 旋转变化 + 阴影扩张,active 时阴影骤减模拟按压
- +使用 group + group-hover:* 让胶带装饰响应卡片悬停,产生视差效果
禁止做 / Don'ts
- -禁止使用平滑渐变(bg-gradient-to-*)
- -禁止使用柔和圆角(rounded-lg 以上)
- -禁止使用毛玻璃效果(backdrop-blur)
- -禁止使用柔和阴影(shadow-[0_Npx_Npx])
- -禁止使用统一整齐的对齐方式
- -禁止对有 hover/group-hover Tailwind 变换的元素使用 style={{ transform }} 内联属性(会导致 transform 冲突)
组件模板
组件预览
按钮
纸片剪切按钮:hover 时纸片掀起(scale-105 + 旋转变化 + 阴影扩张),active 时被按压桌面(缩小 + 阴影骤减)
<button className="
px-7 py-3
bg-[#e74c3c] text-white
font-bold uppercase tracking-wider
rounded-sm
border-2 border-[#2d2d2d]
shadow-[4px_4px_0px_#2d2d2d]
rotate-[-0.7deg]
hover:scale-105 hover:-rotate-[2deg] hover:-translate-y-1
hover:shadow-[8px_8px_0px_#2d2d2d]
active:scale-95 active:rotate-[1deg] active:translate-y-1
active:shadow-[2px_2px_0px_#2d2d2d]
transition-all duration-200 ease-out
">
Cut & Paste
</button>全局样式
全局 CSS
/* Collage Art Global Styles */
:root {
--col-dark: #2d2d2d;
--col-paper: #f5f0e8;
--col-red: #e74c3c;
--col-blue: #3498db;
--col-yellow: #f39c12;
--col-purple: #9b59b6;
}
/* Torn paper edge clip-path */
.col-torn {
clip-path: polygon(
0% 3%, 5% 0%, 12% 4%, 20% 1%, 28% 3%, 35% 0%, 42% 2%, 50% 0%,
58% 3%, 65% 1%, 72% 4%, 80% 0%, 88% 2%, 95% 0%, 100% 3%,
100% 97%, 95% 100%, 88% 98%, 80% 100%, 72% 97%, 65% 100%,
58% 98%, 50% 100%, 42% 97%, 35% 100%, 28% 98%, 20% 100%,
12% 97%, 5% 100%, 0% 98%
);
}
/* Washi tape decoration - striped repeating-linear-gradient */
.col-tape {
position: relative;
}
.col-tape::before {
content: "";
position: absolute;
top: -10px;
left: 20%;
width: 80px;
height: 20px;
background: repeating-linear-gradient(
90deg,
var(--col-yellow) 0px,
var(--col-yellow) 3px,
rgba(255,255,255,0.3) 3px,
rgba(255,255,255,0.3) 6px
);
opacity: 0.7;
transform: rotate(2deg);
}
/* Paper lift — hover 时上浮,active 时按压 */
.col-paper-lift {
transition: all 0.2s ease-out;
}
.col-paper-lift:hover {
transform: translateY(-8px) scale(1.02) rotate(-1deg);
box-shadow: 12px 12px 0 var(--col-red);
}
.col-paper-lift:active {
transform: translateY(2px) scale(0.98) rotate(1deg);
box-shadow: 2px 2px 0 var(--col-red);
}
/* Stamp/postal mark decoration */
.col-stamp {
border: 3px dashed var(--col-dark);
padding: 8px;
position: relative;
}
.col-stamp::after {
content: "APPROVED";
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) rotate(12deg);
font-family: 'Courier New', monospace;
font-size: 12px;
font-weight: 700;
color: var(--col-red);
opacity: 0.3;
}
/* Newspaper column text */
.col-newspaper {
font-family: 'Times New Roman', serif;
line-height: 1.2;
columns: 2;
column-gap: 20px;
column-rule: 1px solid var(--col-dark);
}无障碍
无障碍评分
基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。
综合评分
等级: D - 较差
对比度
| 场景 | 颜色 | 比率 | AA | AAA |
|---|---|---|---|---|
| Text on background | /#2d2d2d / #f5f0e8 | 12.14:1 | ||
| Secondary text on background | /#e74c3c / #f5f0e8 | 3.37:1 | ||
| Muted text on background | /#2d2d2d / #f5f0e8 | 12.14:1 | ||
| Text on secondary background | /#2d2d2d / #ebe4d8 | 10.9:1 | ||
| Secondary text on secondary | /#e74c3c / #ebe4d8 | 3.02:1 | ||
| Button primary | /#ffffff / #e74c3c | 3.82:1 | ||
| Text on accent 1 | /#2d2d2d / #e74c3c | 3.6:1 | ||
| Alt text on accent 1 | /#e74c3c / #e74c3c | 1:1 | ||
| Text on accent 2 | /#2d2d2d / #3498db | 4.37:1 | ||
| Alt text on accent 2 | /#e74c3c / #3498db | 1.21:1 | ||
| Text on accent 3 | /#2d2d2d / #f39c12 | 6.28:1 | ||
| Alt text on accent 3 | /#e74c3c / #f39c12 | 1.74:1 | ||
| Text on accent 4 | /#2d2d2d / #9b59b6 | 2.95:1 | ||
| Alt text on accent 4 | /#e74c3c / #9b59b6 | 1.22:1 |
可读性
分数
87/100
字号
text-sm md:text-base
字重
font-serif font-bold uppercase tracking-wider
行高
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 的技能包