源战役
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

176 rivejä
6.5 KiB

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