2.7 KiB
2.7 KiB
分支叙事指南
基本分支
最简单的分支:一个场景 → 多个选项 → 不同目标场景。
"scene_1": {
"id": "scene_1",
"videoUrl": "scene_1/video.mp4",
"choices": [
{ "text": "帮助他", "targetScene": "help" },
{ "text": "离开", "targetScene": "leave" }
]
}
条件分支
选项可以根据变量条件显示/隐藏:
"choices": [
{
"text": "高信任路线",
"targetScene": "trust_path",
"conditions": [
{ "variable": "trust", "op": ">=", "value": 80 }
]
},
{ "text": "普通路线", "targetScene": "normal_path" }
]
op 支持:>, <, >=, <=, ==, !=。
变量与效果
全局变量在 JSON 顶层定义初始值:
{
"variables": { "trust": 50, "courage": 0, "investigation": 0 }
}
选项选择后应用效果:
{
"text": "与陌生人握手",
"targetScene": "trust_ending",
"effects": [
{ "type": "add", "target": "trust", "value": 30 }
]
}
效果类型:
"set"— 设置变量为指定值"add"— 增加(负数=减少)
场景进入效果
进入场景时自动触发:
"ending": {
"id": "ending",
"videoUrl": "ending/video.mp4",
"onEnter": [
{ "type": "set", "target": "completed_game", "value": 1 }
]
}
限时选择
{
"text": "快速决定!",
"targetScene": "timeout_scene",
"timeLimit": 10
}
10 秒内不选,自动选这个选项。timeLimit: 0 或省略 = 不限时。
默认跳转
无选项或有选项但都不满足条件时,自动跳转:
"scene": {
"id": "scene",
"videoUrl": "scene/video.mp4",
"choices": [], // 无选项时自动跳
"nextScene": "auto_next"
}
优先级:choices > nextScene > 什么都没配(游戏结束)。
关键选择提示(Prompt)
重要选项可以配置前置金色标识 + 选后浮现提示:
{
"text": "与陌生人握手",
"textKey": "left_door.choice.handshake",
"prompt": "陌生人会记住你的善意",
"promptKey": "left_door.prompt.handshake",
"targetScene": "trust_ending"
}
- 前置:选项按钮左侧显示金色竖线 + 淡金边框
- 后置:选择确认后,画面中央浮现 prompt 文字,2 秒淡出
promptKey 支持 i18n,配置方法见 国际化指南。
多国语言选项
选项文案支持中/英/日等多语言,使用 textKey 机制:
{
"text": "继续前进",
"textKey": "qte_success.choice.continue",
"targetScene": "continue_ending"
}
text是回退值(翻译找不到时使用)textKey指向public/locales/zh.json中的翻译
详细配置见 国际化指南。