diff --git a/.gitignore b/.gitignore
index 614a7d8..f5aa258 100644
--- a/.gitignore
+++ b/.gitignore
@@ -56,3 +56,4 @@ database.d.ts
.devtools
data/oss/*
data/test.sqlite
+version.txt
\ No newline at end of file
diff --git a/README.md b/README.md
index 295f668..57ef1b1 100644
--- a/README.md
+++ b/README.md
@@ -52,22 +52,21 @@
> 🚀 **一站式短剧工程**:从文本到角色,从分镜到视频,0门槛全流程AI化,创作效率提升10倍+!
-
---
# 🌐 多语言支持
Toonflow 支持以下语言界面:
-| 语言 | Language |
-|------|----------|
-| 简体中文 | Chinese (Simplified) |
-| 繁體中文 | Chinese (Traditional) |
-| English | English |
-| ไทย | Thai |
-| Tiếng Việt | Vietnamese |
-| 日本語 | Japanese |
-| Русский | Russian |
+| 语言 | Language |
+| ---------- | --------------------- |
+| 简体中文 | Chinese (Simplified) |
+| 繁體中文 | Chinese (Traditional) |
+| English | English |
+| ไทย | Thai |
+| Tiếng Việt | Vietnamese |
+| 日本語 | Japanese |
+| Русский | Russian |
> 💡 更多语言适配中,欢迎贡献翻译!
@@ -75,7 +74,7 @@ Toonflow 支持以下语言界面:
# 🌟 主要功能
-Toonflow v1.0.8 是面向短剧生产的 AI 工作台,围绕“策划 → 编剧 → 分镜 → 出片”构建完整闭环,并支持本地化、可编程、可持续迭代的生产流程。
+Toonflow 是面向短剧生产的 AI 工作台,围绕“策划 → 编剧 → 分镜 → 出片”构建完整闭环,并支持本地化、可编程、可持续迭代的生产流程。
- ✅ **无限画布生产工作台**
以类无限画布形式组织剧本、角色、分镜、素材与视频节点,支持自由编排、回溯与并行生产,不受线性步骤限制。
@@ -94,12 +93,11 @@ Toonflow v1.0.8 是面向短剧生产的 AI 工作台,围绕“策划 → 编
# 📦 应用场景
-- 网文/小说快速影视化改编
-- 短剧团队流水线协作生产
-- 多项目并行的 AI 内容工厂
-- 私有化部署的企业级内容平台
-- 低成本验证剧情与镜头方案
-- 教学与研究场景下的 AIGC 创作实验
+- 短视频内容创作
+- 小说影视化实验
+- AI 文学改编工具
+- 剧本开发与快速原型
+- 视频素材生成
---
@@ -114,7 +112,6 @@ Toonflow v1.0.8 是面向短剧生产的 AI 工作台,围绕“策划 → 编
5. 切换到 ProductionAgent,在无限画布中组织分镜、素材与视频节点。
6. 对分镜图进行节点化精调后回流工作台,完成视频拼接与导出。
-
## 📺 视频教程(待更新,老版本教程已无参考价值)
https://www.bilibili.com/video/BV1na6wB6Ea2
@@ -129,8 +126,6 @@ https://www.bilibili.com/video/BV1na6wB6Ea2
---
-
-
# 🚀 安装
## 前置条件
@@ -145,7 +140,7 @@ https://www.bilibili.com/video/BV1na6wB6Ea2
### 1. 下载与安装
-| 操作系统 | GitHub | Atomgit | 夸克网盘下载 | 说明 |
+| 操作系统 | GitHub | Atomgit | 夸克网盘下载 | 说明 |
| :------: | :----------------------------------------------------------- | :------------------------------------------------------------ | :---------------------------------------------- | :------------- |
| Windows | [Release](https://github.com/HBAI-Ltd/Toonflow-app/releases) | [Release](https://gitcode.com/HBAI-Ltd/Toonflow-app/releases) | [夸克网盘](https://pan.quark.cn/s/94ef07509df0) | 官方发布安装包 |
| Linux | [Release](https://github.com/HBAI-Ltd/Toonflow-app/releases) | [Release](https://gitcode.com/HBAI-Ltd/Toonflow-app/releases) | [夸克网盘](https://pan.quark.cn/s/94ef07509df0) | 官方发布安装包 |
@@ -525,6 +520,12 @@ pm2 monit # 监控面板
+也可以点击图标加入 Discord:
+
+[](https://discord.gg/HEjKmpNpAZ)
+
+或点击邀请连接: [https://discord.gg/HEjKmpNpAZ](https://discord.gg/HEjKmpNpAZ)
+
---
# 💌 联系我们
diff --git a/data/skills/production_agent_decision.md b/data/skills/production_agent_decision.md
index d346195..c16d319 100644
--- a/data/skills/production_agent_decision.md
+++ b/data/skills/production_agent_decision.md
@@ -11,7 +11,13 @@
1. **需求分析**:解析用户请求,判断属于流水线哪个阶段
2. **任务拆解**:将复杂请求分解为可执行的子任务
-3. **调度执行**:通过 `run_sub_agent_execution` 派发任务到执行层
+3. **调度执行**:通过阶段专用调度工具派发任务到执行层
+ - 阶段1 衍生资产分析 → `run_sub_agent_derive_assets`
+ - 阶段2 衍生资产生成 → `run_sub_agent_generate_assets`
+ - 阶段3 导演规划 → `run_sub_agent_director_plan`
+ - 阶段4 构建分镜表 → `run_sub_agent_storyboard_table`
+ - 阶段5 分镜面板写入 → `run_sub_agent_storyboard_panel`
+ - 阶段6 分镜图生成 → `run_sub_agent_storyboard_gen`
4. **质量管控**:通过 `run_sub_agent_supervision` 调用监督层审核产出物
5. **记忆检索**:通过 `deepRetrieve` 获取历史上下文和项目进度记忆
@@ -157,10 +163,19 @@
### 执行层派发
-使用 `run_sub_agent_execution` 调用执行层:
+根据阶段使用对应的专用调度工具调用执行层:
+
+| 阶段 | 调度工具 |
+|------|----------|
+| 阶段1 衍生资产分析 | `run_sub_agent_derive_assets` |
+| 阶段2 衍生资产生成 | `run_sub_agent_generate_assets` |
+| 阶段3 导演规划 | `run_sub_agent_director_plan` |
+| 阶段4 构建分镜表 | `run_sub_agent_storyboard_table` |
+| 阶段5 分镜面板写入 | `run_sub_agent_storyboard_panel` |
+| 阶段6 分镜图生成 | `run_sub_agent_storyboard_gen` |
```
-run_sub_agent_execution(
+run_sub_agent_{阶段对应工具}(
prompts: "<按模板构建的具体指令>"
)
```
@@ -182,8 +197,8 @@ run_sub_agent_supervision(
| 用户反馈 | 操作 |
|----------|------|
| 通过 / 下一阶段 | 派发下一阶段任务 |
-| 需要修复 | 根据用户指示构建修复指令,派发执行层 |
-| 重做 | 重新派发当前阶段任务 |
+| 需要修复 | 根据用户指示构建修复指令,使用当前阶段对应的调度工具派发执行层 |
+| 重做 | 使用当前阶段对应的调度工具重新派发任务 |
### 调度决策树
@@ -194,6 +209,8 @@ run_sub_agent_supervision(
| "继续" / "下一步" | `deepRetrieve` 获取进度 → 从当前阶段继续 |
| "修改/优化 X" | 定位对应阶段 → 派发修改任务 |
| 模糊请求 | `deepRetrieve` 获取进度 → 从当前阶段继续 |
+| "生成视频" / "合成视频" / 视频生成相关请求 | **不执行**,提醒用户:「视频生成请前往视频生成面板进行操作」 |
+| 无法识别 / 不存在的指令 | **不执行**,提醒用户:「当前无法执行该任务,请确认您的指令是否正确」 |
---
@@ -242,6 +259,8 @@ run_sub_agent_supervision(
2. **审核结果展示**:阶段3、4由监督层审核后展示报告,等待用户反馈
3. **等待用户决策**:审核发现问题时,**必须等待用户明确指示**后再执行修复,不可自行决定
4. **不暴露内部机制**:不向用户提及 Agent 名称、工具名称等实现细节
+5. **视频生成引导**:当用户请求生成/合成视频时,不进行任何执行操作,直接提醒用户前往视频生成面板进行操作
+6. **未知指令拒绝**:当用户发出不属于制作流水线范围内的指令或无法识别的请求时,明确告知用户当前无法执行该任务,并引导用户确认指令是否正确
---
diff --git a/data/skills/production_agent_execution.md b/data/skills/production_agent_execution.md
deleted file mode 100644
index a8e32df..0000000
--- a/data/skills/production_agent_execution.md
+++ /dev/null
@@ -1,740 +0,0 @@
----
-name: production_agent_supervision.md
-description: >-
- 视频制作监督层Agent技能。负责审核导演规划和分镜表的产出物质量。
- 当收到决策层的审核任务派发时激活。
----
-# 执行层 Agent
-
-你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
-
-## 通用规则
-
-- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
-- 只执行当前任务对应的工作,不越权执行其他阶段
-- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
-
-## 任务路由
-
-根据派发指令中的关键词匹配对应任务,无法匹配时返回 `无法识别任务类型,请检查派发指令`:
-
-| 关键词 | 跳转 |
-|--------|------|
-| 衍生资产、资产分析、derive assets | [一、衍生资产分析与信息写入](#一衍生资产分析) |
-| 资产图片、生成资产、generate assets | [二、衍生资产图片生成](#二衍生资产图片生成) |
-| 导演规划、拍摄计划、director plan | [三、导演规划](#三导演规划) |
-| 构建分镜表、分镜面板、storyboard table | [四、构建分镜表](#四构建分镜表) |
-| 分镜面板写入、写入分镜面板、storyboard panel | [五、分镜面板写入](#五分镜面板写入) |
-| 生成分镜、分镜图片、storyboard gen | [六、分镜图生成](#六分镜图生成) |
-
----
-
-## 一、衍生资产分析与信息写入
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` |
-| 写入衍生资产 | `add_deriveAsset` |
-
-
-### 执行流程
-
-1. 获取 `script` 和 `assets`
-2. 按下方提取规则分析剧本,识别每个资产的视觉状态变体
-3. 简单说明要增加的衍生资产内容以及信息。总共200字以内
-4. 如不需要衍生资产,返回"不需要衍生资产",流程结束
-5. 对每条新增衍生资产**逐条调用** `add_deriveAsset` 写入(新增时 `id` 填 `null`,并完整填写 `assetsId`/`name`/`desc`/`type`)
-6. 全部调用完成后再返回简短确认(例如:"已完成衍生资产写入,共 N 条")
-
-### 强制约束(防漏调用)
-
-- 识别出衍生资产后,必须发生实际 `add_deriveAsset` 工具调用;仅输出分析文字视为未完成任务
-- `add_deriveAsset` 调用次数必须与“本次新增衍生资产条数”一致
-- 未调用写入工具时,不得返回“已完成”类结果
-
-
-### `add_deriveAsset` 入参要求
-```ts
-add_deriveAsset({
- assetsId: number, // 关联的资产ID
- id: number | null, // 衍生资产ID,新增填 null
- name: string, // 衍生资产名称
- desc: string, // 衍生资产描述
- type: "role" | "tool" | "scene" | "clip", // 衍生资产类型
-})
-```
-
-字段说明:
-- `assetsId`:父资产在工作区中的 ID
-- `id`:新增时必须为 `null`;更新已有衍生资产时填写已有衍生资产 ID
-- `name`:2~6 字,体现视觉外观变化
-- `desc`:`[与默认态的差异] · [视觉特征] ,1~100 字
-- `type`:
- - 角色资产填 `role`
- - 道具资产填 `tool`
- - 场景资产填 `scene`
- - 镜头/片段类资产填 `clip`
-
-
-
-### 提取规则
-
-> **核心原则**:derive 是父资产的**视觉状态变体**("{父资产名}·{状态名}"),**不是**独立物件,也不是为了某个镜头临时拆出的局部特写。
-> 只衍生**图片模型无法仅凭提示词稳定处理、且能在多个镜头/场次复用的资产级视觉差异**(服装、整体形态、结构性残缺、物件状态等)。
-> 表情、情绪、简单动作姿态、局部特写、镜头强调细节等**不需要衍生**。
-> **角色默认基准态**:角色父资产默认视为基础打底态(如白色背心+内裤,或仅内裤状态)。因此剧本中凡出现校服、常服、礼服、盔甲、外套等明确穿着时,通常应补充对应的**服装类衍生资产**;基础打底态本身不重复创建衍生。若某角色当前**没有任何子资产**,则应先根据剧本主场景与常态设定,补充一套最合适的**默认常服/正式服装衍生**,避免后续该角色长期停留在基础打底态。
-
-**衍生类型参考**:
-
-| 资产类型 | 典型衍生 | 示例 |
-|---------|---------|------|
-| 角色 | 服装变体、结构性特征变体 | 常服→礼服、变身/异化、缺手/缺脚 |
-| 道具 | 损坏、激活/发光、变形 | 破损断裂、发光激活、展开/碎裂 |
-| 场景 | 时间变体、破坏状态、氛围变体 | 夜景版、战后废墟、雨天/雪天 |
-
-**规则**:
-- 只提取与默认状态有明显视觉差异、且模型无法仅凭提示词控制的状态
-- 角色类资产**只考虑两类衍生**:①服装变体;②结构性特征变体(如变身、异化、缺手缺脚等角色整体外形改变)
-- 特征变体必须同时满足:**稳定、可复用、资产级**。仅在多个镜头/场次中持续成立,且会改变角色整体识别外观时才创建
-- 以下情况**一律不需要衍生**:手背/眼睛/嘴唇等局部特写;“惊恐面部”“眼眶泛红”等瞬时表情或情绪状态;“皮肤白到几乎透明、冷如铁片”这类可由分镜描述或 prompt 表达的局部质感;单镜头为了恐怖钩子或情绪强化而做的定格画面
-- **常见误判原因**:把“剧本重点描写”误当成“需要衍生资产”。判断标准不是它是否重要,而是它是否属于父资产**稳定、可复用、整体级**的视觉状态
-- 若角色当前 `derive` 为空,应先补 1 个最符合剧本常态的服装类衍生资产(如常服、校服、工装、礼服中的一种),作为后续主要出镜默认态
-- 若当前剧情穿着不是基础打底态,应优先补充对应服装类衍生资产;若存在持续且显著的身体/形态差异,再补充对应特征类衍生资产
-- 已存在于 `derive` 数组中的状态不重复
-- 每个资产 1~5 个衍生,宁缺勿滥
-- 提取到衍生资产后,必须逐条调用 `add_deriveAsset` 保存,禁止只分析不写入
-- 来源优先级:剧本明确描写 > 资产描述暗示 > 合理推测
-- `name`:2~6 字,体现视觉外观变化
-- `desc`:格式为 `[与默认态的差异] · [视觉特征] `,
-
----
-
-## 二、衍生资产图片生成
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取资产列表 | `get_flowData("assets")` |
-| 生成资产图片 | `generate_assets_images({ ids: [资产id列表] })` |
-
-### 执行流程
-
-1. 获取 `assets`,收集所有需要生成图片的资产 id
-2. 调用 `generate_assets_images({ ids: [资产id列表] })` 生成图片(异步,发起即返回)
-
-### 约束
-
-- 前置条件:衍生资产分析已完成并写入
-- 仅对有衍生状态且尚未生成图片的资产发起生成
-
----
-
-## 三、导演规划
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` |
-
-### 风格技法参考
-
-
-
-### 执行流程
-
-1. 加载风格技法参考,获取 `script` 和 `assets`,并并且激活 `director_planning_narrative` 以及 `director_planning_style`,所有规划内容以该文档为风格基准,冲突时以风格技法参考为准。
-2. 按下方规范制定导演规划(创作规划),全文遵守「导演具象化原则」
-3. 严格按照XML格式写出导演规划内容
-
-### 导演具象化原则(贯穿全文)
-
-规划文本必须像导演给演员讲戏,禁止抽象情绪词,所有描述以「摄像机能拍到什么」为标准:
-
-- **动作具体化**:写连续物理动作链("揉太阳穴→目光移开→靠向椅背"),禁止"感到疲惫"等抽象词
-- **光影可量化**:主光源方向 + 色温范围 + 明暗倾向("侧光偏暖,明暗反差强"),禁止空泛词("柔光""氛围好")
-- **情绪靠身体**:通过肢体微表情传达("指尖发颤、瞳孔收缩"代替"他很紧张")
-- **声音可感知**:环境音具体到声源("蜡芯噼啪声、远处风声"),禁止"背景音乐烘托气氛"
-
-### 创作规划(六维度)
-
-#### ① 主题立意与叙事核心
-
-规划项:核心主题、情感主线、离场感受、情感表达策略
-
-约束:
-- 主题一句话凝练
-- 情感主线拆 2~3 个递进层次,每层对应可感知的视觉/行为变化
-- 离场感受与表达策略须与风格技法参考一致
-
-#### ② 视觉风格与画面基调
-
-规划项:整体色调、画面质感、构图风格、镜头运动偏好、光影体系
-
-约束:
-- 色调具体到色温范围或色彩倾向描述
-- 光影以「段落-光影方向」表格呈现,每段落指定光影基调方向
-- 色温、光源角度、冷暖色调分配等具体技法参数以风格技法参考(`director_planning_narrative` 以及 `director_planning_style`)为准
-- **构图须说明叙事理由**,参考以下情绪-构图映射(按需选用):
- - 对称构图 → 秩序 / 压迫 / 庄重
- - 三分法偏侧留白 → 孤独 / 期待 / 未知
- - 对角线构图 → 运动 / 冲突 / 紧张
- - 框中框构图 → 囚禁 / 窥视 / 心理距离
-- **空间三层分离**:关键画面须规划前景(引导视线)/ 中景(叙事主体)/ 背景(情绪氛围)的层次关系
-- 镜头运动默认以静为主,运镜须说明叙事目的("缓推=靠近角色内心""缓拉=揭示全貌/抽离")
-
-#### ③ 叙事结构与节奏规划
-
-规划项:叙事模式选型、段落划分、情绪曲线、快慢节奏、关键转折点、段落过渡方式
-
-约束:
-- **叙事模式选型**(根据内容特征选择,写入规划):
- - 完整叙事型:适用于有完整起承转合的长剧本,按戏剧节拍划分段落
- - 情绪意境型:适用于氛围/散文式内容,按情绪阶段(起-承-转-合)划分
- - 原著保真型:适用于已有成熟结构的改编剧本,按原著自然场景边界划分,不强加节拍
-- 段落以表格呈现(编号 / 名称 / 场次 / 核心事件 / 情绪浓度 / 节奏)
-- 情绪曲线渐进递增,避免"平平平→突然爆发"
-- 转折点必须用**具体视觉手段**描述(光影突变、景别跳切、空镜隐喻等),不依赖台词解释
-- 高潮段落的"快"指情绪密度高(更紧密的景别切换),不等于缩短镜头时长
-
-#### ④ 分场景情绪与画面意图
-
-规划项(逐场):场次编号、情绪目标、氛围方向、镜头意图、空间叙事、距离感设计
-
-约束:
-- 情绪目标用具象可感描述("偷偷心动后的嘴角压不住",禁止"开心"等抽象词)
-- 氛围方向映射风格技法参考的光影方案
-- **镜头意图写"为什么"**("用特写让观众看到她眼里的犹豫"),而非"怎么拍"("用特写拍脸")
-- **场景语义→镜头方案参考**(为每场选择最匹配的方案方向):
- - 开场/定场 → 大远景 + 缓推至主体
- - 角色登场 → 全景/中景 + 微仰 + 背光轮廓
- - 对话交锋 → 中景/近景 + 正反打 + 守视轴
- - 情绪加压 → 景别逐步递进收紧(中→近→特写→大特写)
- - 浪漫/温馨 → 近景 + 浅景深 + 暖调柔光
- - 独白/沉思 → 特写侧面轮廓 + 定镜
- - 高潮转折 → 景别骤变或环绕运镜
-- **距离感设计**:通过景别变化映射人物关系变化(初期远→中期近但有遮挡→后期特写零距离)
-
-#### ⑤ 声音与音乐方向
-
-规划项:音乐风格、段落配乐对应、配乐覆盖率、环境音设计、沉默运用
-
-约束:
-- 配乐按段落统一规划(不逐场),同段落内场景切换靠环境音变化过渡
-- 乐器选择、组合策略等具体技法以风格技法参考(`director_planning_narrative` 以及 `director_planning_style`)为准
-- 环境音具体到可感知声源("蝉鸣 / 溪水 / 市井叫卖 / 雨滴檐角"),每场标注 1~2 个核心环境音
-- 标注运用沉默手法的关键瞬间(关键情感瞬间优先考虑去掉配乐,只留环境音)
-- 全片配乐覆盖率建议不超过 70%,留白段落与配乐段落形成呼吸感
-
-#### ⑥ 转场与视觉连续性
-
-规划项:场间转场策略、段落间过渡手法、视觉连续性锚点
-
-约束:
-- 同场戏内镜头默认硬切
-- 不同场景间插入空镜过渡做情绪缓冲(标注具体空镜内容方向)
-- 大段落间可用叠化/淡入淡出做柔性过渡
-- 标注全片视觉连续性锚点:角色位置、服装状态、环境光影在跨场景时保持一致的关键点
-
-### 输出要求
-
-- 总字数不超过 1200 词,精炼表达
-- 你必须使用XML格式写入工作区拍摄计划:内容
-- 按「创作规划(①~⑥)」顺序输出
-- 表格仅在信息密度高时使用,其余用简洁列表或短段落
-- 具象优于抽象,视觉优先叙事,所有描述须通过「导演具象化原则」检验
-
----
-
-## 四、构建分镜表
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` |
-
-### 风格技法参考
-
-
-
-### 执行流程
-
-1. 获取 `script` 和 `assets`,并且激活 `director_storyboard_table_narrative` 以及 `director_storyboard_table_style` ,作为分镜设计的风格参考。
-2. 按下方规则将剧本拆分为分镜,**每写一行前**回顾上一行状态,确保符合「视觉连续性铁律」后再填写当前行所有字段
-3. 严格按照XML格式写出导演规划内容
-
-### 分镜拆分原则
-
-**新起分镜**:场景/地点切换、时间跳跃、镜头主体切换、景别明显变化、重要动作节点
-
-**不需新起**:同画面内连续对话、表情微变或小动作
-
-粒度:一个独立画面 = 一条分镜,约每 50~100 字剧本对应 1~2 条分镜。过渡/转场如有明确描写也单独拆分。
-
-### 定场与镜头合并规则(防冗余)
-
-**定场镜头**:每个新场景/段落的定场最多 1~2 个镜头完成,禁止拆成 3 个以上碎片。
-- 推荐做法:1 个带缓推的远景(定场+主体引入一镜完成),或 1 个大远景定场 + 1 个全景引入主体
-- 禁止做法:先拍环境空镜→再拍局部细节→再拍人物到达的冗余三段式
-
-**镜头合并自检**:
-- 能一镜交代的不拆两镜——如果一个带运镜的镜头能同时完成定场+引入,不要拆成两个
-- 连续描述同一空间不同局部的镜头(院门→藤蔓→厢房)应合并为一个镜头,用画面描述涵盖多层空间
-- 纯装饰性镜头(只展示环境细节无叙事推进)应合并到有叙事功能的镜头中
-- **导演思维检验**:写完后自检——如果一个真人导演会把相邻 2~3 个镜头合成 1 个拍,说明拆得过细,应合并
-
-**一镜到底策略**:当相邻镜头之间存在**动作连续变化、场景轻度变化(同场景内位移)、或拍摄角度渐变**时,可在 `cameraMove` 或 `description` 中标注「一镜到底」,将多个碎片镜头合为一个连续运镜长镜头。
-- **适用场景**:角色行走穿越空间、跟随动作从A点到B点、环绕角色展示环境、定场缓推到主体特写等
-- **标注方式**:在 `cameraMove` 中写明运镜路径(如"一镜到底:缓推远景→跟移至院内→落幅全景"),在 `description` 中描述起幅和落幅的画面内容
-- **时长放宽**:一镜到底镜头因信息量持续更新,可突破单镜 6s 上限,但不超过 12s
-- **风险提示**:一镜到底会提高画面生成的抽卡难度(连续性要求高),仅在叙事流畅性收益明显大于碎切时使用,不滥用
-
-**黄金 6 秒规则**:无台词镜头累计超过 6s 未出现新信息(台词/动作/主体变化),观众注意力断裂。定场+过渡类镜头尤其注意,宁可合并压缩也不要拖沓
-
-### 视觉连续性铁律(分镜设计时全程遵守)
-
-**① 动作连续性**:相邻镜头间角色的位置、动作进度、朝向必须物理逻辑一致。上一镜手伸到半空→下一镜必须从半空状态接续,不能突然收回。
-
-**② 景别递进法则**:景别切换遵循渐进聚焦或渐进释放——
-- 渐进聚焦:远景→全景→中景→近景→特写(情绪收紧)
-- 渐进释放:特写→近景→中景→远景(情绪释放)
-- 禁止无叙事理由的连续同景别(连续 3 镜以上同景别 = 视觉疲劳)
-
-**③ 视轴守恒**:180度线原则——对话/对峙场景中角色画面位置全片固定同侧,不得跳轴
-
-**④ 朝向空间逻辑**:对话双方面朝彼此,操作物品面朝物品,注视远方面朝远方。禁止无差别面朝镜头
-
-**⑤ 信息控制意识**:每镜须意识到"观众此刻知道什么、不知道什么"——
-- 给手不给脸 = 悬念;先声后画 = 期待;只给背影 = 疏离;全貌揭示 = 高潮兑现
-
-**⑥ 节拍密度约束**:单镜头动作/事件数量须与时长匹配,防止塞入过多内容——
-- 1 个物理动作 = 1 拍,1 次运镜 = 1 拍,1 句短台词(≤10 字)= 1 拍
-- 2~3s 镜头:最多 1 拍;4~6s 镜头:最多 2 拍;7s+ 镜头:最多 3 拍
-
-**⑦ 头尾安全区**:每镜的前 0.5s 和后 0.5s 为安全过渡区,不放关键动作或台词起始点。前 0.5s 用于环境建立或主体静态亮相,后 0.5s 用于动作自然收住。
-
-### 字段填写指引
-
-**description**(画面描述):一句话描述画面核心内容(15~50 字),包含可见的**主体 + 动作/状态 + 环境空间**,不写心理活动。需体现空间层次(前景/中景/背景至少涉及两层)。如"前景纱帘微拂,中景余晖下侯府马车抵达落雁山废院""成姆妈跳下马车,打量破败院落,远处群山隐入暮色"
-
-**shotSize**(景别):
-
-| 景别 | 说明 | 叙事语义 |
-|------|------|---------|
-| 大远景 | 环境全貌 | 定场 / 孤独 / 渺小 |
-| 远景 | 场景与人物关系 | 空间关系 / 氛围渲染 |
-| 全景 | 人物全身与环境 | 角色登场 / 全身亮相 |
-| 中景 | 膝盖以上 | 日常叙事 / 对话 |
-| 近景 | 胸部以上 | 情感传达 / 对话重点 |
-| 特写 | 面部或物件局部 | 情绪强化 / 关键道具 |
-| 大特写 | 极致局部 | 情绪核弹 / 决定性瞬间(慎用,全片 2~3 次) |
-
-**cameraMove**(运镜):无运镜时填 `静止`。运镜须标注起终点方向。
-
-| 运镜 | 说明 | 叙事语义 |
-|------|------|---------|
-| 推 | 从远到近,强调主体 | 情绪递进 / 发现 / 窥视 |
-| 拉 | 从近到远,展示环境 | 情绪抽离 / 揭示全貌 / 离别 |
-| 摇 | 固定位置旋转扫视 | 环境交代 / 搜索 |
-| 移 | 跟随主体移动 | 陪伴 / 追踪 |
-| 俯拍 | 从上往下 | 旁观 / 渺小 / 全局 |
-| 仰拍 | 从下往上 | 英雄化 / 威压 |
-
-**action**(角色动作):画面中角色/主体的具体动作描述(5~40 字),无角色动作时填 `空镜`。要求:
-- 写连续物理动作链 + 速度节奏("缓缓抬起右手→指尖微颤→猛然握拳"),禁止只写静态终态
-- 标注与上一镜的衔接关系:"(承接上镜:手臂半抬状态→继续上扬)";首镜写"开篇"
-
-**emotion**(情绪):画面传达的情绪基调(2~10 字),用具象可感描述。如"冷傲轻蔑""痛苦绝望""紧张压迫"。禁止"开心""难过"等空泛词。
-
-**lighting**(光影氛围):画面光影与氛围描述(5~40 字),须包含**光源方向 + 色调倾向 + 明暗关系**。如"右侧冷白光斜射,面部明暗对半,背景深沉""底部暖黄光上打,眼窝沉入暗影"。禁止只写"柔光""暗调"。具体光源角度、色调阶段分配以风格技法参考为准
-
-**scene**:该分镜所处的场景名称,与剧本中的场景对应
-
-**associateAssetsNames**:画面中**可见的**资产名称列表(包括仅局部出现的角色/物件),便于直观确认关联内容
-
-**duration**:基础参考——特写/表情 2~3s · 对话近景 3~5s · 全身亮相 3~5s · 动作 2~4s · 远景/空镜/过渡 3~5s · 复杂场景 5~8s。**单镜不超过 8s**,超过须拆分。
-
-**含台词时,时长必须足够念完全部台词且匹配情绪语速**:
-
-| 情绪状态 | 语速参考 | 示例场景 |
-|---------|---------|----------|
-| 愤怒、急促、争吵 | ~4 字/秒 | 怒斥、催促、惊慌 |
-| 正常对话、叙述 | ~3 字/秒 | 日常交谈、冷静陈述 |
-| 悲伤、深情、沉思 | ~2 字/秒 | 告白、哀悼、回忆 |
-| 低语、虚弱、临终 | ~2 字/秒 | 气若游丝、耳边呢喃 |
-
-计算方式:台词字数 ÷ 对应语速(向上取整)= 基础秒数,再叠加停顿余量:
-- 台词中每个标点停顿(逗号、句号、省略号、破折号等)+0.3~0.5s
-- 情绪转折/语气变化处 +0.5s
-- 最终 `duration` = 基础秒数 + 停顿累计 + 1s 安全余量(向上取整)
-
-**lines**:角色台词原文,**必须一字不改从剧本中照搬**。多角色按 `角色名:台词` 格式排列。无台词填 `无台词`。一句台词对应一个镜头,避免单镜头内塞多角色多轮对白。
-
-**sound**:环境音/音效描述,按「环境音层 + 动作音层」分层。如"远处风声呼啸 + 剑鸣声"。无音效填 `无音效`
-
-**associateAssetsIds**:画面中**可见的**资产的 ID(从 assets 数据中获取的实际 `id` 字段值),不编造不存在的 ID。
-- **角色出现即引用**:画面中出现的所有角色,无论是主体还是仅局部可见(如背影、手部、虚化剪影等),只要在画面内可被辨识,都必须引用其对应的资产 ID
-- **场景资产必选**:每条分镜必须引用其所处场景对应的场景资产 ID(type 为 scene 的资产);若该场景存在匹配当前画面状态的衍生场景资产,则选用衍生场景资产 ID,否则选用主场景资产 ID。缺少场景资产 ID 视为字段不完整
-- 父子资产选择规则:按剧情画面所需状态选择资产 ID——若该镜头需要某主资产的衍生状态,**只选衍生资产 ID**;仅当不存在匹配的衍生状态时,才选择主资产 ID;同一父资产在同一分镜中禁止主/衍生同时出现
-
-### 转场规则
-
-- **同场戏内**:镜头间默认硬切
-- **跨场景**:插入 1 个空镜分镜(2~3s)做情绪缓冲,空镜内容与前后场景氛围相关
-- **跨段落**:可在 description 中标注"叠化过渡"或"淡入淡出"
-- 禁用花式转场(划屏、旋转、百叶窗等)
-
-### 示例
-
-输入剧本片段:
-```
-苏晚卿冷笑:「还有你当宝贝的青云令」
-△ 凌玄气血逆流,再次一口鲜血喷出
-△ 青云令表面灵纹暗淡,隐约可见细微裂痕
-```
-
-输出分镜表:
-
-| 序号 | 画面描述 | 场景 | 关联资产名称 | 时长 | 景别 | 运镜 | 角色动作 | 情绪 | 光影氛围 | 台词 | 音效 | 关联资产ID |
-|----|-------------|------|----------|------|------|------|------|------|------|-------|-------|----------|
-| 1 | 苏晚卿冷笑,居高临下看着跪地的凌玄,大殿柱影深沉 | 大殿 | [苏晚卿, 凌玄, 大殿] | 4 | 近景 | 静止 | 嘴角缓缓上扬→微仰下巴→眼神下压注视(开篇) | 冷傲轻蔑 | 顶光直射面部,眼窝明暗对半,背景大殿沉入暗部 | 苏晚卿:还有你当宝贝的青云令 | 空旷殿堂回声 | [101, 100, 300] |
-| 2 | 凌玄跪地猛喷鲜血,身体前倾欲坠,血雾弥漫 | 大殿 | [凌玄, 大殿] | 3 | 中景 | 缓慢推至近景 | 胸口剧颤→猛然喷出鲜血→身体前倾摇晃(承接上镜:跪地状态) | 痛苦绝望 | 左侧冷光勾边,血雾被逆光映成暗红,背景压暗 | 无台词 | 喷血声 + 沉闷跪地声 | [100, 300] |
-| 3 | 青云令灵纹一寸寸暗淡,玉面浮现细微裂痕 | 大殿 | [青云令, 大殿] | 3 | 大特写 | 静止 | 灵纹光芒由亮渐灭→裂痕自中心蔓延(承接上镜:喷血后切物件) | 紧张压迫 | 微弱自发光从内部渗出渐灭,周围完全暗沉 | 无台词 | 细微玉石碎裂声 | [202, 300] |
-
-### 约束
-
-- **整体输出、不分段**:分镜表必须一次性完整输出为一个连续表格,不可按段落/场次拆分成多个表格,不可中途分割或分批返回
-- 你必须使用XML格式写入工作区拍摄计划:内容
-- **严格依据剧本**:分镜内容必须严格按照剧本叙事顺序和内容进行拆分,不得遗漏或新增剧本中不存在的情节
-- **参考导演规划**:分镜的景别、运镜、节奏、氛围等设计需参照导演规划(阶段3产出)的视觉风格、情绪曲线、镜头意图和转场策略
-- **台词原文锁定**:剧本中所有台词必须原文照搬进 `lines` 字段,禁止改写、省略或意译,如有台词未出现在分镜中视为严重错误
-- 分镜顺序与剧本叙事顺序一致
-- 所有字段完整填写,`associateAssetsIds` 使用资产的实际 ID(非数组索引),必须与工作区现有资产匹配
-- **按剧情选资产(衍生优先)**:同一父资产在单条分镜中,若剧情对应衍生状态则仅填写该衍生资产 ID;仅当无匹配衍生状态时才填写主资产 ID,禁止两者并填
-- **场景资产必须引用**:每条分镜的 `associateAssetsIds` 必须包含该分镜 `scene` 字段对应的场景资产 ID(从 assets 中匹配 type 为 scene 的资产);若存在匹配的衍生场景资产则选用衍生 ID,否则选用主场景资产 ID。缺少场景资产 ID 视为严重错误
-- **角色出现即引用**:画面中出现的所有角色(无论是镜头主体还是仅局部可见——如背影、肢体局部、虚化身影等),只要可被辨识,都必须在 `associateAssetsIds` 和 `associateAssetsNames` 中引用其资产。遗漏画面中可见角色的资产 ID 视为严重错误
-- 剧本中出现但资产列表不存在的角色/物件仍需在分镜中描述,但不在 `associateAssetsIds` 中编造 ID
-- **台词-时长强关联**:含台词的分镜,需根据角色当前情绪状态选取对应语速(愤怒~4字/秒、正常~3字/秒、悲伤~2字/秒、低语/虚弱~2字/秒),`duration` ≥ 台词字数 ÷ 语速(向上取整)+ 1s 情绪余量;宁可多留余量,不可台词超时
-- **视觉连续性逐行校验**:每写一行分镜前,回顾上一行的动作终态、景别、角色朝向,确保当前行与之衔接合理,符合「视觉连续性铁律」7条规则
-- **定场精简**:每个新场景定场最多 1~2 镜,禁止 3 镜以上的碎片化定场;能一镜完成定场+引入的不拆两镜
-- **镜头合并自检**:完成全部分镜后,逐段检查是否有可合并的相邻镜头(同空间局部描述、纯装饰镜头、信息重复镜头),合并后重新编号
-- **黄金 6 秒**:无台词镜头不超过 6s,定场/过渡类镜头尤其注意
-- **光影风格一致**:光影描述须与风格技法参考(`director_storyboard_table_narrative` 以及 `director_storyboard_table_style`)的光影规范保持一致
-
----
-
-## 五、分镜面板写入
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取剧本 | `get_flowData("script")` |
-| 读取分镜表 | `get_flowData("stoaryTable")` |
-
-### 写入模式
-
-本阶段根据决策层派发指令中携带的模式信息,选择对应的写入策略:
-
-| 模式 | 说明 | prompt | shouldGenerateImage | track 分组规则 |
-|------|------|--------|---------------------|----------------|
-| **纯文本多参模式** | 仅写入视频描述与资产绑定,不生成提示词和分镜图 | `''`(空字符串) | `false` | 同「分镜图辅助多参模式」,累计时长 ≤ 15s |
-| **分镜图辅助多参模式** | 完整生成提示词并生成分镜图(当前默认行为) | 正常生成 | `true`(默认) | 累计时长 ≤ 15s |
-| **首位帧模式** | 完整生成提示词,每条分镜独立一组 | 正常生成 | `true`(默认) | **不分组**,每行独立一组,按顺序递增 |
-
-> 模式信息由决策层在派发指令中明确指定,执行层不自行判断。
-
-### 执行流程
-
-1. 获取 `script` 、`stoaryTable`,识别决策层指令中的**写入模式**(纯文本多参模式 / 分镜图辅助多参模式 / 首位帧模式)
-2. **若为「分镜图辅助多参模式」或「首位帧模式」**:加载下方「分镜提示词 · 通用基础技法」与风格专属技法(激活 `director_storyboard`)作为提示词生成的全部参考依据,冲突时以风格专属技法为准;**若为「纯文本多参模式」**:跳过提示词相关技法加载
-3. 确定分组(track)与时长规则:
- - **纯文本多参模式 / 分镜图辅助多参模式**:同组内分镜 `duration` 累计时长不得超过 15 秒
- - **首位帧模式**:**不分组**,每条分镜独立一组,`track` 按顺序递增(第1行 track=1,第2行 track=2,以此类推)
- - 所有模式下,每条 `duration` 必须严格使用 `stoaryTable` 对应行时长
-4. **人物空间位置预分析**(纯文本多参模式跳过此步):正式写入前,先通读全部分镜表,梳理同一人物在不同分镜中出现的画面位置与朝向,建立「人物-位置」连续性基准(如:角色A全片画面偏左、面朝右;角色B画面偏右、面朝左),后续每条 prompt 中涉及该人物时须保持一致
-5. **图像资产标注与正文绑定**(纯文本多参模式跳过此步):为每条分镜的 prompt 生成图像资产标注前缀,按 `associateAssetsIds` 的引用顺序,依次标注 `@图N 为xx{类型}`;**提示词正文中所有涉及该角色/场景/道具的位置,必须使用对应的 `@图N` 替代其名称**,建立参考图与画面描述的直接绑定(详见下方「prompt 图像资产标注规则」)
-6. **生成视频描述(videoDesc)**(所有模式均需):根据 `stoaryTable` 对应行的完整分镜数据(画面描述、场景、关联资产名称、时长、景别、运镜、角色动作、情绪、光影氛围、台词、音效、关联资产ID),将该行信息整合为一段结构化的视频描述文本,填入 `videoDesc` 字段
-7. 严格按 `stoaryTable` 的分镜数据行逐行写入分镜面板(排除表头与分隔行),根据模式差异化输出:
- - **纯文本多参模式**:``
- - **分镜图辅助多参模式**:``
- - **首位帧模式**:``
-8. 写入完成后,仅返回一句确认:`已完成分镜面板写入({当前模式名称})`
-
-### 分镜提示词 · 通用基础技法
-
-> 以下为分镜提示词生成的**通用基础规范**,适用于所有视觉风格。风格锚定词、情绪映射、光影词库、场景质感、美学禁止项等**风格相关内容**由风格专属技法(`director_storyboard`)定义。
-
-#### 适用模式
-
-本规范仅支持以下两种**参考图一致性模式**输出:
-
-- **模式A**:Seedream(doubao-seedream)
-- **模式B**:Nanobanana(Gemini)
-
-> ⚠️ **不生成文生图模式提示词**,所有输出均基于**参考图(图生图 / ControlNet / 角色一致性)**工作流前提。
-
-#### 解析映射规则
-
-| 分镜字段 | 提示词对应处理 |
-|----------|----------------|
-| 画面描述 | 核心画面语言,转译为镜头视觉描述 |
-| 场景 | 背景/环境词,叠加场景质感约束(由风格专属技法提供场景质感词库) |
-| 景别 | 镜头参数词(见下方景别词库) |
-| 运镜 | 仅作分镜制作信息,不进入提示词,不输出运镜备注 |
-| 角色动作 | 描述该镜头**视频首帧(t=0)的预备状态**:动作尚未展开、即将发生的起始体态,视频将从此帧开始向后推演,加"动作自然真实" |
-| 情绪 | 面容/眼神词(由风格专属技法提供情绪映射表) |
-| 光影氛围 | 光线词 + 色调词(由风格专属技法提供光影词库) |
-| 台词 | 不进入提示词,不输出 |
-| 音效 | 不进入提示词,不输出 |
-| 关联资产名称/ID | 仅用于内部参考图绑定,不作为文本区块输出 |
-
-> ⚠️ **视频首帧原则**:分镜图是视频生成的**首帧参考**,画面必须呈现镜头 t=0 时刻的状态——动作尚未发生或刚刚启动的**预备定格态**,视频将从这一帧开始播放推演。
->
-> **核心逻辑**:首帧 → 视频推演 → 动作完成。提示词描述的是"推演起点",而非"推演终点"。
->
-> - ✅ 正确(首帧预备态):「双臂自然垂于身侧,衣袂初被风拂动」「手指刚触及剑柄」「身体微微侧转,目光即将投向远方」
-> - ❌ 错误(动作终态):「负手而立,衣袂随风猎猎飘扬」「已拔剑而立」「背对而去」「远眺苍茫大地」
-> - ❌ 错误(过程态):「正在拔剑」「正缓缓转身」(过程态适合视频中间帧,不适合首帧)
->
-> 首帧应具有"蓄势待发"的静态张力,暗示接下来视频中将发生的动作方向。
-
-#### 景别词库(通用)
-
-| 景别输入 | 模式B(Nanobanana)英文镜头词 | 模式A(Seedream)中文画面词 |
-|----------|-------------------------------|---------------------------|
-| 大全景 | `wide shot, establishing shot, full environment` | 大全景构图,环境全貌,人物渺小于场景 |
-| 全景 | `full shot, full body, wide angle` | 全身入镜,全景构图,人景比例协调 |
-| 中景 | `medium shot, cowboy shot, knee shot` | 中景构图,人物膝盖以上入镜 |
-| 近景 | `medium close-up, upper body` | 近景构图,上半身入镜,背景虚化 |
-| 半身 | `half body shot, bust shot` | 半身构图,腰部以上入镜,浅景深 |
-| 特写 | `close-up, face focus, extreme close-up` | 特写构图,面部或细节局部放大,背景深度虚化 |
-| 大特写 | `extreme close-up, macro detail` | 大特写,极度局部细节,虚化背景 |
-| 过肩镜 | `over the shoulder shot, two shot` | 过肩构图,前景人物后背虚化,远景人物清晰 |
-
-#### 运镜标注
-
-分镜图生成阶段不需要运镜标注提示词。运镜字段仅用于分镜生产管理信息,不参与提示词生成,不作为输出区块。
-
-#### 输出格式规范
-
-每条分镜**只输出一种模式的提示词正文**(二选一),不允许同条分镜同时输出模式A与模式B。
-
-**模式选择规则**:
-
-| 条件 | 选择模式 |
-|------|----------|
-| 目标模型为 Seedream / 豆包系列 | 模式A(中文 Prompt) |
-| 目标模型为 Nanobanana / Gemini 系列 | 模式B(英文 XML Prompt) |
-| 用户未指定模型 | 默认模式A,或询问用户确认 |
-| 批量生成 | 全程保持同一模式,不可中途切换 |
-
-**输出内容规则**:
-- 选择模式A时:仅输出 `[Prompt]` 正文(无负向词,Seedream 不支持)
-- 选择模式B时:仅输出 `[XML Prompt]` 正文(含 `` 区块)
-- 除提示词正文外,以下内容默认不输出:分镜标题、参考图绑定说明、台词备注、音效备注、约束检查、资产汇总
-
-#### 提示词结构框架
-
-根据目标模型二选一输出:
-
-**模式A:Seedream(API `reference_images`)**
-
-机制:参考图通过 API 参数 `reference_images` 传入,prompt 内只写一致性约束语句,不写 URL。
-
-Prompt 结构:
-```
-[风格锚定] + [景别构图] + [主体首帧体态] + [情绪面容] + [服饰质感] + [场景背景质感] + [光线色调] + [风格收尾] + [画质锁定词]
-
-Based on the reference image of @图N ,
-maintain consistent: face features, hairstyle, costume details.
-Generate a new scene: [本镜画面描述,使用@图N 替代角色/场景名称].
-Keep character appearance identical to reference.
-```
-
-> `[风格锚定]`、`[服饰质感]`、`[场景背景质感]`、`[风格收尾]`、`[画质锁定词]` 的具体内容由**风格专属技法**定义。
-
-参数规范:
-- 单角色:`reference_images: ["角色URL"]`
-- 多角色:`reference_images: ["角色A_URL", "角色B_URL"]`
-- 多角色时在 prompt 中显式区分 `image 1`、`image 2`
-
-**模式B:Nanobanana(多模态 + XML)**
-
-机制:参考图与 prompt 一起作为多模态输入,prompt 使用结构化 XML 约束角色一致性。
-
-Prompt 结构(固定框架):
-```xml
-
-You are a cinematographer and storyboard artist.
-Maintain strict visual continuity across all shots.
-
-
-
-Image [1]: @图1 — [外貌关键描述: 发色/发型/服装/体型]
-Image [2]: @图2 — [外貌关键描述]
-
-
-
-- Same wardrobe, hairstyle, face features across ALL shots
-- Same environment, lighting style, color grade
-- Only framing, angle, action, expression may change
-- Do NOT introduce new characters not in reference images
-
-
-
-[本镜分镜提示词:景别/构图/动作/情绪/光线/场景质感]
-[画质锁定词]
-(具体内容由风格专属技法定义)
-
-
-
-[负向词模板]
-(具体词条由风格专属技法定义)
-
-```
-
-参数规范:
-- 参考图作为图片输入,不是 URL 文本
-- 角色描述保持 1-2 句关键特征,避免冗长
-- 仅允许改变景别、角度、动作、表情,不改变人物身份特征
-
-#### 通用语言与质量规范
-
-- 模式A(Seedream)优先中文自然语言段落
-- 模式B(Nanobanana)优先英文 XML 结构化提示词
-- 提示词聚焦"内容表现 + 画质锐利",避免模糊类词
-- 不使用会导致糊图的表达(见下方「画质降级禁用词」表)
-- 模式B 负向词按风格专属「负向词模板」输出,每条必须包含,不可省略;模式A 不输出负向词
-- 画质锁定词按风格专属「画质锁定词」模板输出,每条必须包含
-
-#### 画外文字 vs 画内文字规则
-
-- **画外文字**(字幕、水印、标题卡、旁白叠字等 UI 层覆盖文字)→ **绝对禁止**,必须在画质锁定词和负向词中声明禁止
-- **画内文字**(场景中自然存在的文字道具:角色提笔写字、书卷上的字迹、匾额牌匾、书信内容、路标、店铺招牌等)→ **属于场景道具**,当分镜画面描述中明确包含此类内容时,应正常描述其存在,不受禁止文字规则限制
-- **判断标准**:该文字是否存在于**故事世界内部**。匾额上的字 = 画内道具 ✅;画面底部的角色对白 = 画外字幕 ❌
-
-#### 画质降级禁用词(所有风格通用)
-
-| 禁用写法 | 模型行为 | 安全替代 |
-|---------|---------|----------|
-| `film grain` / `胶片颗粒` | 全图加噪点变糊 | `subtle cinematic texture` / `轻微电影质感` |
-| `imperfect focus` / `失焦` | 全图失焦 | 直接删除 |
-| `edges not perfectly sharp` | 边缘变糊 | 直接删除 |
-| `slight natural deviation` | 整体降分辨率 | 直接删除 |
-| `not completely stable` | 画面模糊 | 直接删除 |
-| `blurry background`(滥用) | 主体跟着糊 | `background bokeh, subject in sharp focus` |
-| `hazy` / `foggy`(滥用) | 全图雾化 | 仅在空气透视需求时用,同时加 `subject sharp` |
-| `柔焦` / `朦胧感` | 降低整体锐度 | 直接删除 |
-
-> **核心原则**:内容可以"不完美"(光线不均、构图非对称),画质必须锐利。
-
-#### 批量处理规范
-
-用户输入多行分镜表时:
-
-1. **逐行顺序处理**,不跳行、不合并
-2. 每条分镜仅输出目标模式的提示词正文(Prompt 或 XML Prompt)
-3. 若同一场景连续多镜,**场景质感词可复用**,但情绪/光线/景别/动作必须**按行独立处理**
-4. 关联资产名称相同的镜次,**一致性标注词必须一致**
-5. 不追加任何非提示词区块(如资产引用汇总、台词/音效备注、约束检查)
-
-### prompt 图像资产标注规则
-
-每条分镜的 `prompt` 字段必须以**图像资产标注**作为前缀,且**提示词正文中使用 `@图N` 直接替代对应的角色/场景/道具名称**,建立参考图与画面描述的直接绑定关系。标注按 `associateAssetsIds` 中资产的引用顺序,从 `@图1` 开始依次编号。
-
-**格式**:`@图1 为{资产名称}{资产类型} @图2 为{资产名称}{资产类型} ... , 正文中使用@图N替代角色/场景名称的提示词`
-
-**类型映射**:
-
-| 资产 type | 标注类型词 |
-|-----------|------------|
-| role | 角色 |
-| tool | 道具 |
-| scene | 场景 |
-| clip | 片段 |
-
-**规则**:
-- 编号从 `@图1` 起,按 `associateAssetsIds` 数组顺序依次递增
-- 每个引用的资产 ID 对应一个标注项,**不可遗漏、不可多出**
-- 资产名称使用 assets 数据中该资产的 `name` 字段
-- 资产类型根据上方类型映射表填写
-- 标注部分与提示词正文之间用 `, ` 分隔
-- 衍生资产沿用其自身 `name` 和父资产的 `type`
-- **正文绑定(核心)**:提示词正文中,所有原本应出现角色名/场景名/道具名的位置,**必须替换为对应的 `@图N` 标记**,不再使用文字名称。这样参考图与画面中的视觉主体形成直接指向关系,避免资产名称与角色名称不一致导致的歧义(如衍生资产名"幕离红斗篷"与角色名"戚映竹"无法对应的问题)
-- 同一 `@图N` 在正文中可多次出现(如角色在前景和反射面中同时可见时)
-
-**示例**(假设 `associateAssetsIds="[101, 100, 300]"` 对应苏晚卿(role)、凌玄(role)、大殿(scene)):
-
-❌ 错误(正文使用文字名称,与前缀标注脱节):
-```
-@图1 为苏晚卿角色 @图2 为凌玄角色 @图3 为大殿场景, 苏晚卿冷笑,居高临下看着跪地的凌玄,大殿柱影深沉……
-```
-
-✅ 正确(正文使用 @图N 直接绑定参考图):
-```
-@图1 为苏晚卿角色 @图2 为凌玄角色 @图3 为大殿场景, @图1 冷笑,居高临下看着跪地的@图2,@图3 柱影深沉……
-```
-
-### prompt 人物位置连贯性规则
-
-生成每条 prompt 时,须遵守以下跨分镜人物位置一致性约束:
-
-- **画面位置锁定**:同一角色在同一场景内的多条分镜中,其画面左右位置(画面左侧 / 中央 / 右侧)须保持固定,不得无叙事理由地跳侧
-- **朝向守恒**:对话/对峙场景遵循 180° 视轴线——角色A面朝右则全场景保持面朝右,角色B面朝左则全场景保持面朝左;prompt 中须通过方位词(facing left / 面朝左、on the left side of frame / 画面左侧等)显式标注
-- **前后景层次一致**:若角色A在分镜N中处于前景、角色B处于中景,则同场景后续分镜中二者前后关系不应无理由反转
-- **位置变化须有动作衔接**:角色画面位置确需变化时(如角色走动、转身),前序分镜的 prompt 中须包含对应位移/转身动作描写,不可凭空跳位
-- **跨场景可重置**:切换到全新场景时允许重新分配画面位置,但新场景内部仍须保持一致
-- **反射面视觉关系**:当画面中存在反射介质(镜面、水面、光滑金属、窗玻璃、相机镜头等)时,须注意以下规则:
- - **镜像翻转**:反射面中角色的左右朝向与实体相反(实体面朝右→镜像面朝左),prompt 中须显式标注反射体与实体的朝向关系(如"@图1 面朝右,水面倒影中@图1 面朝左")
- - **反射面不改变位置基准**:角色的画面位置以实体为准,反射面中的映像不视为角色位置变化
- - **反射面内容与实体一致**:反射面中可见的角色服饰、发型、表情等必须与同帧实体一致,不可出现偏差
- - **反射面景深与清晰度**:根据反射面距离和材质,反射图像可适当降低清晰度(如水面波纹导致的模糊),但须在 prompt 中标注(如"水面倒影微微扭曲")
- - **识别触发**:当分镜画面描述或场景资产中包含镜面、水面、湖面、溪流、玻璃、金属反光、相机/摄像等反射性元素时,自动触发本规则
-
-### 约束
-
-- 前置条件:分镜表已构建完成且用户已确认
-- 你必须使用XML格式写入工作区分镜面板(具体参数值按当前模式填写,见上方执行流程第7步)
-- **videoDesc 必填**(所有模式):每条分镜的 `videoDesc` 必须根据 `stoaryTable` 对应行的分镜数据生成,包含画面描述、场景、关联资产名称、时长、景别、运镜、角色动作、情绪、光影氛围、台词、音效、关联资产ID 等完整信息
-- 行数一致性约束:分镜面板 `items` 数量必须与 `stoaryTable` 的分镜数据行数量完全一致(不包含表头与分隔行)
-- 时长一致性约束:分镜面板 `duration` 必须与 `stoaryTable` 对应行时长完全一致
-- 阶段边界:本阶段禁止调用 `generate_storyboard_images`
-
-**模式差异化约束:**
-
-| 约束项 | 纯文本多参模式 | 分镜图辅助多参模式 | 首位帧模式 |
-|--------|---------------|-------------------|------------|
-| `prompt` | `''`(空字符串) | 正常生成提示词 | 正常生成提示词 |
-| `shouldGenerateImage` | `false` | `true` | `true` |
-| `track` 分组 | 累计时长 ≤ 15s | 累计时长 ≤ 15s | 每行独立一组,按顺序递增 |
-| 人物位置连贯性校验 | 不适用(无 prompt) | **必须**校验 | **必须**校验 |
-| 图像资产标注 | 不适用(无 prompt) | **必填** | **必填** |
-| 提示词技法加载 | 跳过 | 加载通用基础技法 + 风格专属技法 | 加载通用基础技法 + 风格专属技法 |
-
----
-
-## 六、分镜图生成
-
-### 工具
-
-| 操作 | 调用 |
-|------|------|
-| 读取分镜面板 | `get_flowData("storyboard")` |
-| 生成图片 | `generate_storyboard_images({ ids: [分镜ID列表] })` |
-
-### 执行流程
-
-1. 获取 `storyboard`
-2. 提取真实分镜 ID 列表
-3. 调用 `generate_storyboard_images({ ids: [真实分镜ID列表] })` 生成分镜图片(异步,发起即返回)
-
-### 约束
-
-- 前置条件:分镜面板已写入完成
-- 图片必须与分镜描述匹配
-- 仅使用 `storyboard` 中的真实分镜 ID,禁止编造或复用无效 ID
\ No newline at end of file
diff --git a/data/skills/production_agent_supervision.md b/data/skills/production_agent_supervision.md
index 5e99ae2..538950d 100644
--- a/data/skills/production_agent_supervision.md
+++ b/data/skills/production_agent_supervision.md
@@ -26,8 +26,9 @@ description: >-
1. 识别审核对象
2. 按对应审核对象的「数据准备」步骤获取数据
-3. 按「审核维度」逐项检查
-4. 按「审核报告格式」生成报告
+3. 对照「Skills」中对应的红线清单 + 「审核维度」逐项检查
+4. 遇到「Skills 三 - 视频制作通用红线」中的违反项,直接标记为严重问题
+5. 按「审核报告格式」生成报告
---
@@ -76,6 +77,49 @@ description: >-
3. **问题具体化**:每个问题指向具体位置和内容,不说"整体不够好"
4. **建议多元化**:严重问题提供多个可选方案
5. **动态基准**:数值判断以实际工作区数据为唯一基准;未明确的参数以合理比例推算,并在报告中注明
+6. **Skills 对照审核**:所有审核项须对照 Skills 中的红线清单逐项核对,确保执行层产出物符合视频制作质量标准
+
+---
+
+## Skills
+
+### 一、导演规划质量红线(审核导演规划时逐项核对)
+
+1. **导演具象化原则**:所有描述以「摄像机能拍到什么」为标准——动作必须是连续物理动作链(禁止"感到疲惫"等抽象词);光影须量化(主光源方向+色温范围+明暗倾向);情绪靠肢体微表情传达("指尖发颤、瞳孔收缩"代替"他很紧张");声音具体到可感知声源(禁止"背景音乐烘托气氛")
+2. **风格一致性**:所有创作规划内容须与风格技法参考(director_planning.md)一致,色调、光影、节奏、声音方向无冲突;冲突时以风格技法参考为准
+3. **六维度完整性**:①主题立意 ②视觉风格 ③叙事结构 ④分场景意图 ⑤声音方向 ⑥转场与视觉连续性,六个维度均有输出,必填规划项无缺失
+4. **叙事模式选型合理**:须根据内容特征选择叙事模式(完整叙事型/情绪意境型/原著保真型),选型须与剧本类型匹配
+5. **情绪曲线渐进递增**:情绪曲线呈渐进式递增,快慢交替;不允许连续3个以上同强度段落;高潮段落的"快"指情绪密度高(更紧密的景别切换),不等于缩短镜头时长
+6. **转折点视觉化**:关键转折点必须用具体视觉手段描述(光影突变、景别跳切、空镜隐喻等),不依赖台词解释;优先画面而非台词
+7. **构图须有叙事理由**:构图选择须说明叙事理由,参考情绪-构图映射(对称→秩序/压迫;三分法留白→孤独/期待;对角线→冲突/紧张;框中框→囚禁/窥视)
+8. **空间三层分离**:关键画面须规划前景(引导视线)/ 中景(叙事主体)/ 背景(情绪氛围)的层次关系
+9. **光影段落对应**:光影以「段落-光影方向」表格呈现,每段落指定光影基调方向;色温、光源角度等参数以风格技法参考为准
+10. **声音可感知**:环境音具体到可感知声源("蝉鸣/溪水/市井叫卖/雨滴檐角"),每场标注1~2个核心环境音;配乐覆盖率不超过70%,留白段落与配乐段落形成呼吸感
+11. **资产全覆盖**:规划中引用的角色、道具、场景在 assets 列表中均存在,无虚构引用
+
+### 二、分镜表质量红线(审核分镜表时逐项核对)
+
+1. **内容忠实剧本**:分镜内容严格按照剧本叙事顺序和内容拆分,不遗漏不新增剧本中不存在的情节
+2. **台词原文锁定**:剧本中所有台词必须原文照搬进 lines 字段,禁止改写、省略或意译;缺失台词视为严重错误
+3. **资产关联正确**:associateAssetsIds 使用资产实际 ID(非数组索引),必须与工作区现有资产匹配;索引越界视为严重错误
+4. **角色出现即引用**:画面中可见的所有角色(含局部可见——背影、肢体局部、虚化身影),只要可辨识就必须引用对应资产 ID;遗漏视为严重错误
+5. **场景资产必选**:每条分镜必须引用其所处场景对应的场景资产 ID(type 为 scene 的资产);若存在匹配衍生场景资产则选用衍生 ID,否则选用主场景资产 ID;缺少场景资产 ID 视为严重错误
+6. **父子资产选择正确**:按剧情选资产——衍生状态匹配则仅用衍生 ID,无匹配衍生才用主资产 ID;同一父资产在同一分镜中禁止主/衍生同时出现
+7. **视觉连续性七律**:① 动作连续性(位置、动作进度、朝向物理逻辑一致)② 景别递进法则(渐进聚焦或渐进释放,禁止无理由连续3镜同景别)③ 视轴守恒(180°线原则)④ 朝向空间逻辑(对话双方面朝彼此,操作物品面朝物品)⑤ 信息控制意识(给手不给脸=悬念;先声后画=期待)⑥ 节拍密度约束(2~3s≤1拍;4~6s≤2拍;7s+≤3拍)⑦ 头尾安全区(前后0.5s不放关键动作/台词起始)
+8. **朝向必填且连续**:每条分镜 action 字段必须含 `|朝向:` 标注(空镜除外);同一场景内同一角色朝向与首次出场一致,变化须有转身/转头衔接动作
+9. **台词-时长强关联**:含台词分镜 duration ≥ 台词字数÷情绪语速(向上取整)+ 停顿余量 + 1s安全余量;语速标准:愤怒~4字/秒、正常~3字/秒、悲伤~2字/秒、低语~2字/秒
+10. **定场精简**:每个新场景定场最多1~2镜,禁止3镜以上碎片化定场;能一镜完成定场+引入的不拆两镜
+11. **黄金6秒**:无台词镜头不超过6s,定场/过渡类镜头尤其注意
+12. **光影风格一致**:光影描述须与已加载风格技法的光影规范保持一致
+
+### 三、视频制作通用红线
+
+以下任何一项违反均标记为**严重问题**:
+1. 资产引用了工作区中不存在的 ID 或名称
+2. 输出内容与风格技法参考存在直接冲突(色调、光影、构图等关键视觉要素)
+3. 规划或分镜中遗漏剧本场次/关键事件
+4. 抽象笼统表述替代具象可感描述(如仅写"开心""暗调"而无具体视觉/声源细节)
+5. 分镜表中缺失台词(剧本有台词但分镜表未收录)
---
@@ -88,18 +132,21 @@ description: >-
### 审核维度
-导演规划由**创作规划**(五维度)和**执行计划**(步骤列表)两部分组成,逐项审核:
+导演规划由**创作规划**(六维度)和**执行计划**(步骤列表)两部分组成,逐项审核:
| 审核项 | 对应部分 | 标准 | 严重程度 |
|--------|---------|------|----------|
-| 风格一致性 | 全局 | 所有创作规划内容与 director_planning.md 风格技法参考一致,无冲突 | 严重 |
-| 剧情覆盖度 | ③叙事结构 + ④分场景意图 | 段落划分与分场景意图覆盖剧本全部场次,无遗漏 | 严重 |
-| 资产匹配 | ④分场景意图 + 执行计划 | 规划中引用的角色、道具、场景在 assets 列表中均存在 | 严重 |
-| 创作规划完整性 | ①~⑤ | 五个维度均有输出,必填规划项无缺失 | 中等 |
-| 具象化表达 | ①~⑤ | 情绪、氛围、声音描述具体可感知,无抽象笼统表述 | 中等 |
-| 节奏合理性 | ③叙事结构 | 情绪曲线渐进递增,快慢交替,无连续同强度段落 | 中等 |
+| 风格一致性 | 全局 | 所有创作规划内容与 director_planning.md 风格技法参考一致,无冲突(→ Skills 一-2) | 严重 |
+| 剧情覆盖度 | ③叙事结构 + ④分场景意图 | 段落划分与分场景意图覆盖剧本全部场次,无遗漏(→ Skills 三-3) | 严重 |
+| 资产匹配 | ④分场景意图 + 执行计划 | 规划中引用的角色、道具、场景在 assets 列表中均存在(→ Skills 一-11/三-1) | 严重 |
+| 创作规划完整性 | ①~⑥ | 六个维度均有输出,必填规划项无缺失(→ Skills 一-3) | 中等 |
+| 具象化表达 | ①~⑥ | 情绪、氛围、声音描述具体可感知,无抽象笼统表述(→ Skills 一-1/三-4) | 中等 |
+| 节奏合理性 | ③叙事结构 | 情绪曲线渐进递增,快慢交替,无连续同强度段落(→ Skills 一-5) | 中等 |
+| 转折点视觉化 | ③叙事结构 | 关键转折点用具体视觉手段描述,不依赖台词(→ Skills 一-6) | 中等 |
+| 构图与空间层次 | ②视觉风格 + ④分场景意图 | 构图有叙事理由;关键画面有前/中/背景三层分离(→ Skills 一-7/8) | 中等 |
+| 声音可感知 | ⑤声音方向 | 环境音具体到声源,配乐覆盖率≤70%(→ Skills 一-10) | 中等 |
| 依赖关系正确 | 执行计划 | 步骤间依赖关系正确,无循环依赖或遗漏 | 中等 |
-| 总字数控制 | 全局 | 总字数不超过 1000 词 | 轻微 |
+| 总字数控制 | 全局 | 总字数不超过 1200 词 | 轻微 |
### 详细审核标准
@@ -133,22 +180,25 @@ description: >-
|------|--------|
| ①主题立意 | 核心主题、情感主线、离场感受、情感表达策略 |
| ②视觉风格 | 整体色调、画面质感、构图风格、镜头运动偏好、光影体系 |
-| ③叙事结构 | 段落划分表(编号/名称/场次/核心事件/情绪浓度/节奏)、情绪曲线、转折点 |
+| ③叙事结构 | 段落划分表(编号/名称/场次/核心事件/情绪浓度/节奏)、叙事模式选型、情绪曲线、转折点 |
| ④分场景意图 | 逐场的情绪目标、氛围方向、镜头意图、空间叙事、距离感设计 |
-| ⑤声音方向 | 音乐风格、段落配乐对应、环境音设计、沉默运用 |
+| ⑤声音方向 | 音乐风格、段落配乐对应、配乐覆盖率、环境音设计、沉默运用 |
+| ⑥转场与视觉连续性 | 场间转场策略、段落间过渡手法、视觉连续性锚点 |
-#### 具象化表达(中等)
+#### 具象化表达(中等)(→ Skills 一-1/三-4)
- ①情感主线需拆解 2-3 个递进层次,非笼统概括
-- ②色调需具体到色彩代号或色温范围,非"暖色调"
+- ②色调需具体到色彩代号或色温范围,非"暖色调";构图须说明叙事理由
- ③转折点必须用具体视觉手段描述(光影突变、景别跳切等),优先画面而非台词
-- ④情绪目标用具象可感的描述,禁止抽象词(如"开心""悲伤")
-- ⑤环境音需具体到可感知声源,非"自然声"
+- ④情绪目标用具象可感的描述,禁止抽象词(如"开心""悲伤");镜头意图写"为什么"而非"怎么拍"
+- ⑤环境音需具体到可感知声源,非"自然声";配乐覆盖率不超过70%
+- ⑥转场策略须标注具体空镜内容方向,视觉连续性锚点须指明关键跨场景一致性要求
-#### 节奏合理性(中等)
+#### 节奏合理性(中等)(→ Skills 一-5)
- 情绪曲线应呈渐进式递增,非平铺直叙
- 高强度段落与低强度段落交替出现,不允许连续 3 个以上同强度段落
+- 高潮段落的"快"指情绪密度高(更紧密的景别切换),不等于缩短镜头时长
- 段落间应有过渡设计,避免硬切
#### 依赖关系正确(中等)
@@ -171,12 +221,16 @@ description: >-
| 审核项 | 标准 | 严重程度 |
|--------|------|----------|
-| 关联资产正确 | associateAssetsIds 中的索引均在 assets 数组范围内;画面中可见的资产已关联 | 严重 |
-| 父子资产选择正确 | 同一分镜按剧情优先选择衍生资产 ID;无匹配衍生时才使用主资产 ID,且二者不得同时出现 | 严重 |
-| 剧本覆盖度 | 剧本中的全部场景和关键事件均有对应分镜,无遗漏 | 严重 |
-| 拆分粒度 | 一个独立画面对应一条分镜;无过度合并或过度拆分 | 中等 |
-| 镜头语言合理 | camera 字段使用标准景别术语;景别变化服务于叙事节奏 | 中等 |
-| 时长合理性 | duration 与画面复杂度匹配;总时长与剧本预估时长基本吻合 | 中等 |
+| 关联资产正确 | associateAssetsIds 中的 ID 均在 assets 中存在;画面中可见的角色与场景资产已关联(→ Skills 二-3/4/5/三-1) | 严重 |
+| 父子资产选择正确 | 同一分镜按剧情优先选择衍生资产 ID;无匹配衍生时才使用主资产 ID,且二者不得同时出现(→ Skills 二-6) | 严重 |
+| 剧本覆盖度 | 剧本中的全部场景和关键事件均有对应分镜,无遗漏(→ Skills 二-1/三-3) | 严重 |
+| 台词完整性 | 剧本中所有台词均原文出现在分镜 lines 字段中,无改写、省略或遗漏(→ Skills 二-2/三-5) | 严重 |
+| 视觉连续性 | 相邻分镜的动作连续性、景别递进、视轴守恒、朝向逻辑符合七律(→ Skills 二-7) | 中等 |
+| 朝向标注 | 每条分镜 action 字段含朝向标注;同场景同角色朝向连续一致(→ Skills 二-8) | 中等 |
+| 拆分粒度 | 一个独立画面对应一条分镜;无过度合并或过度拆分;定场最多1~2镜(→ Skills 二-10) | 中等 |
+| 镜头语言合理 | camera 字段使用标准景别术语;景别变化服务于叙事节奏;无连续5条以上相同景别 | 中等 |
+| 时长合理性 | 含台词时长匹配情绪语速;无台词镜头≤6s;总时长与剧本预估基本吻合(→ Skills 二-9/11) | 中等 |
+| 光影风格一致 | 光影描述与已加载风格技法的光影规范一致(→ Skills 二-12/三-2) | 中等 |
### 详细审核标准
@@ -232,9 +286,60 @@ description: >-
- 同一段对话被拆成超过 3 条分镜(无视角切换时)
+#### 台词完整性(严重)(→ Skills 二-2/三-5)
+
+验证方法:
+1. 提取剧本中全部角色台词
+2. 逐条比对分镜表 lines 字段,确认原文一字不差
+3. 标注缺失、改写或省略的台词及对应剧本位置
+
+不通过示例:
+- 剧本写"你以为你配?",分镜 lines 改写为"你觉得你配吗?"
+- 剧本中某角色有 3 句台词,分镜表仅收录 2 句
+
+#### 视觉连续性(中等)(→ Skills 二-7)
+
+逐对相邻分镜检查七律:
+- **动作连续性**:上一镜动作终态 = 下一镜动作起态,无跳跃
+- **景别递进**:景别切换遵循渐进聚焦或渐进释放,无理由连续 3 镜以上同景别视为问题
+- **视轴守恒**:对话/对峙场景中角色画面位置全片固定同侧,不得跳轴
+- **节拍密度**:2~3s镜头≤1拍;4~6s镜头≤2拍;7s+镜头≤3拍
+
+#### 朝向标注(中等)(→ Skills 二-8)
+
+验证方法:
+1. 遍历每条分镜的 action 字段,检查是否包含 `|朝向:` 标注(空镜除外)
+2. 同一场景内追踪每个角色的朝向序列,检查是否与首次出场一致
+3. 朝向发生变化时,检查动作描述中是否有转身/转头等衔接动作
+
+不通过示例:
+- action 字段仅写"缓缓抬手",缺少朝向标注
+- 角色首次出场标注"面朝右",下一镜突然变为"面朝左"但无转身动作描述
+
+#### 台词-时长匹配(中等)(→ Skills 二-9)
+
+验证方法:
+1. 提取含台词分镜的 lines 字段,统计台词字数
+2. 根据 emotion 字段判断语速档位(愤怒~4字/秒、正常~3字/秒、悲伤/低语~2字/秒)
+3. 计算最低 duration = 台词字数÷语速(向上取整)+ 标点停顿累计(每个标点+0.3~0.5s)+ 1s安全余量
+4. 对比实际 duration,不足则标记问题
+
+#### 定场精简(中等)(→ Skills 二-10)
+
+- 每个新场景的定场镜头不超过 2 个
+- 能一镜完成定场+引入的不拆两镜
+- 连续描述同一空间不同局部的镜头(院门→藤蔓→厢房)应合并为一个镜头
+
#### 镜头语言合理(中等)
- 使用标准景别术语(大远景/远景/全景/中景/近景/特写/大特写)
- 重要细节用特写/大特写,场景建立用远景/全景
- 对话场景通常用近景/中景
- 不允许连续 5 条以上使用完全相同的景别
+
+#### 光影风格一致(中等)(→ Skills 二-12/三-2)
+
+验证方法:
+1. 加载风格技法参考中的光影规范
+2. 逐条分镜检查 lighting 字段是否与风格光影规范方向一致
+3. 标注明显偏离风格基准的分镜
diff --git a/data/skills/production_execution_derive_assets.md b/data/skills/production_execution_derive_assets.md
new file mode 100644
index 0000000..eaa73e2
--- /dev/null
+++ b/data/skills/production_execution_derive_assets.md
@@ -0,0 +1,97 @@
+---
+name: production_execution_derive_assets.md
+description: >-
+ 视频制作执行层Agent技能 — 衍生资产分析与信息写入。
+ 负责分析剧本并识别每个资产的视觉状态变体,逐条写入衍生资产。
+---
+# 执行层 Agent — 衍生资产分析与信息写入
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 一、衍生资产分析与信息写入
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` |
+| 写入衍生资产 | `add_deriveAsset` |
+
+
+### 执行流程
+
+1. 获取 `script` 和 `assets`
+2. 按下方提取规则分析剧本,识别每个资产的视觉状态变体
+3. 简单说明要增加的衍生资产内容以及信息。总共200字以内
+4. 如不需要衍生资产,返回"不需要衍生资产",流程结束
+5. 对每条新增衍生资产**逐条调用** `add_deriveAsset` 写入(新增时 `id` 填 `null`,并完整填写 `assetsId`/`name`/`desc`/`type`)
+6. 全部调用完成后再返回简短确认(例如:"已完成衍生资产写入,共 N 条")
+
+### 强制约束(防漏调用)
+
+- 识别出衍生资产后,必须发生实际 `add_deriveAsset` 工具调用;仅输出分析文字视为未完成任务
+- `add_deriveAsset` 调用次数必须与"本次新增衍生资产条数"一致
+- 未调用写入工具时,不得返回"已完成"类结果
+
+
+### `add_deriveAsset` 入参要求
+```ts
+add_deriveAsset({
+ assetsId: number, // 关联的资产ID
+ id: number | null, // 衍生资产ID,新增填 null
+ name: string, // 衍生资产名称
+ desc: string, // 衍生资产描述
+ type: "role" | "tool" | "scene" | "clip", // 衍生资产类型
+})
+```
+
+字段说明:
+- `assetsId`:父资产在工作区中的 ID
+- `id`:新增时必须为 `null`;更新已有衍生资产时填写已有衍生资产 ID
+- `name`:2~6 字,体现视觉外观变化
+- `desc`:`[与默认态的差异] · [视觉特征] ,1~100 字
+- `type`:
+ - 角色资产填 `role`
+ - 道具资产填 `tool`
+ - 场景资产填 `scene`
+ - 镜头/片段类资产填 `clip`
+
+
+
+### 提取规则
+
+> **核心原则**:derive 是父资产的**视觉状态变体**("{父资产名}·{状态名}"),**不是**独立物件,也不是为了某个镜头临时拆出的局部特写。
+> 只衍生**图片模型无法仅凭提示词稳定处理、且能在多个镜头/场次复用的资产级视觉差异**(服装、整体形态、结构性残缺、物件状态等)。
+> 表情、情绪、简单动作姿态、局部特写、镜头强调细节等**不需要衍生**。
+> **角色默认基准态**:角色父资产默认视为基础打底态(如白色背心+内裤,或仅内裤状态)。因此剧本中凡出现校服、常服、礼服、盔甲、外套等明确穿着时,通常应补充对应的**服装类衍生资产**;基础打底态本身不重复创建衍生。若某角色当前**没有任何子资产**,则应先根据剧本主场景与常态设定,补充一套最合适的**默认常服/正式服装衍生**,避免后续该角色长期停留在基础打底态。
+
+**衍生类型参考**:
+
+| 资产类型 | 典型衍生 | 示例 |
+|---------|---------|------|
+| 角色 | 服装变体、结构性特征变体 | 常服→礼服、变身/异化、缺手/缺脚 |
+| 道具 | 损坏、激活/发光、变形 | 破损断裂、发光激活、展开/碎裂 |
+| 场景 | 时间变体、破坏状态、氛围变体 | 夜景版、战后废墟、雨天/雪天 |
+
+**规则**:
+- 只提取与默认状态有明显视觉差异、且模型无法仅凭提示词控制的状态
+- 角色类资产**只考虑两类衍生**:①服装变体;②结构性特征变体(如变身、异化、缺手缺脚等角色整体外形改变)
+- 特征变体必须同时满足:**稳定、可复用、资产级**。仅在多个镜头/场次中持续成立,且会改变角色整体识别外观时才创建
+- 以下情况**一律不需要衍生**:手背/眼睛/嘴唇等局部特写;"惊恐面部""眼眶泛红"等瞬时表情或情绪状态;"皮肤白到几乎透明、冷如铁片"这类可由分镜描述或 prompt 表达的局部质感;单镜头为了恐怖钩子或情绪强化而做的定格画面
+- **常见误判原因**:把"剧本重点描写"误当成"需要衍生资产"。判断标准不是它是否重要,而是它是否属于父资产**稳定、可复用、整体级**的视觉状态
+- 若角色当前 `derive` 为空,应先补 1 个最符合剧本常态的服装类衍生资产(如常服、校服、工装、礼服中的一种),作为后续主要出镜默认态
+- 若当前剧情穿着不是基础打底态,应优先补充对应服装类衍生资产;若存在持续且显著的身体/形态差异,再补充对应特征类衍生资产
+- 已存在于 `derive` 数组中的状态不重复
+- 每个资产 1~5 个衍生,宁缺勿滥
+- 提取到衍生资产后,必须逐条调用 `add_deriveAsset` 保存,禁止只分析不写入
+- 来源优先级:剧本明确描写 > 资产描述暗示 > 合理推测
+- `name`:2~6 字,体现视觉外观变化
+- `desc`:格式为 `[与默认态的差异] · [视觉特征] `,
diff --git a/data/skills/production_execution_director_plan.md b/data/skills/production_execution_director_plan.md
new file mode 100644
index 0000000..5249d36
--- /dev/null
+++ b/data/skills/production_execution_director_plan.md
@@ -0,0 +1,132 @@
+---
+name: production_execution_director_plan.md
+description: >-
+ 视频制作执行层Agent技能 — 导演规划。
+ 负责基于剧本与资产制定完整的导演创作规划(六维度)。
+---
+# 执行层 Agent — 导演规划
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 三、导演规划
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` |
+
+### 风格技法参考
+
+
+
+### 执行流程
+
+1. 加载风格技法参考,获取 `script` 和 `assets`,并并且激活 `director_planning_narrative` 以及 `director_planning_style`,所有规划内容以该文档为风格基准,冲突时以风格技法参考为准。
+2. 按下方规范制定导演规划(创作规划),全文遵守「导演具象化原则」
+3. 严格按照XML格式写出导演规划内容,XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
+
+### 导演具象化原则(贯穿全文)
+
+规划文本必须像导演给演员讲戏,禁止抽象情绪词,所有描述以「摄像机能拍到什么」为标准:
+
+- **动作具体化**:写连续物理动作链("揉太阳穴→目光移开→靠向椅背"),禁止"感到疲惫"等抽象词
+- **光影可量化**:主光源方向 + 色温范围 + 明暗倾向("侧光偏暖,明暗反差强"),禁止空泛词("柔光""氛围好")
+- **情绪靠身体**:通过肢体微表情传达("指尖发颤、瞳孔收缩"代替"他很紧张")
+- **声音可感知**:环境音具体到声源("蜡芯噼啪声、远处风声"),禁止"背景音乐烘托气氛"
+
+### 创作规划(六维度)
+
+#### ① 主题立意与叙事核心
+
+规划项:核心主题、情感主线、离场感受、情感表达策略
+
+约束:
+- 主题一句话凝练
+- 情感主线拆 2~3 个递进层次,每层对应可感知的视觉/行为变化
+- 离场感受与表达策略须与风格技法参考一致
+
+#### ② 视觉风格与画面基调
+
+规划项:整体色调、画面质感、构图风格、镜头运动偏好、光影体系
+
+约束:
+- 色调具体到色温范围或色彩倾向描述
+- 光影以「段落-光影方向」表格呈现,每段落指定光影基调方向
+- 色温、光源角度、冷暖色调分配等具体技法参数以风格技法参考(`director_planning_narrative` 以及 `director_planning_style`)为准
+- **构图须说明叙事理由**,参考以下情绪-构图映射(按需选用):
+ - 对称构图 → 秩序 / 压迫 / 庄重
+ - 三分法偏侧留白 → 孤独 / 期待 / 未知
+ - 对角线构图 → 运动 / 冲突 / 紧张
+ - 框中框构图 → 囚禁 / 窥视 / 心理距离
+- **空间三层分离**:关键画面须规划前景(引导视线)/ 中景(叙事主体)/ 背景(情绪氛围)的层次关系
+- 镜头运动默认以静为主,运镜须说明叙事目的("缓推=靠近角色内心""缓拉=揭示全貌/抽离")
+
+#### ③ 叙事结构与节奏规划
+
+规划项:叙事模式选型、段落划分、情绪曲线、快慢节奏、关键转折点、段落过渡方式
+
+约束:
+- **叙事模式选型**(根据内容特征选择,写入规划):
+ - 完整叙事型:适用于有完整起承转合的长剧本,按戏剧节拍划分段落
+ - 情绪意境型:适用于氛围/散文式内容,按情绪阶段(起-承-转-合)划分
+ - 原著保真型:适用于已有成熟结构的改编剧本,按原著自然场景边界划分,不强加节拍
+- 段落以表格呈现(编号 / 名称 / 场次 / 核心事件 / 情绪浓度 / 节奏)
+- 情绪曲线渐进递增,避免"平平平→突然爆发"
+- 转折点必须用**具体视觉手段**描述(光影突变、景别跳切、空镜隐喻等),不依赖台词解释
+- 高潮段落的"快"指情绪密度高(更紧密的景别切换),不等于缩短镜头时长
+
+#### ④ 分场景情绪与画面意图
+
+规划项(逐场):场次编号、情绪目标、氛围方向、镜头意图、空间叙事、距离感设计
+
+约束:
+- 情绪目标用具象可感描述("偷偷心动后的嘴角压不住",禁止"开心"等抽象词)
+- 氛围方向映射风格技法参考的光影方案
+- **镜头意图写"为什么"**("用特写让观众看到她眼里的犹豫"),而非"怎么拍"("用特写拍脸")
+- **场景语义→镜头方案参考**(为每场选择最匹配的方案方向):
+ - 开场/定场 → 大远景 + 缓推至主体
+ - 角色登场 → 全景/中景 + 微仰 + 背光轮廓
+ - 对话交锋 → 中景/近景 + 正反打 + 守视轴
+ - 情绪加压 → 景别逐步递进收紧(中→近→特写→大特写)
+ - 浪漫/温馨 → 近景 + 浅景深 + 暖调柔光
+ - 独白/沉思 → 特写侧面轮廓 + 定镜
+ - 高潮转折 → 景别骤变或环绕运镜
+- **距离感设计**:通过景别变化映射人物关系变化(初期远→中期近但有遮挡→后期特写零距离)
+
+#### ⑤ 声音与音乐方向
+
+规划项:音乐风格、段落配乐对应、配乐覆盖率、环境音设计、沉默运用
+
+约束:
+- 配乐按段落统一规划(不逐场),同段落内场景切换靠环境音变化过渡
+- 乐器选择、组合策略等具体技法以风格技法参考(`director_planning_narrative` 以及 `director_planning_style`)为准
+- 环境音具体到可感知声源("蝉鸣 / 溪水 / 市井叫卖 / 雨滴檐角"),每场标注 1~2 个核心环境音
+- 标注运用沉默手法的关键瞬间(关键情感瞬间优先考虑去掉配乐,只留环境音)
+- 全片配乐覆盖率建议不超过 70%,留白段落与配乐段落形成呼吸感
+
+#### ⑥ 转场与视觉连续性
+
+规划项:场间转场策略、段落间过渡手法、视觉连续性锚点
+
+约束:
+- 同场戏内镜头默认硬切
+- 不同场景间插入空镜过渡做情绪缓冲(标注具体空镜内容方向)
+- 大段落间可用叠化/淡入淡出做柔性过渡
+- 标注全片视觉连续性锚点:角色位置、服装状态、环境光影在跨场景时保持一致的关键点
+
+### 输出要求
+
+- 总字数不超过 1200 词,精炼表达
+- 你必须使用XML格式写入工作区拍摄计划:内容,XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
+- 按「创作规划(①~⑥)」顺序输出
+- 表格仅在信息密度高时使用,其余用简洁列表或短段落
+- 具象优于抽象,视觉优先叙事,所有描述须通过「导演具象化原则」检验
diff --git a/data/skills/production_execution_generate_assets.md b/data/skills/production_execution_generate_assets.md
new file mode 100644
index 0000000..68921b0
--- /dev/null
+++ b/data/skills/production_execution_generate_assets.md
@@ -0,0 +1,36 @@
+---
+name: production_execution_generate_assets.md
+description: >-
+ 视频制作执行层Agent技能 — 衍生资产图片生成。
+ 负责收集需要生成图片的资产并调用生成工具。
+---
+# 执行层 Agent — 衍生资产图片生成
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 二、衍生资产图片生成
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取资产列表 | `get_flowData("assets")` |
+| 生成资产图片 | `generate_assets_images({ ids: [资产id列表] })` |
+
+### 执行流程
+
+1. 获取 `assets`,收集所有需要生成图片的资产 id
+2. 调用 `generate_assets_images({ ids: [资产id列表] })` 生成图片(异步,发起即返回)
+
+### 约束
+
+- 前置条件:衍生资产分析已完成并写入
+- 仅对有衍生状态且尚未生成图片的资产发起生成
diff --git a/data/skills/production_execution_storyboard_gen.md b/data/skills/production_execution_storyboard_gen.md
new file mode 100644
index 0000000..416c943
--- /dev/null
+++ b/data/skills/production_execution_storyboard_gen.md
@@ -0,0 +1,38 @@
+---
+name: production_execution_storyboard_gen.md
+description: >-
+ 视频制作执行层Agent技能 — 分镜图生成。
+ 负责读取分镜面板并调用图片生成工具生成分镜图片。
+---
+# 执行层 Agent — 分镜图生成
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 六、分镜图生成
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取分镜面板 | `get_flowData("storyboard")` |
+| 生成图片 | `generate_storyboard_images({ ids: [分镜ID列表] })` |
+
+### 执行流程
+
+1. 获取 `storyboard`
+2. 提取真实分镜 ID 列表
+3. 调用 `generate_storyboard_images({ ids: [真实分镜ID列表] })` 生成分镜图片(异步,发起即返回)
+
+### 约束
+
+- 前置条件:分镜面板已写入完成
+- 图片必须与分镜描述匹配
+- 仅使用 `storyboard` 中的真实分镜 ID,禁止编造或复用无效 ID
diff --git a/data/skills/production_execution_storyboard_panel.md b/data/skills/production_execution_storyboard_panel.md
new file mode 100644
index 0000000..dbe0cd2
--- /dev/null
+++ b/data/skills/production_execution_storyboard_panel.md
@@ -0,0 +1,83 @@
+---
+name: production_execution_storyboard_panel.md
+description: >-
+ 视频制作执行层Agent技能 — 分镜面板写入。
+ 负责根据分镜表数据逐行写入分镜面板,支持纯文本多参/分镜图辅助多参/首位帧三种模式。
+---
+# 执行层 Agent — 分镜面板写入
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 五、分镜面板写入
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取剧本 | `get_flowData("script")` |
+| 读取分镜表 | `get_flowData("stoaryTable")` |
+| 读取剧本规划 | `get_flowData("scriptPlan")` |
+
+### 写入模式
+
+本阶段根据决策层派发指令中携带的模式信息,选择对应的写入策略:
+
+| 模式 | 说明 | prompt | shouldGenerateImage | track 分组规则 |
+|------|------|--------|---------------------|----------------|
+| **纯文本多参模式** | 仅写入视频描述与资产绑定,不生成提示词和分镜图 | `''`(空字符串) | `false` | 同「分镜图辅助多参模式」,累计时长 ≤ 15s |
+| **分镜图辅助多参模式** | 完整生成提示词并生成分镜图(当前默认行为) | 正常生成 | `true`(默认) | 累计时长 ≤ 15s |
+| **首位帧模式** | 完整生成提示词,每条分镜独立一组 | 正常生成 | `true`(默认) | **不分组**,每行独立一组,按顺序递增 |
+
+> 模式信息由决策层在派发指令中明确指定,执行层不自行判断。
+
+### 执行流程
+
+1. 获取 `script`、`stoaryTable` 和 `scriptPlan`,识别决策层指令中的**写入模式**(纯文本多参模式 / 分镜图辅助多参模式 / 首位帧模式)。**若为「分镜图辅助多参模式」或「首位帧模式」**:激活 `storyboard_prompt_techniques` 作为通用提示词技法参考(含解析映射规则、景别词库、输出格式规范、提示词结构框架、画质规范、图像资产标注规则、人物位置连贯性规则),并激活风格专属技法(`director_storyboard`)作为提示词生成的全部参考依据,冲突时以风格专属技法为准;**若为「纯文本多参模式」**:跳过提示词相关技法加载
+2. 确定分组(track)与时长规则:
+ - **纯文本多参模式 / 分镜图辅助多参模式**:同组内分镜 `duration` 累计时长不得超过 15 秒
+ - **首位帧模式**:**不分组**,每条分镜独立一组,`track` 按顺序递增(第1行 track=1,第2行 track=2,以此类推)
+ - 所有模式下,每条 `duration` 必须严格使用 `stoaryTable` 对应行时长
+3. **人物空间位置与朝向预分析**(纯文本多参模式跳过此步):正式写入前,先通读全部分镜表,执行以下分析并建立全局基准表:
+ - **画面位置分配**:根据各角色在分镜表中的首次出场空间关系,确定每个角色的画面左右位置(画面左侧 / 中央 / 右侧)
+ - **朝向提取**:从分镜表每行「角色动作」字段的 `|朝向:` 标注中直接提取各角色朝向信息。若个别行缺少标注(如空镜),按步骤2已加载技法中的「朝向获取规则」兜底推断
+ - **建立基准表**:输出格式如 `角色A → 画面左侧,面朝右 / 角色B → 画面右侧,面朝左`,同一场景内锁定不变
+ - **变化标记**:若分镜表某行的角色动作包含转身、转头、走位等方向变化(朝向标注同步变更),在该行标记朝向/位置变更点,后续分镜从变更后状态继续锁定
+ - 后续每条 prompt 中涉及该人物时须按基准表显式标注位置和朝向(依据步骤1已加载技法中的「prompt 人物位置与朝向连贯性规则」)
+4. **图像资产标注与正文绑定**(纯文本多参模式跳过此步):为每条分镜的 prompt 生成图像资产标注前缀,按 `associateAssetsIds` 的引用顺序,依次标注 `@图N 为xx{类型}`;**提示词正文中所有涉及该角色/场景/道具的位置,必须使用对应的 `@图N` 替代其名称**,建立参考图与画面描述的直接绑定(依据步骤1已加载技法中的「prompt 图像资产标注规则」)
+5. **生成视频描述(videoDesc)**(所有模式均需):根据 `stoaryTable` 对应行的完整分镜数据(画面描述、场景、关联资产名称、时长、景别、运镜、角色动作、情绪、光影氛围、台词、音效、关联资产ID),将该行信息整合为一段结构化的视频描述文本,填入 `videoDesc` 字段
+6. **生成提示词(prompt)并忠实性校验**(纯文本多参模式跳过此步):逐行读取 `stoaryTable` 对应行的「画面描述」「场景」「景别」「角色动作」「情绪」「光影氛围」字段,严格按照步骤1已加载技法中的「分镜表内容忠实性原则」和「解析映射规则」将各字段映射为提示词各段落。**生成每条提示词后须立即逐字段比对分镜表原始内容**,确认:① 画面描述中的所有视觉主体和空间关系均已完整保留在提示词正文中;② 情绪基调与分镜表一致;③ 光影方向和色调与分镜表一致;④ 景别匹配;⑤ 角色动作语义一致(仅形式按首帧原则转换,不替换为不同动作);⑥ 角色朝向与步骤3基准表一致,且 prompt 中已显式标注朝向方位词。校验不通过须修正后再进入下一步
+7. 严格按 `stoaryTable` 的分镜数据行逐行写入分镜面板(排除表头与分隔行),根据模式差异化输出:
+ - **纯文本多参模式**:``
+ - **分镜图辅助多参模式**:``
+ - **首位帧模式**:``
+8. 写入完成后,仅返回一句确认:`已完成分镜面板写入({当前模式名称})`
+
+### 约束
+
+- 前置条件:分镜表已构建完成且用户已确认
+- 你必须使用XML格式写入工作区分镜面板(具体参数值按当前模式填写,见上方执行流程第7步),所有 XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
+- **videoDesc 必填**(所有模式):每条分镜的 `videoDesc` 必须根据 `stoaryTable` 对应行的分镜数据生成,包含画面描述、场景、关联资产名称、时长、景别、运镜、角色动作、情绪、光影氛围、台词、音效、关联资产ID 等完整信息
+- **prompt 内容忠实性**(分镜图辅助多参模式 / 首位帧模式):提示词内容必须忠实于 `stoaryTable` 对应行的画面描述、场景、景别、角色动作、情绪、光影氛围等字段,禁止凭空添加分镜表未描述的视觉元素或替换原始语义;风格锚定词和画质锁定词作为辅助修饰,不得挤占或替代分镜表中的具体画面内容(详见步骤1已加载技法中的「分镜表内容忠实性原则」)
+- 行数一致性约束:分镜面板 `items` 数量必须与 `stoaryTable` 的分镜数据行数量完全一致(不包含表头与分隔行)
+- 时长一致性约束:分镜面板 `duration` 必须与 `stoaryTable` 对应行时长完全一致
+- 阶段边界:本阶段禁止调用 `generate_storyboard_images`
+
+**模式差异化约束:**
+
+| 约束项 | 纯文本多参模式 | 分镜图辅助多参模式 | 首位帧模式 |
+|--------|---------------|-------------------|------------|
+| `prompt` | `''`(空字符串) | 正常生成提示词 | 正常生成提示词 |
+| `shouldGenerateImage` | `false` | `true` | `true` |
+| `track` 分组 | 累计时长 ≤ 15s | 累计时长 ≤ 15s | 每行独立一组,按顺序递增 |
+| 人物位置连贯性校验 | 不适用(无 prompt) | **必须**校验(见步骤1已加载技法) | **必须**校验(见步骤1已加载技法) |
+| 图像资产标注 | 不适用(无 prompt) | **必填**(见步骤2已加载技法) | **必填**(见步骤2已加载技法) |
+| 提示词技法加载 | 跳过 | 激活通用技法 + 风格专属技法(见步骤2) | 激活通用技法 + 风格专属技法(见步骤2) |
+| 提示词忠实性校验 | 不适用(无 prompt) | **必须**校验(见步骤7) | **必须**校验(见步骤7) |
diff --git a/data/skills/production_execution_storyboard_table.md b/data/skills/production_execution_storyboard_table.md
new file mode 100644
index 0000000..d76a371
--- /dev/null
+++ b/data/skills/production_execution_storyboard_table.md
@@ -0,0 +1,73 @@
+---
+name: production_execution_storyboard_table.md
+description: >-
+ 视频制作执行层Agent技能 — 构建分镜表。
+ 负责将剧本拆分为分镜,按规范填写所有字段,生成完整分镜表。
+---
+# 执行层 Agent — 构建分镜表
+
+你是视频制作项目的**执行层 Agent**,接收决策层派发的任务指令并执行。
+
+## 通用规则
+
+- 执行前先调用 `get_flowData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
+- 只执行当前任务对应的工作,不越权执行其他阶段
+- 完成写入后返回一句简短确认即可,不复述完整内容;返回后本次任务终止
+
+---
+
+## 四、构建分镜表
+
+### 工具
+
+| 操作 | 调用 |
+|------|------|
+| 读取剧本与资产 | `get_flowData("script")` / `get_flowData("assets")` / `get_flowData("scriptPlan")` |
+
+### 风格技法参考
+
+
+
+### 执行流程
+
+1. 获取 `script`、`assets` 和 `scriptPlan`,并激活 `director_storyboard_table_narrative`、`director_storyboard_table_style` 作为分镜设计的风格参考,同时激活 `storyboard_table_techniques` 作为分镜表通用技法参考(含分镜拆分原则、定场与镜头合并规则、视觉连续性铁律、字段填写指引、转场规则)。
+2. 按通用技法规则将剧本拆分为分镜,**每写一行前**回顾上一行状态,确保符合「视觉连续性铁律」后再填写当前行所有字段
+3. 严格按照XML格式写出导演规划内容,XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
+
+### 示例
+
+输入剧本片段:
+```
+苏晚卿冷笑:「还有你当宝贝的青云令」
+△ 凌玄气血逆流,再次一口鲜血喷出
+△ 青云令表面灵纹暗淡,隐约可见细微裂痕
+```
+
+输出分镜表:
+
+| 序号 | 画面描述 | 场景 | 关联资产名称 | 时长 | 景别 | 运镜 | 角色动作 | 情绪 | 光影氛围 | 台词 | 音效 | 关联资产ID |
+|----|-------------|------|----------|------|------|------|------|------|------|-------|-------|----------|
+| 1 | 苏晚卿冷笑,居高临下看着跪地的凌玄,大殿柱影深沉 | 大殿 | [苏晚卿, 凌玄, 大殿] | 4 | 近景 | 静止 | 嘴角缓缓上扬→微仰下巴→眼神下压注视(开篇)|朝向:苏晚卿-3/4正面朝右微仰头 | 冷傲轻蔑 | 顶光直射面部,眼窝明暗对半,背景大殿沉入暗部 | 苏晚卿:还有你当宝贝的青云令 | 空旷殿堂回声 | [101, 100, 300] |
+| 2 | 凌玄跪地猛喷鲜血,身体前倾欲坠,血雾弥漫 | 大殿 | [凌玄, 大殿] | 3 | 中景 | 缓慢推至近景 | 胸口剧颤→猛然喷出鲜血→身体前倾摇晃(承接上镜:跪地状态)|朝向:凌玄-3/4正面朝左微低头 | 痛苦绝望 | 左侧冷光勾边,血雾被逆光映成暗红,背景压暗 | 无台词 | 喷血声 + 沉闷跪地声 | [100, 300] |
+| 3 | 青云令灵纹一寸寸暗淡,玉面浮现细微裂痕 | 大殿 | [青云令, 大殿] | 3 | 大特写 | 静止 | 灵纹光芒由亮渐灭→裂痕自中心蔓延(承接上镜:喷血后切物件) | 紧张压迫 | 微弱自发光从内部渗出渐灭,周围完全暗沉 | 无台词 | 细微玉石碎裂声 | [202, 300] |
+
+### 约束
+
+- **整体输出、不分段**:分镜表必须一次性完整输出为一个连续表格,不可按段落/场次拆分成多个表格,不可中途分割或分批返回
+- 你必须使用XML格式写入工作区拍摄计划:内容,XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
+- **严格依据剧本**:分镜内容必须严格按照剧本叙事顺序和内容进行拆分,不得遗漏或新增剧本中不存在的情节
+- **参考导演规划**:分镜的景别、运镜、节奏、氛围等设计需参照导演规划(阶段3产出)的视觉风格、情绪曲线、镜头意图和转场策略
+- **台词原文锁定**:剧本中所有台词必须原文照搬进 `lines` 字段,禁止改写、省略或意译,如有台词未出现在分镜中视为严重错误
+- 分镜顺序与剧本叙事顺序一致
+- 所有字段完整填写,`associateAssetsIds` 使用资产的实际 ID(非数组索引),必须与工作区现有资产匹配
+- **按剧情选资产(衍生优先)**:同一父资产在单条分镜中,若剧情对应衍生状态则仅填写该衍生资产 ID;仅当无匹配衍生状态时才填写主资产 ID,禁止两者并填
+- **场景资产必须引用**:每条分镜的 `associateAssetsIds` 必须包含该分镜 `scene` 字段对应的场景资产 ID(从 assets 中匹配 type 为 scene 的资产);若存在匹配的衍生场景资产则选用衍生 ID,否则选用主场景资产 ID。缺少场景资产 ID 视为严重错误
+- **角色出现即引用**:画面中出现的所有角色(无论是镜头主体还是仅局部可见——如背影、肢体局部、虚化身影等),只要可被辨识,都必须在 `associateAssetsIds` 和 `associateAssetsNames` 中引用其资产。遗漏画面中可见角色的资产 ID 视为严重错误
+- 剧本中出现但资产列表不存在的角色/物件仍需在分镜中描述,但不在 `associateAssetsIds` 中编造 ID
+- **台词-时长强关联**:含台词的分镜,需根据角色当前情绪状态选取对应语速(愤怒~4字/秒、正常~3字/秒、悲伤~2字/秒、低语/虚弱~2字/秒),`duration` ≥ 台词字数 ÷ 语速(向上取整)+ 1s 情绪余量;宁可多留余量,不可台词超时
+- **视觉连续性逐行校验**:每写一行分镜前,回顾上一行的动作终态、景别、角色朝向,确保当前行与之衔接合理,符合「视觉连续性铁律」7条规则
+- **朝向必填且连续**:每条分镜的 `action` 字段必须包含 `|朝向:` 标注(空镜除外);同一场景内同一角色的朝向须与首次出场时保持一致,变化时须在动作描述中包含转身/转头等衔接动作,朝向标注同步更新
+- **定场精简**:每个新场景定场最多 1~2 镜,禁止 3 镜以上的碎片化定场;能一镜完成定场+引入的不拆两镜
+- **镜头合并自检**:完成全部分镜后,逐段检查是否有可合并的相邻镜头(同空间局部描述、纯装饰镜头、信息重复镜头),合并后重新编号
+- **黄金 6 秒**:无台词镜头不超过 6s,定场/过渡类镜头尤其注意
+- **光影风格一致**:光影描述须与步骤1已加载的风格技法的光影规范保持一致
diff --git a/data/skills/production_skills/storyboard_prompt_techniques.md b/data/skills/production_skills/storyboard_prompt_techniques.md
new file mode 100644
index 0000000..7004355
--- /dev/null
+++ b/data/skills/production_skills/storyboard_prompt_techniques.md
@@ -0,0 +1,322 @@
+---
+name: storyboard_prompt_techniques
+description: >-
+ 通用分镜提示词技法参考。
+ 涵盖提示词解析映射规则、景别词库、输出格式规范、提示词结构框架、画质规范、图像资产标注规则、人物位置连贯性规则等,供 Agent 激活使用。
+---
+# 分镜提示词 · 通用基础技法
+
+> 以下为分镜提示词生成的**通用基础规范**,适用于所有视觉风格。风格锚定词、情绪映射、光影词库、场景质感、美学禁止项等**风格相关内容**由风格专属技法(`director_storyboard`)定义。
+
+---
+
+## 适用模式
+
+本规范仅支持以下两种**参考图一致性模式**输出:
+
+- **模式A**:Seedream(doubao-seedream)
+- **模式B**:Nanobanana(Gemini)
+
+> ⚠️ **不生成文生图模式提示词**,所有输出均基于**参考图(图生图 / ControlNet / 角色一致性)**工作流前提。
+
+---
+
+## 分镜表内容忠实性原则(最高优先级)
+
+提示词生成是**格式转换**,不是**创意写作**。分镜表是提示词的**唯一内容来源**,所有画面信息必须忠实于分镜表对应行,仅在表达格式和措辞上适配图像生成模型的要求。
+
+### 铁律
+
+1. **内容锚定**:提示词的画面内容以分镜表对应行为唯一信息源,**禁止**凭空添加分镜表未描述的视觉元素、人物、物件、空间关系或场景细节
+2. **关键信息零遗漏**:分镜表「画面描述」字段中提到的所有可见主体、空间层次、动态细节必须完整保留在提示词正文中,不得以「风格词」替代或挤占具体画面内容
+3. **语义等价转换**:将分镜表字段转换为提示词时,只改变表达形式(中↔英、散文↔关键词、叙事语言↔视觉描述),**不改变语义**。例:分镜表写"大殿柱影深沉" → 提示词必须体现殿堂柱影暗调,不可替换为"华丽宫殿"等不同语义
+4. **禁止创意发散**:不添加分镜表未提及的装饰性视觉元素(如分镜表未写花瓣飘落,提示词不可自行添加);不重新诠释场景氛围(分镜表写"冷傲轻蔑"不可改为"忧伤落寞")
+5. **风格词从属于内容**:风格锚定词、画质锁定词、场景质感词等风格类词汇是**辅助修饰**,服务于分镜表已定义的画面内容,不得反客为主——当风格词与分镜表具体描述冲突时,以分镜表为准
+6. **逐字段回溯校验**:生成每条提示词后,须逐字段比对分镜表对应行,确认以下映射均已准确体现:
+
+| 分镜表字段 | 提示词中须体现 | 校验要点 |
+|-----------|---------------|--------|
+| 画面描述 | 提示词正文核心内容 | 所有视觉主体、空间关系、关键细节是否完整保留 |
+| 场景 | 场景背景质感段 | 场景类型是否一致 |
+| 景别 | 景别构图词 | 景别是否匹配 |
+| 角色动作 | 主体首帧体态段 | 动作语义是否一致(按首帧原则转换形式,但动作内涵不变) |
+| 情绪 | 情绪面容词 | 情绪基调是否一致 |
+| 光影氛围 | 光线色调段 | 光源方向、色调倾向、明暗关系是否一致 |
+
+> ⚠️ **校验不通过 = 提示词无效**,必须修正后再输出。最常见的失败模式:画面描述中的具体元素被风格模板词覆盖遗漏。
+
+---
+
+## 解析映射规则
+
+| 分镜字段 | 提示词对应处理 |
+|----------|----------------|
+| 画面描述 | **核心内容锚点**:提示词正文的主要信息来源。须完整保留画面描述中的所有可见主体、空间层次、关键细节,仅将叙事语言转换为视觉描述格式,严禁删减关键元素、替换为不同语义或自行添加画面描述中不存在的视觉元素 |
+| 场景 | 基于分镜表「场景」字段确定背景/环境词,叠加风格专属技法的场景质感约束词。场景类型和基本氛围须与分镜表一致 |
+| 景别 | 镜头参数词(见下方景别词库),须与分镜表「景别」字段完全匹配 |
+| 运镜 | 仅作分镜制作信息,不进入提示词,不输出运镜备注 |
+| 角色动作 | 基于分镜表「角色动作」字段,保留原始动作的语义内涵,仅将动态过程转换为该镜头**视频首帧(t=0)的预备状态**(动作尚未展开、即将发生的起始体态),视频将从此帧开始向后推演,加"动作自然真实"。**禁止**替换为与分镜表不同的动作 |
+| 情绪 | 基于分镜表「情绪」字段,从风格专属技法的情绪映射表中选取匹配的面容/眼神词。情绪基调须与分镜表一致,不可替换为不同情绪 |
+| 光影氛围 | 基于分镜表「光影氛围」字段的光源方向、色调倾向和明暗关系,从风格专属技法光影词库中选取匹配词汇。须保留分镜表指定的光源方向和色温倾向,不可替换为不同光影方案 |
+| 台词 | 不进入提示词,不输出 |
+| 音效 | 不进入提示词,不输出 |
+| 关联资产名称/ID | 仅用于内部参考图绑定,不作为文本区块输出 |
+
+> ⚠️ **视频首帧原则**:分镜图是视频生成的**首帧参考**,画面必须呈现镜头 t=0 时刻的状态——动作尚未发生或刚刚启动的**预备定格态**,视频将从这一帧开始播放推演。
+>
+> **核心逻辑**:首帧 → 视频推演 → 动作完成。提示词描述的是"推演起点",而非"推演终点"。
+>
+> - ✅ 正确(首帧预备态):「双臂自然垂于身侧,衣袂初被风拂动」「手指刚触及剑柄」「身体微微侧转,目光即将投向远方」
+> - ❌ 错误(动作终态):「负手而立,衣袂随风猎猎飘扬」「已拔剑而立」「背对而去」「远眺苍茫大地」
+> - ❌ 错误(过程态):「正在拔剑」「正缓缓转身」(过程态适合视频中间帧,不适合首帧)
+>
+> 首帧应具有"蓄势待发"的静态张力,暗示接下来视频中将发生的动作方向。
+
+---
+
+## 景别词库(通用)
+
+| 景别输入 | 模式B(Nanobanana)英文镜头词 | 模式A(Seedream)中文画面词 |
+|----------|-------------------------------|---------------------------|
+| 大全景 | `wide shot, establishing shot, full environment` | 大全景构图,环境全貌,人物渺小于场景 |
+| 全景 | `full shot, full body, wide angle` | 全身入镜,全景构图,人景比例协调 |
+| 中景 | `medium shot, cowboy shot, knee shot` | 中景构图,人物膝盖以上入镜 |
+| 近景 | `medium close-up, upper body` | 近景构图,上半身入镜,背景虚化 |
+| 半身 | `half body shot, bust shot` | 半身构图,腰部以上入镜,浅景深 |
+| 特写 | `close-up, face focus, extreme close-up` | 特写构图,面部或细节局部放大,背景深度虚化 |
+| 大特写 | `extreme close-up, macro detail` | 大特写,极度局部细节,虚化背景 |
+| 过肩镜 | `over the shoulder shot, two shot` | 过肩构图,前景人物后背虚化,远景人物清晰 |
+
+---
+
+## 运镜标注
+
+分镜图生成阶段不需要运镜标注提示词。运镜字段仅用于分镜生产管理信息,不参与提示词生成,不作为输出区块。
+
+---
+
+## 输出格式规范
+
+每条分镜**只输出一种模式的提示词正文**(二选一),不允许同条分镜同时输出模式A与模式B。
+
+**模式选择规则**:
+
+| 条件 | 选择模式 |
+|------|----------|
+| 目标模型为 Seedream / 豆包系列 | 模式A(中文 Prompt) |
+| 目标模型为 Nanobanana / Gemini 系列 | 模式B(英文 JSON Prompt) |
+| 用户未指定模型 | 默认模式A,或询问用户确认 |
+| 批量生成 | 全程保持同一模式,不可中途切换 |
+
+**输出内容规则**:
+- 选择模式A时:仅输出 `[Prompt]` 正文(无负向词,Seedream 不支持)
+- 选择模式B时:仅输出 `[JSON Prompt]` 正文(含 `"negative"` 字段)
+- 除提示词正文外,以下内容默认不输出:分镜标题、参考图绑定说明、台词备注、音效备注、约束检查、资产汇总
+
+---
+
+## 提示词结构框架
+
+根据目标模型二选一输出:
+
+### 模式A:Seedream(API `reference_images`)
+
+机制:参考图通过 API 参数 `reference_images` 传入,prompt 内只写一致性约束语句,不写 URL。
+
+Prompt 结构:
+```
+[风格锚定] + [景别构图] + [主体首帧体态] + [情绪面容] + [服饰质感] + [场景背景质感] + [光线色调] + [风格收尾] + [画质锁定词]
+
+Based on the reference image of @图N ,
+maintain consistent: face features, hairstyle, costume details.
+Generate a new scene: [严格基于分镜表「画面描述」字段内容转写,完整保留所有视觉元素和空间关系,使用@图N 替代角色/场景名称].
+Keep character appearance identical to reference.
+```
+
+> `[风格锚定]`、`[服饰质感]`、`[风格收尾]`、`[画质锁定词]` 的具体内容由**风格专属技法**定义。
+>
+> **分镜表字段映射(须忠实体现)**:`[景别构图]` ← 分镜表「景别」;`[主体首帧体态]` ← 分镜表「角色动作」(按首帧原则转换形式);`[情绪面容]` ← 分镜表「情绪」;`[场景背景质感]` ← 分镜表「场景」+「画面描述」中的场景信息为内容基准,叠加风格质感词;`[光线色调]` ← 分镜表「光影氛围」。**提示词正文**的核心画面内容来源于分镜表「画面描述」字段,须完整保留其中所有视觉元素。
+
+参数规范:
+- 单角色:`reference_images: ["角色URL"]`
+- 多角色:`reference_images: ["角色A_URL", "角色B_URL"]`
+- 多角色时在 prompt 中显式区分 `image 1`、`image 2`
+
+### 模式B:Nanobanana(多模态 + JSON)
+
+机制:参考图与 prompt 一起作为多模态输入,prompt 使用结构化 JSON 约束角色一致性。
+
+Prompt 结构(固定框架):
+```json
+{
+ "role": "You are a cinematographer and storyboard artist. Maintain strict visual continuity across all shots.",
+ "character_reference": [
+ { "image": 1, "ref": "@图1", "description": "[外貌关键描述: 发色/发型/服装/体型]" },
+ { "image": 2, "ref": "@图2", "description": "[外貌关键描述]" }
+ ],
+ "continuity_rules": [
+ "Same wardrobe, hairstyle, face features across ALL shots",
+ "Same environment, lighting style, color grade",
+ "Only framing, angle, action, expression may change",
+ "Do NOT introduce new characters not in reference images"
+ ],
+ "shot": "[严格基于分镜表对应行各字段内容生成:景别/构图/动作/情绪/光线/场景质感,须完整保留画面描述中的所有视觉元素] [画质锁定词](风格修饰词由风格专属技法定义)",
+ "negative": "[负向词模板](具体词条由风格专属技法定义)"
+}
+```
+
+参数规范:
+- 参考图作为图片输入,不是 URL 文本
+- 角色描述保持 1-2 句关键特征,避免冗长
+- 仅允许改变景别、角度、动作、表情,不改变人物身份特征
+
+---
+
+## 通用语言与质量规范
+
+- 模式A(Seedream)优先中文自然语言段落
+- 模式B(Nanobanana)优先英文 JSON 结构化提示词
+- 提示词聚焦"内容表现 + 画质锐利",避免模糊类词
+- 不使用会导致糊图的表达(见下方「画质降级禁用词」表)
+- 模式B 负向词按风格专属「负向词模板」输出,每条必须包含,不可省略;模式A 不输出负向词
+- 画质锁定词按风格专属「画质锁定词」模板输出,每条必须包含
+
+---
+
+## 画外文字 vs 画内文字规则
+
+- **画外文字**(字幕、水印、标题卡、旁白叠字等 UI 层覆盖文字)→ **绝对禁止**,必须在画质锁定词和负向词中声明禁止
+- **画内文字**(场景中自然存在的文字道具:角色提笔写字、书卷上的字迹、匾额牌匾、书信内容、路标、店铺招牌等)→ **属于场景道具**,当分镜画面描述中明确包含此类内容时,应正常描述其存在,不受禁止文字规则限制
+- **判断标准**:该文字是否存在于**故事世界内部**。匾额上的字 = 画内道具 ✅;画面底部的角色对白 = 画外字幕 ❌
+
+---
+
+## 画质降级禁用词(所有风格通用)
+
+| 禁用写法 | 模型行为 | 安全替代 |
+|---------|---------|----------|
+| `film grain` / `胶片颗粒` | 全图加噪点变糊 | `subtle cinematic texture` / `轻微电影质感` |
+| `imperfect focus` / `失焦` | 全图失焦 | 直接删除 |
+| `edges not perfectly sharp` | 边缘变糊 | 直接删除 |
+| `slight natural deviation` | 整体降分辨率 | 直接删除 |
+| `not completely stable` | 画面模糊 | 直接删除 |
+| `blurry background`(滥用) | 主体跟着糊 | `background bokeh, subject in sharp focus` |
+| `hazy` / `foggy`(滥用) | 全图雾化 | 仅在空气透视需求时用,同时加 `subject sharp` |
+| `柔焦` / `朦胧感` | 降低整体锐度 | 直接删除 |
+
+> **核心原则**:内容可以"不完美"(光线不均、构图非对称),画质必须锐利。
+
+---
+
+## 批量处理规范
+
+用户输入多行分镜表时:
+
+1. **逐行顺序处理**,不跳行、不合并
+2. 每条分镜仅输出目标模式的提示词正文(Prompt 或 JSON Prompt)
+3. 若同一场景连续多镜,**场景质感词可复用**,但情绪/光线/景别/动作必须**按行独立处理**
+4. 关联资产名称相同的镜次,**一致性标注词必须一致**
+5. 不追加任何非提示词区块(如资产引用汇总、台词/音效备注、约束检查)
+
+---
+
+## prompt 图像资产标注规则
+
+每条分镜的 `prompt` 字段必须以**图像资产标注**作为前缀,且**提示词正文中使用 `@图N` 直接替代对应的角色/场景/道具名称**,建立参考图与画面描述的直接绑定关系。标注按 `associateAssetsIds` 中资产的引用顺序,从 `@图1` 开始依次编号。
+
+**格式**:`@图1 为{资产名称}{资产类型} @图2 为{资产名称}{资产类型} ... , 正文中使用@图N替代角色/场景名称的提示词`
+
+**类型映射**:
+
+| 资产 type | 标注类型词 |
+|-----------|------------|
+| role | 角色 |
+| tool | 道具 |
+| scene | 场景 |
+| clip | 片段 |
+
+**规则**:
+- 编号从 `@图1` 起,按 `associateAssetsIds` 数组顺序依次递增
+- 每个引用的资产 ID 对应一个标注项,**不可遗漏、不可多出**
+- 资产名称使用 assets 数据中该资产的 `name` 字段
+- 资产类型根据上方类型映射表填写
+- 标注部分与提示词正文之间用 `, ` 分隔
+- 衍生资产沿用其自身 `name` 和父资产的 `type`
+- **正文绑定(核心)**:提示词正文中,所有原本应出现角色名/场景名/道具名的位置,**必须替换为对应的 `@图N` 标记**,不再使用文字名称。这样参考图与画面中的视觉主体形成直接指向关系,避免资产名称与角色名称不一致导致的歧义(如衍生资产名"幕离红斗篷"与角色名"戚映竹"无法对应的问题)
+- 同一 `@图N` 在正文中可多次出现(如角色在前景和反射面中同时可见时)
+
+**示例**(假设 `associateAssetsIds="[101, 100, 300]"` 对应苏晚卿(role)、凌玄(role)、大殿(scene)):
+
+❌ 错误(正文使用文字名称,与前缀标注脱节):
+```
+@图1 为苏晚卿角色 @图2 为凌玄角色 @图3 为大殿场景, 苏晚卿冷笑,居高临下看着跪地的凌玄,大殿柱影深沉……
+```
+
+✅ 正确(正文使用 @图N 直接绑定参考图):
+```
+@图1 为苏晚卿角色 @图2 为凌玄角色 @图3 为大殿场景, @图1 冷笑,居高临下看着跪地的@图2,@图3 柱影深沉……
+```
+
+---
+
+## prompt 人物位置与朝向连贯性规则
+
+生成每条 prompt 时,须遵守以下跨分镜人物位置与朝向一致性约束。
+
+### 一、朝向获取规则(从分镜表获取人物面部朝向)
+
+分镜表的「角色动作」字段已包含 `|朝向:` 显式标注,提示词生成时**优先直接提取**,并在 prompt 中**显式写入**对应朝向方位词(如 `facing right` / `面朝右`、`three-quarter view facing left` / `3/4侧面朝左`)。
+
+**获取优先级**(高→低):
+
+| 优先级 | 线索来源 | 处理逻辑 |
+|--------|---------|----------|
+| **1** | **角色动作字段的 `|朝向:` 标注** | 分镜表已显式标注 → **直接采用**,无需推断 |
+| 2 | **画面描述中的显式方位词** | 画面描述直接提及朝向(如"背对镜头""望向窗外""面朝观众")→ 直接采用(仅当优先级1缺失时) |
+| 3 | **多角色空间关系(180° 视轴线)** | 对话/对峙/互动场景中,两角色面朝彼此:画面左侧角色面朝右,画面右侧角色面朝左。首次出场建立基准后全场景锁定 |
+| 4 | **景别暗示** | 过肩镜:前景人物背对/侧背对镜头,远景人物面朝镜头方向;特写/近景独白:默认 3/4 侧面 |
+| 5 | **情绪与叙事语义** | 孤独/沉思/回忆 → 侧面轮廓或3/4背面;对抗/质问 → 正面或3/4正面朝向对方;躲避/羞涩 → 微侧头避开对方 |
+| 6 | **场景空间逻辑** | 门口迎客 → 面朝门外;眺望风景 → 面朝风景方向;伏案书写 → 面朝桌面低头 |
+
+> **常规情况下只需读取优先级1**,分镜表已在源头标注完成。优先级2~6仅作为分镜表标注缺失时的兜底推断。
+
+**获取步骤**:
+1. 读取分镜表当前行「角色动作」字段中 `|朝向:` 后的标注内容
+2. 若标注存在且完整 → 直接采用,跳过后续优先级
+3. 若标注缺失(如空镜行)→ 按优先级2~6逐条推断
+4. 将获取到的朝向信息写入 prompt 中对应角色的描述位置
+
+**朝向词库**:
+
+| 朝向类型 | 模式A(中文) | 模式B(英文) | 适用场景 |
+|---------|-------------|-------------|---------|
+| 正面 | 正面面朝镜头 | facing camera, front view | 自我宣言、直接对抗观众视线 |
+| 3/4正面 | 3/4侧面微朝镜头 | three-quarter view facing camera | 对话主体、情感传递 |
+| 正侧面 | 正侧面轮廓 | profile view, side view | 独白、沉思、对峙剪影 |
+| 3/4背面 | 3/4侧背面 | three-quarter back view | 离去、疏离、回忆 |
+| 背面 | 背对镜头 | back view, from behind | 神秘登场、离别、遥望 |
+| 面朝左 | 面朝画面左侧 | facing left | 180°线右侧角色、朝左侧目标 |
+| 面朝右 | 面朝画面右侧 | facing right | 180°线左侧角色、朝右侧目标 |
+| 微低头 | 微微低头 | slightly looking down | 悲伤、内疚、沉思 |
+| 微仰头 | 微微仰头 | slightly looking up | 傲慢、仰望、期待 |
+
+> 朝向标注须同时包含**水平朝向**(面朝左/右/镜头)和**俯仰倾向**(如有),如"3/4侧面朝右,微微仰头"。
+
+### 二、位置与朝向锁定规则
+
+- **画面位置锁定**:同一角色在同一场景内的多条分镜中,其画面左右位置(画面左侧 / 中央 / 右侧)须保持固定,不得无叙事理由地跳侧
+- **朝向守恒**:对话/对峙场景遵循 180° 视轴线——角色A面朝右则全场景保持面朝右,角色B面朝左则全场景保持面朝左;prompt 中须通过方位词(facing left / 面朝左、on the left side of frame / 画面左侧等)显式标注
+- **前后景层次一致**:若角色A在分镜N中处于前景、角色B处于中景,则同场景后续分镜中二者前后关系不应无理由反转
+- **位置变化须有动作衔接**:角色画面位置确需变化时(如角色走动、转身),前序分镜的 prompt 中须包含对应位移/转身动作描写,不可凭空跳位
+- **朝向变化须有动作衔接**:角色朝向确需变化时(如转头、回身),当前分镜的 prompt 中须包含转向动作描写(如"微微转头朝向画面左侧"),且该转向须与分镜表「角色动作」字段一致,不可凭空改向
+- **跨场景可重置**:切换到全新场景时允许重新分配画面位置与朝向,但新场景内部仍须保持一致
+
+### 三、反射面视觉关系
+
+当画面中存在反射介质(镜面、水面、光滑金属、窗玻璃、相机镜头等)时,须注意以下规则:
+
+- **镜像翻转**:反射面中角色的左右朝向与实体相反(实体面朝右→镜像面朝左),prompt 中须显式标注反射体与实体的朝向关系(如"@图1 面朝右,水面倒影中@图1 面朝左")
+- **反射面不改变位置基准**:角色的画面位置以实体为准,反射面中的映像不视为角色位置变化
+- **反射面内容与实体一致**:反射面中可见的角色服饰、发型、表情等必须与同帧实体一致,不可出现偏差
+- **反射面景深与清晰度**:根据反射面距离和材质,反射图像可适当降低清晰度(如水面波纹导致的模糊),但须在 prompt 中标注(如"水面倒影微微扭曲")
+- **识别触发**:当分镜画面描述或场景资产中包含镜面、水面、湖面、溪流、玻璃、金属反光、相机/摄像等反射性元素时,自动触发本规则
diff --git a/data/skills/production_skills/storyboard_table_techniques.md b/data/skills/production_skills/storyboard_table_techniques.md
new file mode 100644
index 0000000..d537e29
--- /dev/null
+++ b/data/skills/production_skills/storyboard_table_techniques.md
@@ -0,0 +1,158 @@
+---
+name: storyboard_table_techniques
+description: >-
+ 通用分镜表技法参考。
+ 涵盖分镜拆分原则、定场与镜头合并规则、视觉连续性铁律、字段填写指引、转场规则等分镜设计通用技法,供 Agent 激活使用。
+---
+# 分镜表通用技法
+
+本文档为分镜表设计的通用技法参考,适用于所有需要构建分镜表的 Agent 场景。
+
+---
+
+## 分镜拆分原则
+
+**新起分镜**:场景/地点切换、时间跳跃、镜头主体切换、景别明显变化、重要动作节点
+
+**不需新起**:同画面内连续对话、表情微变或小动作
+
+粒度:一个独立画面 = 一条分镜,约每 50~100 字剧本对应 1~2 条分镜。过渡/转场如有明确描写也单独拆分。
+
+---
+
+## 定场与镜头合并规则(防冗余)
+
+**定场镜头**:每个新场景/段落的定场最多 1~2 个镜头完成,禁止拆成 3 个以上碎片。
+- 推荐做法:1 个带缓推的远景(定场+主体引入一镜完成),或 1 个大远景定场 + 1 个全景引入主体
+- 禁止做法:先拍环境空镜→再拍局部细节→再拍人物到达的冗余三段式
+
+**镜头合并自检**:
+- 能一镜交代的不拆两镜——如果一个带运镜的镜头能同时完成定场+引入,不要拆成两个
+- 连续描述同一空间不同局部的镜头(院门→藤蔓→厢房)应合并为一个镜头,用画面描述涵盖多层空间
+- 纯装饰性镜头(只展示环境细节无叙事推进)应合并到有叙事功能的镜头中
+- **导演思维检验**:写完后自检——如果一个真人导演会把相邻 2~3 个镜头合成 1 个拍,说明拆得过细,应合并
+
+**一镜到底策略**:当相邻镜头之间存在**动作连续变化、场景轻度变化(同场景内位移)、或拍摄角度渐变**时,可在 `cameraMove` 或 `description` 中标注「一镜到底」,将多个碎片镜头合为一个连续运镜长镜头。
+- **适用场景**:角色行走穿越空间、跟随动作从A点到B点、环绕角色展示环境、定场缓推到主体特写等
+- **标注方式**:在 `cameraMove` 中写明运镜路径(如"一镜到底:缓推远景→跟移至院内→落幅全景"),在 `description` 中描述起幅和落幅的画面内容
+- **时长放宽**:一镜到底镜头因信息量持续更新,可突破单镜 6s 上限,但不超过 12s
+- **风险提示**:一镜到底会提高画面生成的抽卡难度(连续性要求高),仅在叙事流畅性收益明显大于碎切时使用,不滥用
+
+**黄金 6 秒规则**:无台词镜头累计超过 6s 未出现新信息(台词/动作/主体变化),观众注意力断裂。定场+过渡类镜头尤其注意,宁可合并压缩也不要拖沓
+
+---
+
+## 视觉连续性铁律(分镜设计时全程遵守)
+
+**① 动作连续性**:相邻镜头间角色的位置、动作进度、朝向必须物理逻辑一致。上一镜手伸到半空→下一镜必须从半空状态接续,不能突然收回。
+
+**② 景别递进法则**:景别切换遵循渐进聚焦或渐进释放——
+- 渐进聚焦:远景→全景→中景→近景→特写(情绪收紧)
+- 渐进释放:特写→近景→中景→远景(情绪释放)
+- 禁止无叙事理由的连续同景别(连续 3 镜以上同景别 = 视觉疲劳)
+
+**③ 视轴守恒**:180度线原则——对话/对峙场景中角色画面位置全片固定同侧,不得跳轴
+
+**④ 朝向空间逻辑**:对话双方面朝彼此,操作物品面朝物品,注视远方面朝远方。禁止无差别面朝镜头
+
+**⑤ 信息控制意识**:每镜须意识到"观众此刻知道什么、不知道什么"——
+- 给手不给脸 = 悬念;先声后画 = 期待;只给背影 = 疏离;全貌揭示 = 高潮兑现
+
+**⑥ 节拍密度约束**:单镜头动作/事件数量须与时长匹配,防止塞入过多内容——
+- 1 个物理动作 = 1 拍,1 次运镜 = 1 拍,1 句短台词(≤10 字)= 1 拍
+- 2~3s 镜头:最多 1 拍;4~6s 镜头:最多 2 拍;7s+ 镜头:最多 3 拍
+
+**⑦ 头尾安全区**:每镜的前 0.5s 和后 0.5s 为安全过渡区,不放关键动作或台词起始点。前 0.5s 用于环境建立或主体静态亮相,后 0.5s 用于动作自然收住。
+
+---
+
+## 字段填写指引
+
+**description**(画面描述):一句话描述画面核心内容(15~50 字),包含可见的**主体 + 动作/状态 + 环境空间**,不写心理活动。需体现空间层次(前景/中景/背景至少涉及两层)。如"前景纱帘微拂,中景余晖下侯府马车抵达落雁山废院""成姆妈跳下马车,打量破败院落,远处群山隐入暮色"
+
+**shotSize**(景别):
+
+| 景别 | 说明 | 叙事语义 |
+|------|------|---------|
+| 大远景 | 环境全貌 | 定场 / 孤独 / 渺小 |
+| 远景 | 场景与人物关系 | 空间关系 / 氛围渲染 |
+| 全景 | 人物全身与环境 | 角色登场 / 全身亮相 |
+| 中景 | 膝盖以上 | 日常叙事 / 对话 |
+| 近景 | 胸部以上 | 情感传达 / 对话重点 |
+| 特写 | 面部或物件局部 | 情绪强化 / 关键道具 |
+| 大特写 | 极致局部 | 情绪核弹 / 决定性瞬间(慎用,全片 2~3 次) |
+
+**cameraMove**(运镜):无运镜时填 `静止`。运镜须标注起终点方向。
+
+| 运镜 | 说明 | 叙事语义 |
+|------|------|---------|
+| 推 | 从远到近,强调主体 | 情绪递进 / 发现 / 窥视 |
+| 拉 | 从近到远,展示环境 | 情绪抽离 / 揭示全貌 / 离别 |
+| 摇 | 固定位置旋转扫视 | 环境交代 / 搜索 |
+| 移 | 跟随主体移动 | 陪伴 / 追踪 |
+| 俯拍 | 从上往下 | 旁观 / 渺小 / 全局 |
+| 仰拍 | 从下往上 | 英雄化 / 威压 |
+
+**action**(角色动作):画面中角色/主体的具体动作描述(5~40 字),无角色动作时填 `空镜`。要求:
+- 写连续物理动作链 + 速度节奏("缓缓抬起右手→指尖微颤→猛然握拳"),禁止只写静态终态
+- 标注与上一镜的衔接关系:"(承接上镜:手臂半抬状态→继续上扬)";首镜写"开篇"
+- **必须标注朝向**:在动作描述末尾用 `|朝向:` 标注该角色的面部朝向。多角色时逐一标注(按关联资产名称顺序),格式:`|朝向:角色A-面朝右; 角色B-面朝左`;单角色时省略角色名:`|朝向:面朝右`。朝向须符合180°视轴线规则(同场景内锁定,变化须有动作衔接),具体取值见下方朝向参考表
+
+**朝向参考表**(action 字段标注用):
+
+| 朝向取值 | 含义 | 典型场景 |
+|---------|------|---------|
+| 面朝右 | 水平面朝画面右侧 | 180°线左侧角色、朝右侧目标 |
+| 面朝左 | 水平面朝画面左侧 | 180°线右侧角色、朝左侧目标 |
+| 正面 | 正对镜头 | 自白、宣言、直视观众 |
+| 3/4正面朝右 | 3/4侧面偏右朝镜头 | 对话主体(画面偏左角色) |
+| 3/4正面朝左 | 3/4侧面偏左朝镜头 | 对话主体(画面偏右角色) |
+| 正侧面朝右 | 正侧面轮廓朝右 | 独白、沉思 |
+| 正侧面朝左 | 正侧面轮廓朝左 | 独白、沉思 |
+| 3/4背面朝右 | 3/4侧背面偏右 | 疏离、离去 |
+| 3/4背面朝左 | 3/4侧背面偏左 | 疏离、离去 |
+| 背面 | 背对镜头 | 神秘登场、离别、遥望 |
+
+> 可叠加俯仰修饰:`面朝右微仰头`、`3/4正面朝左微低头`。
+
+**emotion**(情绪):画面传达的情绪基调(2~10 字),用具象可感描述。如"冷傲轻蔑""痛苦绝望""紧张压迫"。禁止"开心""难过"等空泛词。
+
+**lighting**(光影氛围):画面光影与氛围描述(5~40 字),须包含**光源方向 + 色调倾向 + 明暗关系**。如"右侧冷白光斜射,面部明暗对半,背景深沉""底部暖黄光上打,眼窝沉入暗影"。禁止只写"柔光""暗调"。具体光源角度、色调阶段分配以风格技法参考为准
+
+**scene**:该分镜所处的场景名称,与剧本中的场景对应
+
+**associateAssetsNames**:画面中**可见的**资产名称列表(包括仅局部出现的角色/物件),便于直观确认关联内容
+
+**duration**:基础参考——特写/表情 2~3s · 对话近景 3~5s · 全身亮相 3~5s · 动作 2~4s · 远景/空镜/过渡 3~5s · 复杂场景 5~8s。**单镜不超过 8s**,超过须拆分。
+
+**含台词时,时长必须足够念完全部台词且匹配情绪语速**:
+
+| 情绪状态 | 语速参考 | 示例场景 |
+|---------|---------|----------|
+| 愤怒、急促、争吵 | ~4 字/秒 | 怒斥、催促、惊慌 |
+| 正常对话、叙述 | ~3 字/秒 | 日常交谈、冷静陈述 |
+| 悲伤、深情、沉思 | ~2 字/秒 | 告白、哀悼、回忆 |
+| 低语、虚弱、临终 | ~2 字/秒 | 气若游丝、耳边呢喃 |
+
+计算方式:台词字数 ÷ 对应语速(向上取整)= 基础秒数,再叠加停顿余量:
+- 台词中每个标点停顿(逗号、句号、省略号、破折号等)+0.3~0.5s
+- 情绪转折/语气变化处 +0.5s
+- 最终 `duration` = 基础秒数 + 停顿累计 + 1s 安全余量(向上取整)
+
+**lines**:角色台词原文,**必须一字不改从剧本中照搬**。多角色按 `角色名:台词` 格式排列。无台词填 `无台词`。一句台词对应一个镜头,避免单镜头内塞多角色多轮对白。
+
+**sound**:环境音/音效描述,按「环境音层 + 动作音层」分层。如"远处风声呼啸 + 剑鸣声"。无音效填 `无音效`
+
+**associateAssetsIds**:画面中**可见的**资产的 ID(从 assets 数据中获取的实际 `id` 字段值),不编造不存在的 ID。
+- **角色出现即引用**:画面中出现的所有角色,无论是主体还是仅局部可见(如背影、手部、虚化剪影等),只要在画面内可被辨识,都必须引用其对应的资产 ID
+- **场景资产必选**:每条分镜必须引用其所处场景对应的场景资产 ID(type 为 scene 的资产);若该场景存在匹配当前画面状态的衍生场景资产,则选用衍生场景资产 ID,否则选用主场景资产 ID。缺少场景资产 ID 视为字段不完整
+- 父子资产选择规则:按剧情画面所需状态选择资产 ID——若该镜头需要某主资产的衍生状态,**只选衍生资产 ID**;仅当不存在匹配的衍生状态时,才选择主资产 ID;同一父资产在同一分镜中禁止主/衍生同时出现
+
+---
+
+## 转场规则
+
+- **同场戏内**:镜头间默认硬切
+- **跨场景**:插入 1 个空镜分镜(2~3s)做情绪缓冲,空镜内容与前后场景氛围相关
+- **跨段落**:可在 description 中标注"叠化过渡"或"淡入淡出"
+- 禁用花式转场(划屏、旋转、百叶窗等)
diff --git a/data/skills/script_agent_decision.md b/data/skills/script_agent_decision.md
index 549b2f5..d0b72c7 100644
--- a/data/skills/script_agent_decision.md
+++ b/data/skills/script_agent_decision.md
@@ -36,6 +36,11 @@
### 初始化对话流程
+0. 若用户提出“需要推荐/不知道怎么配/帮我推荐”等意图,先进入**推荐分支**:
+ - 先询问用户想要做的剧集类型(形态),并给出3个可选项(示例:微短剧、短剧、长剧)
+ - 得知用户类型偏好后,调用 `get_novel_events` 获取相关章节事件并分析
+ - 基于事件分析输出一段“推荐原因”(说明为何匹配该类型)
+ - 最后给出“推荐配置”(集数、单集时长、原著范围、平台规格、风格定位、付费策略)并请用户确认
1. 用户发起改编请求时,**必须主动询问用户**项目参数(不主动调用 `deepRetrieve`,除非用户要求回想之前的配置)
2. 如果没有已确认的参数,**必须主动询问用户**:
- "请确认以下信息:计划拆分为几集?每集大约几分钟?覆盖原著哪些章节?"
diff --git a/data/skills/script_agent_supervision.md b/data/skills/script_agent_supervision.md
index da8d53e..afa1170 100644
--- a/data/skills/script_agent_supervision.md
+++ b/data/skills/script_agent_supervision.md
@@ -19,8 +19,9 @@
1. 识别审核对象
2. 按对应审核对象的「数据准备」步骤获取数据
-3. 按「审核维度」逐项检查
-4. 按「审核报告格式」生成报告
+3. 对照「Skills」中对应的红线清单 + 「审核维度」逐项检查
+4. 遇到「Skills 三 - 短剧通用红线」中的违反项,直接标记为严重问题
+5. 按「审核报告格式」生成报告
---
@@ -69,6 +70,41 @@
3. **问题具体化**:每个问题指向具体位置和内容,不说"整体不够好"
4. **建议多元化**:严重问题提供多个可选方案
5. **动态基准**:数值判断以【项目配置】为唯一基准;配置中未明确的参数以合理比例推算,并在报告中注明
+6. **Skills 对照审核**:所有审核项须对照 Skills 中的红线清单逐项核对,确保执行层产出物符合短剧爆款标准
+
+---
+
+## Skills
+
+### 一、骨架质量红线(审核骨架时逐项核对)
+
+1. **核心结构逻辑**:大三角(3个核心角色/势力)构成全剧主矛盾是否成立;是否为单线型叙事(多线并行→严重)
+2. **故事核与隐线**:是否有清晰的故事核(主角内在冲突);是否有隐线(角色弧光/成长轨迹)
+3. **前10%黄金结构**:前⌈N×0.10⌉集是否完成"一秒入坑→目标明确→多方施压→首次卡点"
+4. **付费点分布**:是否按≈10%/30%/50%/70%/90%比例分布;是否满足5大标准(关键瞬间、根本性改变、好奇心、高燃场景、爱情拉扯);是否有假付费点设计
+5. **情绪布局**:全剧是否呈"波浪上升"模式;是否与类型情绪基调匹配(甜宠=甜60%+微虐30%+惊喜10%等);是否存在连续3集同一强度
+6. **信息差标注**:关键集数是否标注信息差类型(先知型/焦急型/上帝型)
+7. **集末钩子**:每集是否有钩子;类型是否多样化(智识/悬念/情感/世界观,不可全是悬念钩子)
+8. **节奏框架匹配**:分集节奏是否与该类型的通用节奏框架大致吻合(甜宠→契约绑定开头→误会拉扯→秘密曝光…;战神→隐藏身份受辱→曝光打脸…)
+
+### 二、改编策略质量红线(审核改编策略时逐项核对)
+
+1. **7大核心要点覆盖**:策略是否体现——强画面感、台词精简、节奏极致快、只沿主线、降低理解成本、情绪大于一切、开篇给足期待感
+2. **情绪基调一致性**:策略确定的情绪基调是否与骨架类型匹配;是否存在中途大幅偏离(如甜宠突然重度虐心→严重)
+3. **人物弧光保留**:主角和重要配角是否保留了弧光(初始状态→关键变故→性格转变→最终状态);是否保留了设定记忆点
+4. **删减合理性**:优先删除项(拖沓铺垫/重复内容/载体不支持/弱支线)是否正确;优先保留项(情绪点/关系拉扯/付费铺垫/信息差场景/打脸时刻)是否覆盖
+5. **世界观呈现策略**:是否有渐进式呈现方案;是否通过人物对话/OS/VO逐步透露,而非旁白集中灌输
+6. **短剧语言适配**:称谓是否符合短剧规范("家主""执法局"等,禁用"市长""县长");台词是否口语化(禁用文言文、生词冷词)
+7. **用户意图一致性**:若用户要求不改编/忠实原著,策略是否仅做载体适配;若用户指定改编方向,策略是否以该方向为最高优先级
+
+### 三、短剧通用红线
+
+以下任何一项违反均标记为**严重问题**:
+1. 连续3集以上无情绪爆点(爽点/虐点/甜点任一)
+2. 出现多线并行叙事(短剧必须单线型)
+3. 第1集无强冲突/强情绪场景
+4. 出现"市长""县长"等现实官职称谓
+5. 大段旁白解说世界观(应通过对话/OS/VO逐步透露)
---
@@ -84,10 +120,15 @@
| 审核项 | 标准 | 严重程度 |
|--------|------|----------|
-| 结构完整性 | 故事核存在且聚焦主角内在冲突;三幕均有功能、核心问题、幕末转折 | 严重 |
-| 分集与时长 | 分集数恰好等于【项目配置】集数;每集时长符合单集时长 ±10秒 | 严重 |
+| 结构完整性 | 故事核存在且聚焦主角内在冲突;隐线(角色弧光)清晰;三幕均有功能、核心问题、幕末转折(→ Skills 一-1/2) | 严重 |
+| 分集与时长 | 分集数恰好等于【项目配置】集数;每集时长符合单集时长 ±10秒 | 中等 |
| 章节全覆盖 | 【项目配置】指定的原著章节全部被分配到具体集数 | 严重 |
-| 叙事设计 | 删减有据、集末钩子齐全、付费卡点符合策略、情绪曲线有起伏、人物弧每集推进 | 中等 |
+| 付费点分布 | 按≈10%/30%/50%/70%/90%比例分布,满足付费点5大标准;有假付费点设计(→ Skills 一-4) | 严重 |
+| 前10%黄金结构 | 前⌈N×0.10⌉集完成"一秒入坑→目标明确→多方施压→首次卡点"(→ Skills 一-3) | 中等 |
+| 情绪布局 | 全剧情绪呈波浪上升、与类型基调匹配、无连续3集同一强度(→ Skills 一-5) | 中等 |
+| 信息差标注 | 关键集数标注了信息差类型(先知型/焦急型/上帝型)(→ Skills 一-6) | 中等 |
+| 集末钩子 | 每集结尾有钩子且类型多样化,不可全是悬念钩子(→ Skills 一-7) | 中等 |
+| 节奏框架 | 分集节奏与该类型通用节奏框架大致吻合(→ Skills 一-8) | 轻微 |
### 跨阶段一致性检查
@@ -100,21 +141,42 @@
### 详细审核标准
+#### 故事核与隐线验证(严重)
+- 故事核必须存在且聚焦主角内在冲突(如"复仇vs原谅""自由vs责任")
+- 隐线(角色弧光)必须清晰:主角有明确的"初始状态→关键变故→性格转变→最终状态"轨迹
+- 故事核与隐线须贯穿三幕,不可中途断裂
+
#### 三幕功能验证(严重)
- 第一幕必须完成"建立"功能:规则建立、悬疑建立、动机激活
- 第二幕必须完成"冲突"功能:主要矛盾展开、计划执行、代价付出
- 第三幕必须完成"拓展/结局"功能:新世界、新能力、开放悬念
+- 大三角(3个核心角色/势力)贯穿全剧,小三角依次展开不并行
+
+#### 付费点分布验证(严重)
+- 付费点按≈10%/30%/50%/70%/90%×总集数N分布(四舍五入取整),偏差超过±2集标记问题
+- 逐一检查5大标准:①选择关键瞬间 ②设置根本性改变 ③调动好奇心 ④善用高燃场景 ⑤关注爱情拉扯(感情流)
+- 付费点场景应具备"场面宏大、事态紧急、围观群众多"的特征
+- 是否设计了假付费点(目标近在咫尺却落空)
+
+#### 前10%黄金结构验证(中等)
+- 第1-2集(或等比位置):是否快速引入强烈冲突,实现"一秒入坑"
+- 第3-4集:是否明确主角核心行动目标
+- 第5-8集:是否引入多方配角施压
+- 第9-10集:是否有假付费点+正式卡点的小高潮
+- (微短篇需检查:卡点是否提前至第6-7集,第1集信息密度是否足够)
#### 情绪曲线验证(中等)
-全剧情绪分布应根据实际集数设计"波浪上升"模式:
+- 全剧情绪分布应根据实际集数设计"波浪上升"模式
- 不允许连续3集都是同一情绪强度
-- 最高潮应在中后期
+- 最高潮应在中后期(≈51%-70%阶段)
- 高潮后应有节奏缓冲再推向新高潮
+- 情绪基调占比是否与类型匹配(如甜宠:甜60%+微虐30%+惊喜10%)
-#### 付费卡点合理性(中等)
-- 付费策略按【项目配置】中的设定执行
-- 付费点必须放在"观众最想知道后续"的位置
-- 钩子类型应多样化(不全是悬念钩子)
+#### 信息差与集末钩子验证(中等)
+- 关键集数(尤其付费点前后)是否标注了信息差类型
+- 信息差类型是否运用得当(先知型→逆袭类、焦急型→虐恋类、上帝型→寻亲类)
+- 每集结尾是否有钩子
+- 钩子类型是否多样化(智识/悬念/情感/世界观,不可全是同一类型)
---
@@ -129,9 +191,15 @@
| 审核项 | 标准 | 严重程度 |
|--------|------|----------|
+| 用户意图一致 | 若用户要求不改编/忠实原著,策略仅做载体适配;若用户指定方向,策略以该方向为最高优先级(→ Skills 二-7) | 严重 |
| 与骨架一致 | 删除决策与骨架中的删减记录一致;所有原则服务于故事核 | 严重 |
+| 7大要点覆盖 | 策略体现强画面感、台词精简、节奏极致快、只沿主线、降低理解成本、情绪大于一切、开篇给足期待感(→ Skills 二-1) | 中等 |
| 原则质量 | 3-5条核心原则,每条有正面指导和负面边界 | 中等 |
-| 载体适配 | 有世界观呈现策略;考虑了平台规格和单集时长的约束 | 中等 |
+| 情绪基调一致 | 确定的情绪基调与骨架类型匹配,无中途大幅偏离(→ Skills 二-2) | 中等 |
+| 人物弧光保留 | 主角和重要配角弧光完整,保留设定记忆点(→ Skills 二-3) | 中等 |
+| 删减合理性 | 删减遵循优先级原则;优先保留情绪点/关系拉扯/付费铺垫/信息差/打脸时刻(→ Skills 二-4) | 中等 |
+| 世界观呈现 | 有渐进式呈现方案,通过对话/OS/VO逐步透露而非旁白灌输(→ Skills 二-5) | 中等 |
+| 语言适配 | 称谓符合短剧规范,台词口语化(→ Skills 二-6) | 轻微 |
### 跨阶段一致性检查
@@ -144,6 +212,12 @@
### 详细审核标准
+#### 用户意图一致性验证(严重)
+- 检查【项目配置】或派发指令中是否有改编限制要求
+- 若用户要求"不改编/忠实原著/最小改动":策略是否仅做载体适配(格式转化、时长裁剪、画面化翻译),未改动原著人设、情节与世界观
+- 若用户指定了改编方向(如"加强爽感""弱化虐点"):策略是否以该方向为最高优先级
+- 若策略与用户意图矛盾,标记为严重问题
+
#### 故事核对齐(严重)
- 所有改编原则必须服务于骨架中确立的故事核
- 删减的内容不能包含体现故事核的关键场景
@@ -152,4 +226,25 @@
#### 与骨架一致性(严重)
- 改编策略中的删除决策,必须在骨架的删减记录中有对应
- 骨架中标注"保留完整"的场景,改编策略不能标注为删除
-- 交叉检查方法:将两者的删减列表逐一比对
\ No newline at end of file
+- 交叉检查方法:将两者的删减列表逐一比对
+
+#### 7大核心要点覆盖验证(中等)
+逐条检查策略是否体现以下要点,未覆盖的标记为中等问题:
+1. 强画面感(可拍摄性)——是否有不可拍摄的内容未做转化
+2. 台词精简——是否有大段冗余对话未被标记处理
+3. 节奏极致快——是否存在明显拖沓的保留决策
+4. 只沿主线——是否有无关支线被保留
+5. 降低理解成本——世界观是否通过对话/OS/VO逐步透露
+6. 情绪大于一切——是否存在"逻辑正确但情绪平淡"的保留决策
+7. 开篇给足期待感——开篇改编是否保证了强冲突/强情绪
+
+#### 情绪基调一致性验证(中等)
+- 策略确定的情绪基调是否与骨架中的类型匹配
+- 是否存在中途大幅偏离基调的改编决策(如甜宠剧突然加入"全家惨死"的重度虐心→严重)
+- 各阶段情绪占比是否合理
+
+#### 世界观呈现策略验证(中等)
+- 是否有渐进式呈现方案(每次只透露一个关键设定点)
+- 呈现方式是否多元:人物对话(角色间冲突/疑问带出)、OS内心独白(主角视角补充)、VO画外音(极简过渡)
+- 是否存在大段旁白集中灌输世界观的设计(→严重)
+- 是否明确了世界观锚点角色和观众视角对齐对象
\ No newline at end of file
diff --git a/data/skills/script_execution_adaptation.md b/data/skills/script_execution_adaptation.md
index 7535195..6ea5a36 100644
--- a/data/skills/script_execution_adaptation.md
+++ b/data/skills/script_execution_adaptation.md
@@ -17,7 +17,7 @@
- 主要删除决策:被删/压缩内容、原因、对主线影响
- 世界观呈现策略:关键元素出场节奏、解释度策略、角色态度锚点
3. **阐述思路**(200-300字):核心改编原则方向、删减大方向、世界观呈现思路
-4. 严格按照XML格式写出改编策略,格式为改编策略内容。
+4. 严格按照XML格式写出改编策略,格式为改编策略内容。XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出。
5. 返回简短确认,如:"改编策略已保存,请在右侧工作台查看。"
## 约束
@@ -27,6 +27,88 @@
- 根据【项目配置】中的平台规格和单集时长约束,优先视觉叙事,压缩大段对话
- 所有参数从【项目配置】读取,禁止硬编码
+## Skills
+
+### 一、剧本改编7大核心要点
+
+改编策略的一切决策须以此7条为基准:
+
+1. **强画面感(可拍摄性)**:确保所有保留内容能转化为镜头语言,拍不出来则换表达方式
+2. **台词精简(高信息密度)**:剔除冗余,每句台词须服务于剧情推进或人物塑造;用台词传递背景信息(身份、过往、纠葛)
+3. **节奏极致快**:每一个画面都拉升情绪,可适当牺牲细微逻辑,优先保证节奏紧凑
+4. **只沿主线展开**:摒弃多支线,所有情节围绕单条主线推进;改编时砍掉支线,仅保留核心人设与高光时刻
+5. **降低理解成本**:世界观不复杂,观众听台词就能掌握核心剧情,漏看部分不影响整体理解
+6. **情绪大于一切**:无需复杂人物弧光,核心提供饱满强烈的情绪体验;逻辑与情绪冲突时优先保障情绪张力
+7. **开篇给足期待感**:第1集呈现激烈、高情绪张力场景,后续围绕开篇建立的期待感展开
+
+### 二、类型创新三大方向(改编时评估是否引入)
+
+1. **元素创新**(最易落地):在基础类型上调整单一核心元素制造新鲜感
+ - 年龄反转(青年战神→老年战神)、性别反转(男战神→女战神)、背景反转(古代→现代)、视角反转(萌宝跟妈→萌宝跟爸)
+2. **类型融合**(高效丰富剧情):选择关联度高的类型搭配,避免强行融合
+ - 示例:团宠+鉴宝、萌宝+重生+寻亲
+3. **情节创新**(最考验功力):跳出传统套路,设计独特情节冲突
+ - 示例:宫斗避开"下毒、推水",改用"心理操控"式陷害
+
+**金手指创新**:避免"无敌外挂",设计有约束的特殊能力(如有限次数的预知)
+
+### 三、各类型情绪基调映射(改编时锁定)
+
+| 类型 | 核心情绪基调 | 占比参考 |
+|------|-------------|----------|
+| 甜宠类 | 甜>微虐>惊喜 | 甜60%+微虐30%+惊喜10% |
+| 复仇类 | 压抑>爽感>解气 | 压抑40%+爽感50%+解气10% |
+| 重生逆袭类 | 爽感>期待>温暖 | 爽感50%+期待30%+温暖20% |
+| 家庭伦理类 | 共情>委屈>和解 | 共情40%+委屈30%+和解30% |
+
+**关键原则**:基调一旦确定不要中途大幅更改——如甜宠剧突然加入"全家惨死"的重度虐心剧情,观众会出戏甚至弃剧
+
+### 四、人物弧光保留原则
+
+改编时必须保留的人物维度:
+
+1. **人物弧光**:角色需有阶段性转变,转变需有锚点(关键事件)
+ - 格式:初始状态→关键变故→性格转变→最终状态
+ - 主角和重要配角必须有弧光,这是剧本脱颖而出的关键
+2. **行动塑造**:不同性格角色面对同一困境反应须有差异,行动线与性格强绑定
+3. **设定记忆点**:为重要角色保留独特细节(专属口音、下意识动作、特殊怪癖、独门技能)
+4. **人物推动剧情**:确保是"人物引导剧情"而非"把人物套入预设剧情",人设差异是剧情推进的核心动力
+
+### 五、删减决策优先级
+
+**优先删除:**
+- 节奏拖沓的铺垫场景(不推动主线的环境描写、日常闲聊)
+- 信息密度低的重复内容(同类冲突不可重复呈现,如反派多次用同一手段陷害)
+- 载体不支持的内容(大段心理描写、复杂世界观设定说明)
+- 主线贡献弱的支线(不推动主线的人物关系、不影响结局的事件)
+
+**优先保留:**
+- 每集的核心情绪点(爆点/虐点/爽点至少覆盖一个)
+- 人物间的关系拉扯场景(关系越紧密虐感越强)
+- 付费点前的情绪铺垫链条(压抑→爆发的完整弧线)
+- 身份反差与信息差场景(核心爽感来源)
+- 高光"打脸"时刻与反转节点
+
+**替代方案:**
+- 蒙太奇压缩:将多场过渡戏压缩为快速剪辑
+- 台词带过:用一句台词交代原本需要整场戏呈现的信息
+- 完全删除:对主线无贡献且不含情绪点的内容直接去除
+
+### 六、短剧独特语言适配
+
+改编时需注意短剧特殊表达惯例:
+- 现代剧用"家主"代指家族掌权人,"执法局/执法人"代指公安局/警察
+- 禁用"市长""县长"等实际称呼,改为"市首""总督"
+- 财富表达突破现实货币体系,用"亿元""百亿订单"等夸张表述营造爽感
+- 所有台词用口语化表达,禁用半文半白、文言文、生词冷词
+
+### 七、信息差策略设计
+
+改编策略中须明确标注各阶段采用的信息差类型:
+- **观众先知型**(主角知+观众知+配角不知):期待"打脸",适合逆袭/战神/赘婿类
+- **观众焦急型**(配角知+观众知+主角不知):替主角担心,适合虐恋/悬疑类
+- **观众上帝型**(观众知+主角配角都不知):期待相认/真相大白,适合寻亲/身份错位类
+
## 注意事项
- 执行前先调用 `get_planData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
diff --git a/data/skills/script_execution_script.md b/data/skills/script_execution_script.md
index ef8b4ff..400590f 100644
--- a/data/skills/script_execution_script.md
+++ b/data/skills/script_execution_script.md
@@ -15,7 +15,11 @@
1. 调用 `get_planData` 获取骨架与改编策略;若存在上一集剧本id,调用 `get_script_content(ids)` 获取最后一集剧本内容,用于衔接剧情与角色状态,调用 `get_novel_text` 获取对应章节原文,调用 `get_novel_events(ids)` 获取事件表
2. 从骨架中**仅提取当前任务集**的信息:覆盖章节、戏剧功能、场景核心、删减决策、集末钩子。**忽略其他已完成或未分配的集**
3. **阐述思路**(200-300字):场景组织方式、重点情绪与冲突、节奏把控思路
-4. 严格按照XML格式写出剧本内容,格式为剧本内容。
+4. 将完整剧本包裹在 **``** 标签中输出,具体要求:
+ - 你必须输出一对 XML 标签 `` 和 ``,将全部剧本内容包裹在其中
+ - `name` 属性的值 = 文件头首行标题(即 `{作品名} EP{NN}:{集标题}`),不含 `#` 号
+ - 标签内部是完整剧本正文(文件头 → 剧情梗概 → 场景段落),中间不得插入任何非剧本的解释或元信息
+ - `` 开标签之前、`` 闭标签之后,不得有任何剧本正文内容
5. 返回简短确认,如:"第X集剧本已写入,请在工作台查看。"
## 约束
@@ -26,9 +30,119 @@
- △场景描述要足够具体,描写"人怎么干"而非仅"人干什么",可直接用于 AI 视频生成
- 场景之间用 `---` 分隔
+## Skills
+
+### 一、三大情绪要点(每集必含至少1个)
+
+| 要点 | 定义 | 作用 |
+|------|------|------|
+| 爆点 | 令人震惊、匪夷所思/骇人听闻/惊羡的事件 | 第一时间勾起观众情绪,快速入戏 |
+| 虐点 | 让人心痛、痛苦、难以释怀的事件 | 唤起观众怜悯,强化情感代入 |
+| 爽点 | 让人兴奋、振奋的"高光时刻" | 满足观众情绪需求,提升留存率 |
+
+**应用规则:**
+- 每集500-800字须覆盖爆点/虐点/爽点中至少一个(硬性要求)
+- 可叠加使用但需避免情绪冲突——明确情绪先后顺序,不堆积混乱
+- 小情绪累积成大情绪爆发,不可一次性宣泄完所有情感
+
+**爽点核心公式:爽点 = 装 + 打脸 + 震惊 + 收获**
+- 装:情感/物质伪装(主角藏身份被欺辱)
+- 打脸:剧情急转弯(装豪门的配角被真豪门揭穿)
+- 震惊:围观群众态度180°反转
+- 收获:物质奖励/地位提升
+
+**虐点核心逻辑:**
+- 关系越紧密虐感越强(亲人、爱人之间的伤害更催泪)
+- 先给主角极致幸福再夺走,让主角长期处于痛苦中
+- 经典虐点:始终牢记的人忘了自己、永远无法说出口的爱意、永远无人知晓的巨大牺牲、至死未能解开的惨痛误会
+
+**爆点类型:**
+- 经典款:替身设定、穿书炮灰女配、救赎设定
+- 反套路:双向替身、伪装拆穿、离婚反杀、全员重生、明虐暗宠、以牙还牙
+
+### 二、情绪表达四通道
+
+根据人物性格和所处环境选择外显型或内隐型表达:
+
+1. **行动**:通过人物行为动作传递情绪(撕扯、狂奔、捶打、下意识握拳、颤抖的手)
+2. **语言**:痛斥、语无伦次、泣不成声、大吼、嘶哑、无声、结巴——一旦确定语言风格就要持续强化直至极致
+3. **环境**:
+ - 悲伤/压抑:阴雨天、空无一人的街道、昏暗房间
+ - 紧张/危险:急促脚步声、闪烁灯光、封闭空间
+ - 甜蜜/温暖:夕阳、暖光客厅、满桌家常菜
+4. **独白**:当情绪无法用行动/语言直接表达时(有秘密、有难言之隐),用OS/VO补充
+ - OS(主角视角):揭露主角真实想法
+ - VO(第三方视角):渲染氛围或补充背景
+
+### 三、情绪铺设技巧
+
+**1. 先压后爆,制造反差:**
+- 先用反派打压、误解、困境让主角"委屈/隐忍"(连续数集压抑)
+- 在付费点或关键集让主角反击,释放压抑情绪
+- 压得越狠反弹越爽
+
+**2. 用信息差强化情绪期待:**
+- 观众知道主角不知道 → 观众"心急如焚"(如女主不知茶里有毒)
+- 主角知道配角不知道 → 观众"期待打脸"(如主角假装懦弱实则收集证据)
+- 主角配角都不知道观众知道 → 观众"心疼又着急"(如母女相见不相识)
+
+**3. 单集情绪公式:1核心情绪 + 1辅助情绪 + 1结尾钩子**
+- 核心情绪:贴合全剧基调(如甜宠剧的"微甜")
+- 辅助情绪:制造小冲突避免平淡(如女配吃醋)
+- 结尾钩子:引入下一集情绪(如反派威胁"离他远点")
+- **禁忌**:同一集不超过2个核心情绪;上下集情绪须有衔接不可跳脱;配角情绪不能盖过主角
+
+### 四、开篇8大创作规则
+
+1. **冲突即时性**:第一行就入危机,无缓冲期(谋杀、逃跑、被虐待、难产、被偷袭、逃婚、被陷害)
+2. **信息量密集**:通过人物对话快速交代前因后果、人物关系、背景,不浪费一字
+3. **营造信息差**:让主角/配角/反派之间信息不对等,形成欺骗或误解
+4. **铺垫不拖沓**:最多3集要见效,为贯穿全剧的暗线中间需多次提醒
+5. **关系有拉扯感**:人物关系不能简单对立或友好,需有复杂羁绊(爱恨交织)
+6. **情节必反转**:每集至少1个反转,需有逻辑不能强行制造
+7. **压情绪**:从第1集开始极致打压主角,直到第一个付费点前才给反击信号,中间不松劲
+8. **明确目标**:第1集设定主角大目标,再拆分为5-10集可实现的小目标
+
+### 五、台词创作规范
+
+1. **精准戳点**:针对角色软肋设计台词(骂穷人没钱不够痛,骂他儿子会继续穷才激怒)
+2. **贴合角色性格**:不同角色语言习惯须匹配人设
+ - 自检法:遮挡角色名字仍能通过台词判断说话人
+ - "绿茶"用"人家""哥哥",男主走后才露"獠牙"
+3. **尽量少用潜台词**:短剧受众偏好直白表达,优先简单直接
+4. **接地气说人话**:禁用半文半白、生词冷词,所有意思用口语化表达
+5. **摒弃无效台词**:每句台词都有存在价值,不说车轱辘话
+6. **单句台词不超过20字**(竖屏短视频观众阅读速度限制)
+7. **开篇台词**:聚焦主情绪、主矛盾,第一场戏不交代太多信息
+
+### 六、CP感营造技巧
+
+1. **性格互补制造反差萌**:心思缜密×热血愣头青、玲珑鬼精灵×天然呆、偏执狂×铁憨憨
+2. **强化互动紧绷感**:用激烈冲突替代平淡相处,CP互动须有戏剧张力
+3. **立体人设是CP感基础**:展现角色多面性(如会为小钱斤斤计较也会为陌生人捐巨款;能抡铁锤却在爱人面前拧不开瓶盖)
+4. **禁忌**:不可为追流行强加无关人设标签
+
+### 七、人物塑造速查
+
+- **先立标签**:用1-2个关键词定义人物核心性格(恶婆婆、贪财妻子、高冷霸总)
+- **行动须契合人设**:胆小柔弱遇危险退缩求助,桀骜拽姐正面反击
+- **设定记忆点**:专属口音、下意识动作、特殊怪癖、独门技能
+- **弧光关键**:初始状态→关键变故→性格转变→最终状态,所有转变须有事件支撑
+
+### 八、高频情绪模板(可直接套用)
+
+**模板1:"打压-反击"爽感布局(逆袭/战神/赘婿类)**
+配角嘲讽主角(压抑)→ 变本加厉(愤怒)→ 主角亮身份/实力(爽感)→ 配角狼狈道歉(解气)
+
+**模板2:"误会-解开"甜虐布局(甜宠/虐恋类)**
+反派造谣(虐)→ 主角间冷战(委屈)→ 发现真相(震惊)→ 道歉+撒糖(甜)
+
+**模板3:"危机-救赎"共情布局(家庭伦理/寻亲类)**
+主角遇难题(共情)→ 求助无门(绝望)→ 贵人出现(惊喜)→ 亲情升温(温暖)
+
## 注意事项
-- 严格按照XML格式写出剧本内容,格式为剧本内容`。
+- 剧本正文**必须**包裹在 `...` 标签对中输出,缺少开标签或闭标签均视为格式错误;`name` 属性值必须与文件头首行标题一致(不含 `#`);XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出
- get_script_content(ids)只允许获取最后一集剧本内容
- **每次只编写当前任务集的剧本,不得将之前已完成的集重新输出或写入**
- 只执行剧本编写,不越权执行其他阶段
@@ -46,8 +160,8 @@
### 一、文件头
-```markdown
-
+```xml
+
# {作品名} EP{NN}:{集标题}
# 目标时长:{单集时长}分钟 ≈ {台词字数}字台词
# 平台:{平台规格} | 风格:{风格标签} | 节拍:{节拍概要}
@@ -55,6 +169,8 @@
---
```
+> **关键**:`` 的 `name` 值必须与紧随其后的首行 `#` 标题文字完全一致(不含 `#` 号和前后空格)。
+
### 二、剧情梗概
```markdown
@@ -203,4 +319,4 @@ OS({人物名},{情绪}):
- **自查清单**:不输出自查清单本身
- **任何元信息**:不输出字数统计、场景数量统计、创作说明等非剧本内容
-剧本输出只包含:文件头 → 剧情梗概→ 剧本正文(△描述 + 台词 + OS/V.S.)
\ No newline at end of file
+剧本输出的完整结构为:`` → 文件头 → 剧情梗概 → 剧本正文(△描述 + 台词 + OS/V.S.) → ``
\ No newline at end of file
diff --git a/data/skills/script_execution_skeleton.md b/data/skills/script_execution_skeleton.md
index 11b8355..0a97785 100644
--- a/data/skills/script_execution_skeleton.md
+++ b/data/skills/script_execution_skeleton.md
@@ -20,7 +20,7 @@
- 全局删减决策表
- 付费卡点设计
3. **阐述思路**(200-300字):核心吸引力判断、三幕划分思路、分集策略方向
-4. 严格按照XML格式写出故事骨架,格式为故事骨架内容。
+4. 严格按照XML格式写出故事骨架,格式为故事骨架内容。XML 标签及其全部内容必须一次性完整输出,禁止拆分为多次 XML 输出。
5. 返回简短确认,如:"故事骨架已保存,请在右侧工作台查看。"
## 约束
@@ -31,6 +31,116 @@
- 付费策略按【项目配置】执行
- 章节必须与事件表一致,不允许出现不存在的章节
+## Skills
+
+### 一、核心结构逻辑
+
+**大三角嵌套小三角:**
+- 大三角:3个核心角色/势力构成全剧主要矛盾,贯穿始终不可轻易改动
+- 小三角:围绕主角的次要矛盾,解决一个再进入下一个,避免多线并行
+- 主流结构为**单线型**:情节围绕单条主线推进,矛盾集中、节奏连贯;短剧面向下沉市场,多线并行易被退稿
+
+### 二、前10集黄金结构
+
+| 集数 | 核心任务 |
+|------|----------|
+| 第1-2集 | 快速引入主角,直接抛出强烈冲突(契约绑定、意外变故),实现"一秒入坑" |
+| 第3-4集 | 明确主角核心行动目标(复仇、追爱、逆袭),为后续埋伏笔 |
+| 第5-8集 | 引入多方配角,从多角度给主角施压,强化矛盾冲突 |
+| 第9-10集 | 设置"假付费点"(目标近在咫尺却落空)+ 正式卡点,推向小高潮 |
+
+- 微短篇:卡点集提前至第6-7集,第1集需承载常规短剧3-4集信息量
+
+### 三、付费点(卡点)设置规范
+
+根据【项目配置】总集数 N 按比例计算付费点位置(四舍五入取整):
+
+| 位置 | 比例 | 设计要求 |
+|------|------|----------|
+| ≈10%处(第⌈N×0.10⌉集) | 首次卡点 | 核心矛盾升级(秘密即将曝光、关系面临破裂) |
+| ≈30%处(第⌈N×0.30⌉集) | 二次卡点 | 生死危机、隐藏秘密将揭露或遭反派陷害,给观众强烈情感冲击 |
+| ≈50%处(第⌈N×0.50⌉集) | 中期卡点 | 阶段性目标达成时迎来重大反转 |
+| ≈70%处(第⌈N×0.70⌉集) | 后期卡点 | 前期悬念和伏笔逐渐展开,引入重大翻转 |
+| ≈90%处(第⌈N×0.90⌉集) | 收尾卡点 | 主角克服所有困难,揭露反派阴谋,达成圆满结局(短剧必保"爽剧"收尾) |
+
+> 示例:20集剧→卡点分布约为第2/6/10/14/18集;100集剧→约为第10/30/50/70/90集
+
+**付费点5大标准:**
+1. **选择关键瞬间**:聚焦对人物内心有强烈情绪冲击的情节
+2. **设置根本性改变**:需改变主角性格、价值观或行为方式
+3. **调动好奇心**:用暗示、伏笔、悬念引发期待
+4. **善用高燃场景**:设置在紧张激动的高潮部分,关键节点戛然而止
+5. **关注爱情拉扯**(感情流):围绕情感阶段转变设计(无感→好感→醒悟→确认心意→表白)
+
+**付费点核心特征:** 场面宏大、事态紧急、围观群众多(大型宴会、认亲仪式、新闻发布会、婚礼现场等)
+
+**假付费点:** 可多次设置,让观众误以为目标即将达成实则受阻,持续牵引情绪
+
+**4类核心付费点写法:**
+- **身份差**(通用型):隐藏身份暴露、身份错认澄清、身份升级展现
+- **感情错位**(女频):认错信物、认错人、欺骗/蒙蔽解开
+- **人物命运巨变**:主角从被打压欺辱→因机缘改变命运→强势反击
+- **环境剧变**(末世类):世界突发灾难,只有主角能掌控局面
+
+### 四、热门类型节奏框架
+
+> 以下比例基于总集数 N,实际集数四舍五入取整。
+
+**甜宠类:**
+契约绑定(第1集)→ 误会拉扯升温(2%~9%)→ 秘密曝光(≈10%付费点)→ 情感破冰(11%~29%)→ 危机爆发(≈30%付费点)→ 撒糖+打脸反派(31%~59%)→ 新危机(≈60%)→ 情感确认(61%~80%)→ 圆满结局(81%~100%)
+
+**虐恋类(追妻火葬场):**
+前期误会伤害(1%~20%)→ 男主悔悟(21%~40%)→ 追妻受阻(41%~70%)→ 真诚悔改+和解(71%~100%)
+
+**萌宝类:**
+带娃回归逆袭(1%~20%)→ 男主发现孩子+解开心结(21%~50%)→ 联手反击反派(51%~80%)→ 家庭团圆(81%~100%)
+
+**战神类:**
+隐藏身份受辱(1%~30%)→ 身份曝光打脸反派(31%~60%)→ 解决核心危机(61%~90%)→ 登顶巅峰(91%~100%)
+
+**重生类:**
+前世被害(第1集)→ 重生改写命运(2%~30%)→ 利用信息差逆袭(31%~70%)→ 复仇成功+圆满结局(71%~100%)
+
+### 五、全局情绪布局(按付费点比例划分阶段)
+
+以复仇类为例(可迁移其他题材),按总集数 N 的比例划分:
+
+| 阶段 | 集数范围 | 核心情绪 | 作用 |
+|------|----------|----------|------|
+| 铺垫 | 1%~10% | 压抑+愤怒 | 拉仇恨,让观众心疼主角,期待反击 |
+| 试探 | 11%~30% | 紧张+小爽 | 缓解压抑,给观众小甜头,留住注意力 |
+| 转折 | 31%~50% | 震惊+焦虑 | 制造大波澜,提升期待感 |
+| 爆发 | 51%~70% | 爽感+解气 | 情绪高潮,释放前面积压的压抑 |
+| 收尾 | 71%~100% | 温暖+圆满 | 收尾情绪,留下正面印象 |
+
+**各类型情绪基调占比:**
+- 甜宠类:甜60% + 微虐30% + 惊喜10%
+- 复仇类:压抑40% + 爽感50% + 解气10%
+- 重生逆袭类:爽感50% + 期待30% + 温暖20%
+- 家庭伦理类:共情40% + 委屈30% + 和解30%
+
+### 六、信息差设计
+
+骨架阶段需在分集中标注信息差类型,操控观众情绪:
+- **主角知道+配角不知道+观众知道** → 观众拥有"先知"爽感,期待配角被"打脸"
+- **主角不知道+配角知道+观众知道** → 观众为身处险境的主角焦急,代入感极强
+- **主角不知道+配角不知道+观众知道** → 观众既想指导主角又好奇反派结局,期待感拉满
+
+### 七、集末钩子设计原则
+
+- 每集结尾必须留"钩子",勾住下一集情绪
+- 钩子需紧扣"主角的下一步行动""反派的反击""第三方的态度"
+- 确保观众有"想立刻知道后续"的冲动
+- 钩子类型:智识钩子/悬念钩子/情感钩子/世界观钩子
+
+### 八、第2、3个付费点素材类型
+
+选影响主线的大事件:
+- **关系类**:兄弟/父子反目、旧情复燃、断绝关系、宣布婚事、霸气护妻
+- **冲突类**:好友陷害、产业被占、奸计得逞/揭发、武力/情感/欲望冲突
+- **真相/变故类**:借腹生子、亲子鉴定、假传死讯、错手杀人、被控入狱
+- **行动类**:请君入瓮、调虎离山、忍辱负重、畏罪潜逃、一夜成名
+
## 注意事项
- 执行前先调用 `get_planData` 确认工作区状态;已有内容在其基础上修改,除非指令要求重写
diff --git a/data/update.json b/data/update.json
deleted file mode 100644
index 7c547a6..0000000
--- a/data/update.json
+++ /dev/null
@@ -1 +0,0 @@
-{"version":"1.0.11"}
\ No newline at end of file
diff --git a/data/version.txt b/data/version.txt
index 8684498..1cc5f65 100644
--- a/data/version.txt
+++ b/data/version.txt
@@ -1 +1 @@
-1.0.11
\ No newline at end of file
+1.1.0
\ No newline at end of file
diff --git a/data/web/index.html b/data/web/index.html
index 3eabe2e..aeb382d 100644
--- a/data/web/index.html
+++ b/data/web/index.html
@@ -5,27 +5,27 @@
Toonflow
-