10 KiB
10 KiB
程序默认规则基线
文档版本:v1.1 最后更新:2026-04-03 20:40:00
本文档用于定义当前客户端在不依赖活动配置细项时,程序层应该内建的默认规则。
目标:
- 先把程序能力层的默认行为定住
- 让代码实现优先对齐这一套基线
- 等默认行为稳定后,再决定哪些能力值得开放成配置
说明:
- 本文档讲的是程序默认规则
- 它先于活动配置存在
- 它不讨论后台录入方式
- 它不追求一次把所有参数开放出去
- 当前这批玩法默认值已开始集中收口到 gameModeDefaults.ts
- 设置页默认值与锁态已开始集中收口到 systemSettingsState.ts
1. 总体原则
当前规则收敛顺序固定为:
- 先定程序默认能力
- 再定玩法默认差异
- 最后才开放活动配置覆盖
程序层默认规则要满足 3 个要求:
- 默认可玩:不给额外配置也能顺畅跑完一局
- 默认统一:相同类型行为在不同玩法下表达一致
- 默认克制:不把调试、测试、历史试验行为带进最小流程
补充一条设置页原则:
- 设置值和锁态分离管理,避免运行时状态被历史缓存污染
2. 程序默认层次
前台默认只保留 5 类可见反馈层。
同时,程序默认值分成两条并行基线:
- 对局规则默认值
- 系统设置默认值
2.1 黑底引导提示条
职责:
- 只负责告诉玩家“下一步该做什么”
规则:
- 自动消失
- 可手动关闭
- 文案变化时可有轻动画
- 默认只配轻震动
- 不承担结果反馈
- 不承担内容说明
2.2 彩色短反馈条
职责:
- 只负责告诉玩家“刚刚发生了什么”
规则:
- 短暂出现
- 不带按钮
- 不显示长说明
- 不承担下一步引导
2.3 白色内容卡
职责:
- 只承载显式配置的点位内容
规则:
- 默认不进入最小流程
- 默认关闭
- 仅当某个点位明确启用时才参与流程
- 浏览型卡片默认短时自动消失
- 交互型卡片只在显式开启时出现
2.4 答题卡
职责:
- 承载显式启用的答题玩法
规则:
- 属于强交互层
- 最小模板下默认关闭
- 仅当点位显式配置
quizCTA 时才进入 - 不依赖白色内容卡作为前置
2.5 成绩总览页
职责:
- 承载结算结果
规则:
- 终点完成后直接进入
- 不再额外叠终点白卡
3. 打点默认规则
3.1 开始点
程序默认行为:
- 必须先打开始点才能正式开赛
- 成功打开始点后开始计时
- 起点完成后只给短反馈,并更新引导和 HUD
- 默认不弹白色开始卡
- 从准备页进入地图即视为进入对局,不再额外要求点击开始按钮
- 默认不弹答题卡
3.2 普通点
程序默认行为:
- 成功打点后先完成基础结算
- 最小模板下默认不弹答题卡
- 如需答题,必须显式配置点位 CTA
- 默认不先弹白色内容卡
- 默认不重复得分
- 默认不重复出题
3.3 结束点
程序默认行为:
- 成功打终点后先给完成短反馈
- 随后直接进入结果页
- 默认不弹白色终点卡
- 默认不弹答题卡
3.4 关门时间
程序默认行为:
- 默认关门时间为开赛后
2小时 - 距离关门时间小于等于
10分钟时,HUD 第 1 页时间区切换为倒计时显示 - 倒计时显示需有区别于正常计时的强调样式
- 到达关门时间后,系统自动结束当前对局
- 超时结束必须和正常完赛、主动退出区分开
4. 玩法默认差异
程序只内建少量玩法差异,不把所有东西做成配置。
4.1 顺序打点 classic-sequential
默认差异:
- 按顺序推进
- 默认允许跳点
- 默认跳点半径 = 打点半径的 2 倍
- 默认跳点前弹出确认
- 当前目标点由系统自动推进
- 终点默认需要在中间点都“成功或跳过”后才生效
- 普通点基础分默认
1 - 普通点默认不附带答题奖励
4.2 积分赛 score-o
默认差异:
- 自由打点
- 默认不存在跳点
- 默认不要求先选中目标点
- 点击某个积分点时,默认只更新当前目标和 HUD 信息
- 未点击选中时,也允许直接进入任意积分点范围完成打点
- 默认至少完成
1个普通积分点后,终点才解锁 - 普通点基础分默认取该点分值
- 普通点默认不附带答题奖励
5. HUD 默认规则
HUD 属于公共程序能力,不属于某个玩法专属实现。
5.1 固定结构
- HUD 固定为 2 页
- 第 1 页为比赛主信息页
- 第 2 页为心率 / 遥测页
- 异型壳子布局固定,不因玩法改变结构
5.2 第 1 页默认职责
- 时间
- 里程
- 动作标签
- 目标摘要
- 目标距离
- 进度摘要
- 速度
- 临近关门时间时,时间槽位切换为倒计时
5.3 第 2 页默认职责
- 心率
- 卡路里
- 平均速度
- 精度或相关遥测值
5.4 遥测身体数据来源
程序默认口径:
- HUD 第 2 页使用统一遥测运行时
- 活动配置里的
game.telemetry.*只作为活动默认值 - 玩家年龄、静息心率、体重等身体数据,后续允许由线上接口覆盖
- 线上身体数据一旦到位,应高于活动配置生效
默认优先级:
系统默认值 -> 活动遥测默认值 -> 玩家线上身体数据
5.5 玩法映射默认口径
- 顺序打点:
- 目标摘要显示当前目标点
- 进度摘要显示完成进度和跳点数
- 积分赛:
- 目标摘要显示当前选中目标点
- 进度摘要显示总分和收集进度
5.6 目标角色默认口径
程序默认把目标拆成 4 类:
- 可打目标:当前进入范围后可真正完成打点的对象
- 引导目标:用于距离音效、接近提示和弱引导的对象
- HUD 目标:用于底部信息面板距离与摘要显示的对象
- 展示高亮目标:用于地图上重点高亮的对象
约束:
- 这 4 类目标不能再混用
- 积分赛里“选中目标”默认只影响 HUD 目标
- 距离音效默认只跟随引导目标,不跟随选中状态
6. 距离反馈默认规则
距离反馈和黑底引导提示条分离管理。
6.1 黑底引导提示条
- 默认只走轻震动
- 不绑定提示音
6.2 距离提示
默认分为 3 档:
distantapproachingready
默认口径:
ready:进入可打点范围approaching:接近目标distant:较远但仍处于有效提醒范围- 更远距离默认静默
默认阈值:
distantDistanceMeters = 80approachDistanceMeters = 20readyDistanceMeters = 5
默认节奏:
distant:弱提醒,默认间隔4800msapproaching:较明确提醒,默认间隔950msready:确认提醒,默认间隔650ms
7. 系统设置默认规则
设置页属于程序公共能力,不属于某个玩法专属逻辑。
7.1 设置项结构
每个设置项默认由两部分组成:
value:设置值isLocked:是否允许玩家修改
7.2 默认值规则
程序默认要求:
- 每个设置项都必须有系统默认值
- 玩家未手动修改时,直接使用系统默认值
- 默认值应集中维护,不散落在页面逻辑里
7.3 持久化规则
程序默认要求:
value需要持久化isLocked不持久化- 页面每次进入时,锁态都应重新按当前运行时规则计算
- 锁态只受系统默认值与活动配置影响,玩家不能在页面中修改锁态
- 设置页中的锁态徽标只做状态展示,不提供点按切换能力
- 锁态生存期:从当前游戏配置载入并进入该局开始,到本局正常结束、超时结束或主动退出为止
默认优先级:
系统设置默认值 -> 玩家本地持久化值
锁态优先级:
系统锁态默认值 -> 当前运行时或活动规则覆盖
7.4 当前已集中维护的设置基线
当前已在 systemSettingsState.ts 集中维护:
- 轨迹显示
- GPS 点显示
- 侧边按钮习惯
- 自动旋转
- 指北针调校
- 北向参考
- 中央标尺显示与锚点
- 各设置项的默认锁态
8. 最小流程基线
8.1 顺序打点最小流程
- 进入游戏,只显示开始点
- 打开始点,开赛并显示全场
- 按顺序推进普通点
- 普通点打点后默认只做基础结算
- 可触发跳点
- 打终点后直接进入结果页
- 如果超过
2小时仍未结束,系统按超时结束处理
8.2 积分赛最小流程
- 进入游戏,只显示开始点
- 打开始点,开赛并显示全部积分点和终点
- 可直接前往任意积分点,或点击某个点更新当前目标
- 进入积分点范围后成功打点
- 普通点打点后默认只做基础结算
- 默认至少完成
1个普通积分点后可打终点结束 - 如果超过
2小时仍未结束,系统按超时结束处理
9. 暂不开放为配置的内容
当前先不优先配置化的内容:
- 弹层体系层级
- 起点是否弹白卡
- 普通点是否先白卡后答题
- 终点是否白卡后结算
- HUD 是否双页
- HUD 异型壳子结构
- 黑条提示与距离反馈的职责边界
这些内容应先作为程序默认能力稳定下来。
10. 故障恢复基线
当前故障恢复按“轻量快照恢复”处理:
- 仅恢复进行中的对局
- 仅恢复核心赛局状态、遥测累计值和地图基础视口
- 不恢复白卡、答题卡、临时动效、短反馈和提示层
- 恢复后由规则层和展示层重新计算 HUD、按钮文案、目标提示和音效状态
当前默认恢复内容:
- 当前配置入口
startedAt / completedControlIds / skippedControlIds / currentTargetControlId / score / modeState- 累计里程、基础心率/卡路里累计、最后 GPS 点
zoom / centerTile / rotation / gpsLock
当前默认不恢复内容:
- 详情卡
- 答题中间态
- 待查看内容入口
- 所有瞬时动效和提示队列
11. 后续开放配置的原则
后续只有满足以下条件的内容,才建议开放成配置:
- 运营确实会频繁改
- 改动不会破坏主流程一致性
- 改完不会引入一组新的层级冲突
优先可配置的内容应是:
- 点位分值
- 点位内容是否启用
- 点位样式
- 三档距离提示阈值
- 三档距离提示间隔
12. 一句话结论
当前阶段应以这份文档作为程序默认能力基线:先把最小流程、弹层职责、HUD 结构和距离反馈定死,再决定哪些内容值得进入配置层。