资源道具化
概念
概念:系统中的每一个资源分配一个唯一标识。
举例:金币、钻石、道具、礼包、勋章、英雄、英雄碎片、活动积分、表情等。
中间层:处理资源增减请求。
举例
签到为例
graph LR
A[签到请求] –>B{是否可签}
B –>|yes| D[读取奖励配置]
D –> E1[直接获得奖励] –> 结束
D –> E2[提出资源增加请求] –> 结束
A[签到请求] –>B{是否可签}
B –>|yes| D[读取奖励配置]
D –> E1[直接获得奖励] –> 结束
D –> E2[提出资源增加请求] –> 结束
style E1 stroke:Orange,stroke-width:4px
style E2 stroke:Red,stroke-width:4px
红色要优于橙色。
红线逻辑,签到模块不关心奖励是怎么加上去的。
中间层处理资源
graph LR
A[资源增减请求] –>B{增加or减少}
B –>|增加| D{不同的类型}
D –> E1[加金币]
D –> E3[加英雄碎片] –> 调用背包模块
D –> E2[加英雄]
E2 -..-> |没有该英雄| F1[调用英雄模块]
E2 -..-> |有该英雄 不允许分解| F1
E2 -..-> |有该英雄 允许分解| F2[读取碎片数 发起加碎片请求] -..-> A
A[资源增减请求] –>B{增加or减少}
B –>|增加| D{不同的类型}
D –> E1[加金币]
D –> E3[加英雄碎片] –> 调用背包模块
D –> E2[加英雄]
E2 -..-> |没有该英雄| F1[调用英雄模块]
E2 -..-> |有该英雄 不允许分解| F1
E2 -..-> |有该英雄 允许分解| F2[读取碎片数 发起加碎片请求] -..-> A
中间层实现了增减资源的操作。
两张表
资源表
id | type | desc | ext… |
---|---|---|---|
资源ID唯一标识 | 不同的类型 | 描述 | 一些扩展字段 |
签到表
day | id | count |
---|---|---|
第几天 | 资源ID | 数量 |
需求扩展
需求:签到给英雄,如果玩家已经拥有该英雄,则改为给3个英雄碎片。
实现:兑换表:英雄、英雄碎片、兑换个数。把自动拆为碎片的逻辑放入中间层,签到模块不用关心。
需求:如果玩家获得A道具100次,获得S勋章。获得3次S勋章,达成Y成就。
实现:勋章表:道具、收集次数。成就表:勋章、收集次数。
增加道具时,对应计数+1。判断是否触发勋章获得的条件,如果达成,增加对应的勋章。
增加勋章时,对应计数+1。判断是否触发成就获得的条件,如果达成,增加对应的成就。
道具、勋章、成就,都资源化,无差别对待。根据资源表中的type,做不同逻辑。
不同的模块,可以复用这套逻辑。
需求:签到给积分,积分可以兑换英雄碎片。
实现:积分作为一种资源,分配一个ID,对接兑换模块。
兑换模块,先发起减请求,再发起加请求。
总结
- 资源道具化,统一性。
- 中间层,对外界屏蔽不同资源的差异。
- 子模块不直接交互,通过中间层间接交互。