源战役
Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.
 
 

208 righe
8.8 KiB

%% ---------------------------------------------------------------------------
%% @doc 跨服竞榜活动头文件.
%% @author zhaoyu
%% @since 2018-11-27
%% ---------------------------------------------------------------------------
-ifndef(RACE_RANK_HRL).
-define(RACE_RANK_HRL, ok).
%% 还没结算
-define(NOT_SETTLEMENT, 0).
%% 排行榜最大上榜人数
-define(RR_RANK_MAX, 100).
-define(TYPE_RACE,1). %%寻常冲榜
-define(TYPE_WISH,2). %%许愿冲榜
-define(TYPE_POOL_RACE,0). %%正常奖池
-define(TYPE_POOL_COIN,1). %%金币奖池
-define(TYPE_POOL_RUNE,2). %%符文奖池
%% 跨服竞榜活动-时间配置
-record(race_rank_act, {
act_id = 0 %% 活动Id
,type = 0 %% 1冲榜2许愿池
,open_day = 0 %% 开服多少天后可以参与
,name = <<>> %% 活动名
,start_time = 0 %% 活动开始时间
,end_time = 0 %% 活动结束时间
,show_time = 0 %% 展示时间
,lv = 0 %% 玩家参加活动需要达到的等级
,condition = [] %% 条件
}
).
%% 跨服竞榜活动-奖池奖励配置
-record(race_rank_draw_pool, {
act_id = 0 %% 活动Id
,type = 0 %% 0冲榜1金币2符文
,stage = 0 %% 世界等级阶段
,award_id = 0 %% 奖励Id
,award = [] %% 奖励
,loading_times = 0 %% 入库次数
,weight = 0 %% 权重
,is_broadcast = 0 %% 是否发送传闻(1发 0不发)
,is_tv = 0 %% 是否上电视(1上 0不上)
}
).
%% 跨服竞榜活动-排名奖励
-record(race_rank_award, {
act_id = 0 %% 活动Id
,stage = 0 %% 世界等级阶段
,min_rank = 0 %% 排名上限
,max_rank = 0 %% 排名下限
,need_score = 0 %% 最低上榜要求
,award = [] %% 奖励
}
).
%% 跨服竞榜活动-积分阶段奖励
-record(race_rank_times_award, {
act_id = 0 %% 活动Id
,stage = 0 %% 世界等级阶段
,award_id = 0 %% 奖励Id
,need_score = 0 %% 所需积分
,server_score = 0 %% 所需全服积分
,award = [] %% 奖励
}
).
%% 跨服竞榜活动信息
-record(rr_act_info, {
act_id = 0 %% 活动Id
,status = 0 %% 已结算奖励:结算时的时间戳;还没结算奖励:0
,start_time = 0 %% 活动开始时间
,end_time = 0 %% 活动结束时间
,show_end_time = 0 %% 展示结束时间
}).
%% race_rank_act进程state
-record(race_rank_act_info, {
opening = [] %% 正在开启中/展示中的活动[#rr_act_info{}]
,ref = 0 %% 活动开启结束定时器
,scores = [] %% 本服积分
}).
%% race_rank_mgr进程state
-record(rr_rank_state, {
server2zone_dict = #{} %% 按ServerId查询ZoneId的索引数据
,acts_rank = [] %% 排行榜数据[#rr_act_rank{}]
}
).
%% 竟榜活动排行榜
-record(rr_act_rank, {
act_id = 0 %% 活动Id
,ranks = [] %% 排行榜数据[#rr_rank{}]
}
).
%% 排行榜数据
-record(rr_rank, {
act_id = 0 %% 活动Id
,zone_id = 0 %% 分区Id
,roles = [] %% 排行榜数据[#rr_rank_role{}]
}
).
%% 排行榜角色数据
-record(rr_rank_role, {
act_id = 0 %% 活动Id
,zone_id = 0 %% 分区Id
,role_id = 0 %% 角色Id
,role_name = <<>> %% 角色名
,server_id = 0 %% 服务器Id(后台唯一服号)
,server_num = 0 %% 服务器编号(玩家可见的服编号)
,score = 0 %% 积分
,time = 0 %% 时间戳
,ranking = 0 %% 排名
}
).
%% 角色竞榜活动数据
-record(role_race_rank, {
act_data = [] %% 角色竞榜活动数据:[#rr_act_data{}]
}
).
%% 角色竞榜活动数据
-record(rr_act_data, {
act_id = 0 %% 活动Id
,times = 0 %% 累计次数
,buy_ten_times = 0 %% 抽十次的累计次数
,buy_ten_time = 0 %% 最近一次抽十次的时间戳
,score = 0 %% 积分
,use_free_times = 0 %% 已使用免费次数
,free_time = 0 %% 最近一次使用免费次数的时间戳
,award_log = [] %% 累计次数奖励领取记录[AwardId]
,valid_time = 0 %% 数据有效截止时间戳
,coin = 0 %%金币
,stage = 0 %%当前阶段 累计充值阶段
,time = 0 %%充值时间 =
,coin_draw = 0 %%金币祈愿次数
,coin_time = 0 %%金币祈愿时间
,rune_draw = 0 %%符文祈愿次数
,rune_time = 0 %%符文祈愿时间
}
).
%% 活动世界等级阶段数据
-record(rr_act_stage, {
act_id = 0 %% 活动Id
,stage = 0 %% 世界等级阶段
,valid_time = 0 %% 数据有效截止时间戳(等于活动的show_end_time)
}
).
%% race_rank_opening_act数据表语句.
%% 活动展示期过后清理数据
-define(RR_ACT_SELECT, <<"SELECT `act_id`,`status` FROM `race_rank_opening_act`">>).
-define(RR_ACT_BATCH, <<"REPLACE INTO race_rank_opening_act (`act_id`,`status`)">>).
-define(RR_ACT_DEL, <<"DELETE FROM race_rank_opening_act WHERE `act_id`=~p">>).
-define(RR_ACT_DEL_ALL, <<"TRUNCATE TABLE race_rank_opening_act">>).
%% race_rank数据表语句.
-define(RR_RANK_SELECT, <<"SELECT `act_id`,`zone_id`,`rid`,`rname`,`server_id`"
",`server_num`,`score`,`time` FROM `race_rank`">>).
-define(RR_RANK_BATCH, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
",`server_num`,`score`,`time`) VALUES ~ts">>).
-define(RR_RANK_REPLACE, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
",`server_num`,`score`,`time`) VALUES (~p, ~p, ~p, '~ts', ~p,~p, ~p, ~p)">>).
-define(RR_RANK_DEL, <<"DELETE FROM race_rank WHERE `act_id`=~p AND `rid`=~p">>).
-define(RR_RANK_BATCH_DEL, <<"DELETE FROM race_rank WHERE `act_id`=~p AND `rid` IN (~ts)">>).
-define(RR_RANK_DEL_ACT, <<"DELETE FROM race_rank WHERE `act_id`=~p">>).
-define(RR_RANK_DEL_ALL, <<"TRUNCATE TABLE race_rank">>).
-define(RR_RANK_LOG_BATCH, <<"REPLACE INTO race_rank (`act_id`,`zone_id`,`rid`,`rname`,`server_id`"
",`server_num`,`score`,`time`) VALUES ~ts">>).
%% role_race_rank数据表语句.
-define(RR_ROLE_SELECT, <<"SELECT `act_id`,`times`,`buy_ten_times`,`buy_ten_time`,`score`,`use_free_times`,`free_time`,`award_log`"
",`valid_time`,`coin`,`stage`,`time`,`coin_draw`,`coin_time`,`rune_draw`,`rune_time` FROM `role_race_rank` WHERE `rid`=~p">>).
-define(RR_ROLE_REPLACE, <<"REPLACE INTO role_race_rank (`rid`,`act_id`,`times`,`buy_ten_times`,`buy_ten_time`,`score`,`use_free_times`,`free_time`"
",`award_log`,`valid_time`,`coin`,`stage`,`time`,`coin_draw`,`coin_time`,`rune_draw`,`rune_time`) VALUES (~p, ~p, ~p, ~p, ~p, ~p, ~p, ~p, '~ts', ~p,~p, ~p, ~p, ~p, ~p, ~p,~p)">>).
-define(RR_ROLE_DEL, <<"DELETE FROM role_race_rank WHERE `act_id`=~p">>).
-define(RR_ROLE_DEL_ROLE, <<"DELETE FROM role_race_rank WHERE `act_id`=~p AND `rid`=~p">>).
-define(RR_ROLE_DEL_ALL, <<"TRUNCATE TABLE role_race_rank">>).
%% log_race_rank数据表语句.
-define(RR_LOG_RANK_BATCH, <<"REPLACE INTO log_race_rank_kf (`act_id`,`zone_id`,`role_id`,`rname`,`server_id`"
",`server_num`,`stime`,`etime`,`score`,`rank`,`ctime`,`time`) VALUES ~ts">>).
-define(RR_LOG_RANK_REPLACE, <<"REPLACE INTO log_race_rank (`act_id`,`zone_id`,`role_id`,`rname`,`stime`,`etime`,`score`,`rank`,`ctime`,`time`) VALUES (~p,~p,~p,'~ts',~p,~p,~p,~p,~p,~p)">>).
%% race_rank_server_score数据表语句.
-define(SQL_SERVER_SCORE_GET, <<"SELECT `act_id`,`score`,`time` FROM `race_rank_server_score`">>).
-define(SQL_SERVER_SCORE_REPLACE, <<"REPLACE INTO `race_rank_server_score` (`act_id`,`score`,`time`) VALUES (~p, ~p, ~p)">>).
-define(SQL_SERVER_SCORE_DEL, <<"DELETE FROM `race_rank_server_score` WHERE `act_id`=~p">>).
-endif. %% RACE_RANK_HRL