%% ------------------------
|
|
%% 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">>).
|