|
|
- %% ------------------------
- %% desc :经验放置
- %% author:hh
- %% time :20/01/16
- %% ------------------------
-
- %% 快速挂机基础经验
- -record(base_fast_onhook_reward, {
- lv = 0, %% 等级
- base_exp = 0, %% 基础经验
- time = 0 %% 持续时间
- }).
-
- %% 快速挂机多倍领取次数
- -record(base_fast_onhook_multi_reward_count, {
- vip = 0, %% vip等级
- count = 0 %% 次数
- }).
-
- %% 货币类(经验)效率
- -record(base_onhook_exp_effiency, {
- wave = 0, %% 波数(关卡)
- effiency = 0 %% 效率
- }).
-
- %% 掉落规则配置
- -record(base_exp_dun_drop_rule, {
- lv = 0, %% 等级
- wave = 0, %% 波数
- rule = [] %% 规则 [{1(轮次),[{2000(权重),[{1(掉落包id),1(掉落包个数)}]}]}] 万分制概率
- }).
-
- %% 掉落物品配置
- -record(base_exp_dun_drop_goods, {
- id = 0, %% 掉落id
- list_id = 0, %% 列表id
- goods_type = 0, %% 物品类型
- goods_id = 0, %% 物品id
- min = 0, %% 最小数量
- max = 0, %% 最大数量
- open_day = [], %% 开服天数
- weight = 0 %% 权重
- }).
-
- %% -------------------------------------------------------
-
- %% 公共进程数据
- -record(exp_dun_drop_state, {
- calc_maps = #{}, %% 结算组别 #{组id => [role_id,....]} 映射列表
- start_time = 0, %% 开始时间
- ref = undefined %% 结算定时器
- }).
-
- %% 个人数据,存储在公共进程字典
- -record(drop_role, {
- id = 0, %% 个人id
- wave_point = [], %% 波数通关节点 [{wave, reach_time},...]
- off_point = [], %% 离线时间节点 [{离线开始, 离线结束},...]
- start_time = 0, %% 结算开启时间(领取完或玩家结算开启),个人活动状态决定开启时间
- calc_time = 0, %% 最近一次结算时间,公共进程结算个人时更新此时间
- calc_goods = [], %% 累积物品道具(最多不超过配置规定时限)
- goods_limit = [], %% 限制的物品 产出数量
- is_rewarding = 0, %% 是否在领奖,若领奖且正结算,则忽略 0否|1是
- remain = 0, %% 上次结算结余时间
- extra_data = [] %% 其他数据如宠物生活技能/离线加成剩余时长 等 [{Mod, Data}]
- }).
-
- %% 玩家放置经验&快速挂机数据-个人进程
- -record(role_exp_dun_drop, {
- fast_drop_time = 0,
- cache_time_last = 0,
- last_time = 0
- }).
-
- -ifdef (DEV_SERVER).
- -define(EXP_DUN_DROP_INTERVAL, 600). %% 玩家结算的间隔
- -define(EXP_DUN_DROP_GROUP, 2). %% 在玩家结算间隔中分割所有玩家的组数量
- -else.
- -define(EXP_DUN_DROP_INTERVAL, 3600). %% 玩家结算的间隔
- -define(EXP_DUN_DROP_GROUP, 15). %% 在玩家结算间隔中分割所有玩家的组数量
- -endif.
-
- -define(EXP_DUN_DROP_SEC_PER_MIN, 60).
-
- -define(EXP_DUN_RATIO_MAX, 10000).
-
- %% 公共进程人物字典key
- -define(DROP_ROLE_KEY(X), {drop_role, X}).
-
- %%
- -define(DB_MAX_LEN, 10).
-
- %% 限制物品
- -define(DROP_BLUE_EQUIP, 2). %% 蓝装
- -define(DROP_PURPLE_EQUIP, 3). %% 紫装以上
-
- %% 是否正领奖
- -define(EXP_DROP_NOT_REWARD, 0).
- -define(EXP_DROP_REWARDING, 1).
-
- -define(EXP_DROP_CALCING, 2). %% 系统结算中
-
- %% 开放功能子id
- -define(EXP_DROP_1, 2). %% 放置经验开启
- -define(EXP_DROP_2, 15). %% 快速挂机开启
-
- %% 经验副本前置任务
- -define(EXP_DUN_PRE_TASK, 10730).
-
- %% 最小领取间隔
- -define(EXP_DROP_REWARD_INTERVAL, 600).
-
- %%
- -define(EXP_DROP_ERROR_LOG_TIME, exp_drop_log_time).
-
- %% 离线挂机加成卡物品子类
- -define(EXP_DROP_GOODS_SUB_TYPE, 41).
-
- %% 数据移除最大间隔
- -define(EXP_DROP_REMOVE, 259200).
-
- -ifdef(DEV_SERVER).
- -define(SVR_RATIO_ADD(ExpDropAddRatio, VipPrivilege, ServerLvExpRatio),
- 1 + ExpDropAddRatio/?RATIO_MAX + VipPrivilege/100 + 0/max(1, ServerLvExpRatio)).
- -else.
- -define(SVR_RATIO_ADD(ExpDropAddRatio, VipPrivilege, ServerLvExpRatio),
- 1 + ExpDropAddRatio/?RATIO_MAX + VipPrivilege/100 + ServerLvExpRatio/100).
- -endif.
-
-
- -define(SELECT_ROLE_DROP_INFO,
- <<"SELECT calc_time, start_time, extra_data FROM role_exp_dun_drop WHERE role_id = ~p">>).
- -define(REPLACE_INTO_DROP_INFO,
- <<"REPLACE INTO role_exp_dun_drop SET role_id = ~p, calc_time = ~p, start_time = ~p, extra_data = ~ts">>).
- -define(UPDATE_DROP_INFO_CALC_TIME,
- <<"UPDATE role_exp_dun_drop SET calc_time = ~p WHERE role_id = ~p">>).
- -define(UPDATE_DROP_INFO_START_TIME,
- <<"UPDATE role_exp_dun_drop SET start_time = ~p WHERE role_id = ~p">>).
- -define (UPDATE_DROP_INFO_EXTRA_DATA,
- <<"UPDATE role_exp_dun_drop SET extra_data = ~ts WHERE role_id = ~p">>).
- -define (UPDATE_DROP_INFO,
- <<"UPDATE role_exp_dun_drop SET start_time = ~p, calc_time = ~p, extra_data = ~ts WHERE role_id = ~p">>).
- -define (UPDATE_DROP_INFO_EXCLUDE_EXTRA_DATA,
- <<"UPDATE role_exp_dun_drop SET start_time = ~p, calc_time = ~p WHERE role_id = ~p">>).
-
- -define(SELECT_ROLE_FAST_EXP,
- <<"SELECT fast_hook_time FROM role_fast_exp WHERE role_id = ~p">>).
- -define(REPLACE_DROP_INFO_FAST_DROP_TIME,
- <<"REPLACE INTO role_fast_exp SET role_id = ~p, fast_hook_time = ~p">>).
-
- -define(SELECT_ROLE_GOODS_DROP,
- <<"SELECT goods_type, goods_id, num FROM role_exp_dun_drop_goods WHERE role_id = ~p">>).
- -define(BATCH_UPDATE_ROLE_GOODS,
- <<"REPLACE INTO `role_exp_dun_drop_goods` (`role_id`, `goods_type`, `goods_id`, `num`)">>).
- -define(DELETE_ROLE_ALL_GOODS,
- <<"DELETE FROM role_exp_dun_drop_goods WHERE role_id = ~p">>).
-
- -define(SELECT_ROLE_EXP_DUN_WAVE,
- <<"SELECT wave, time FROM role_exp_dun_wave_info WHERE role_id = ~p">>).
- -define(REPLACE_INTOEXP_DUN_WAVE,
- <<"REPLACE INTO role_exp_dun_wave_info SET role_id = ~p, wave = ~p, time = ~p">>).
- -define(DELETE_ROLE_EXP_DUN_WAVE,
- <<"DELETE FROM role_exp_dun_wave_info WHERE role_id = ~p AND wave in ~s">>).
-
- -define(SELECT_ROLE_EXP_DUN_REC,
- <<"SELECT data FROM dungeon_best_record WHERE player_id = ~p AND dun_id = ~p">>).
-
- -define(SELECT_ROLE_OFF_POINT,
- <<"SELECT off_start, off_end FROM role_exp_dun_off_point WHERE role_id = ~p">>).
- -define(BATCH_REPLACE_INTO_OFF_POINT,
- <<"REPLACE INTO role_exp_dun_off_point(`role_id`, `off_start`, `off_end`) VALUES ~ts">>).
- -define(BATCH_REPLACE_OFF_POINT_VAL, <<"(~p, ~p, ~p)">>).
- -define(REPLACE_INTO_EXP_DROP_OFF_POINT,
- <<"REPLACE INTO role_exp_dun_off_point SET `role_id` = ~p, `off_start` = ~p, `off_end` = ~p">>).
- -define(DELETE_ROLE_OFF_POINT,
- <<"DELETE FROM role_exp_dun_off_point WHERE role_id = ~p AND off_start in ~s">>).
|