Blame view

src/actions/AdvAction.lua 9.99 KB
23d89d13   zhouahaihai   冒险 结构
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
  local ipairs = ipairs
  local table = table
  local math = math
  local next = next
  local string = string
  local redisproxy = redisproxy
  local MsgPack = MsgPack
  local getRandomName = getRandomName
  local mcast_util = mcast_util
  local string_format = string.format
  local tonumber = tonumber
  local require = require
  local table_insert = table.insert
  local tconcat = table.concat
  local table_unpack = table.unpack
  
  local _M = {}
  
09be9059   zhouhaihai   冒险接口
19
  
c3d5fe54   zhouhaihai   无战斗状态挂机清掉战斗队伍
20
  local function checkFormat(role, format, checkAdvTeam)
09be9059   zhouhaihai   冒险接口
21
22
23
24
25
26
27
28
29
30
  	local advHang = role:getProperty("advHang")
  	local hadHero = {}
  	for chapterId, info in pairs(advHang) do
  		if info.format then
  			for _, heroId in pairs(info.format.heros) do
  				hadHero[heroId] = true
  			end
  		end
  	end
  
c3d5fe54   zhouhaihai   无战斗状态挂机清掉战斗队伍
31
  	if checkAdvTeam then
09be9059   zhouhaihai   冒险接口
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
  		for _, heroId in pairs(role:getProperty("advTeam").heros or {}) do
  			hadHero[heroId] = true
  		end
  	end
  
  	if not format.leader then return end
  	local hadLeader = false
  	for slot, heroId in pairs(format.heros) do
  		if not role.heros[heroId] or hadHero[heroId] then
  			return
  		end
  		if heroId == format.leader then
  			hadLeader = true
  		end
  	end
  	if not hadLeader then return end
  	return true
  end
  
46fac6f1   zhouahaihai   酱料
51
  --开始一个新的关卡
23d89d13   zhouahaihai   冒险 结构
52
53
54
  function _M.startAdvRpc( agent, data )
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
09be9059   zhouhaihai   冒险接口
55
56
57
58
  	local chapterId = msg.chapterId --关卡id
  	local layer = msg.layer or 1	--选择层数
  	local format = msg.format 		--编队
  	local chapterData = csvdb["adv_chapterCsv"][chapterId]
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
59
  	if not chapterData then return  1 end
09be9059   zhouhaihai   冒险接口
60
  
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
61
  	if role.dailyData:getProperty("advC") >= role:getAdvHangLimit() then return 2 end -- 是否有体力
4d943586   zhouhaihai   直通 advt gm
62
63
   
  	if (layer - 1) % globalCsv.adv_can_out_layer_pre ~= 0 then return 3 end
47d5d769   zhouhaihai   中继判断 随机任务
64
  
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
65
  	if layer > chapterData.limitlevel then return 4 end
09be9059   zhouhaihai   冒险接口
66
  
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
67
68
  	-- 关卡开放判断
  	if not role:advChapterIsOpen(chapterId, layer) then return 5 end
09be9059   zhouhaihai   冒险接口
69
  
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
70
  	--中继开放判断
47d5d769   zhouhaihai   中继判断 随机任务
71
  	local advPass = role:getProperty("advPass")
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
72
73
74
  	if layer ~= 1 and (not role:isFuncOpen(FuncOpenType.AdvRelay) or (advPass[chapterId] or 0) < (layer - 1)) then return 6 end
  	
  	if not checkFormat(role, format) then return 7 end
46fac6f1   zhouahaihai   酱料
75
76
  
  	--上一个关卡结束才可以开始新的关卡
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
77
  	if next(role:getProperty("advInfo")) then return 8 end
09be9059   zhouhaihai   冒险接口
78
79
80
81
82
  
  	local advTeam = role:getProperty("advTeam")
  	table.clear(advTeam)
  
  	advTeam.heros = {}
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
83
  	for slot, heroId in pairs(format.heros) do
09be9059   zhouhaihai   冒险接口
84
85
  		advTeam.heros[slot] = heroId
  	end
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
86
  	advTeam.leader = format.leader
09be9059   zhouhaihai   冒险接口
87
88
89
90
  	role:updateProperty({field = "advTeam", value = advTeam})
  	role.dailyData:updateProperty({field = "advC", delta = 1})
  
  	role:getAdvData():initByChapter(chapterId, layer)
23d89d13   zhouahaihai   冒险 结构
91
  
23d89d13   zhouahaihai   冒险 结构
92
93
94
95
  	SendPacket(actionCodes.Adv_startAdvRpc, '')
  	return true
  end
  
09be9059   zhouhaihai   冒险接口
96
97
  
  function _M.startHangRpc(agent, data)
46fac6f1   zhouahaihai   酱料
98
99
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
09be9059   zhouhaihai   冒险接口
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
  	local chapterId = msg.chapterId --关卡id
  	local format = msg.format --编队
  
  	local chapterData = csvdb["adv_chapterCsv"][chapterId]
  	if not chapterData then return end
  
  	local advHang = role:getProperty("advHang")
  	if advHang[chapterId] then return end --正在挂机
  
  	local advPass = role:getProperty("advPass")
  	if advPass[chapterId] ~= chapterData.limitlevel then return end -- 没有全通关
  
  
  	if role.dailyData:getProperty("advC") >= role:getAdvHangLimit() then return end -- 是否有体力
  
c3d5fe54   zhouhaihai   无战斗状态挂机清掉战斗队伍
115
  	if not checkFormat(role, format, next(role:getProperty("advInfo"))) then return end --编队是否正确
09be9059   zhouhaihai   冒险接口
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
  
  	local battleV = 0
  	for _, heroId in pairs(format.heros) do
  		local hero = role.heros[heroId]
  		battleV = battleV + hero:getProperty("battleV")
  	end
  	if battleV < chapterData.idleValue then return end -- 战斗力是否满足
  
  	local info = {}
  	info.format = {}
  	info.format.leader = format.leader
  	info.format.heros  = {}
  	for slot, heroId in pairs(format.heros) do
  		info.format.heros[slot] = heroId
  	end
  	info.time = skynet.timex() + chapterData.idleTime --挂机时间
  
c3d5fe54   zhouhaihai   无战斗状态挂机清掉战斗队伍
133
134
135
136
137
  	-- 没有在战斗  用team来挂机了  把team清掉
  	if not next(role:getProperty("advInfo")) then
  		role:updateProperty({field = "advTeam", value = {}})
  	end
  
09be9059   zhouhaihai   冒险接口
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
  	role:changeUpdates({{type = "advHang", field = chapterId, value = info}})
  
  	role.dailyData:updateProperty({field = "advC", delta = 1})
  
  	SendPacket(actionCodes.Adv_startHangRpc, '')
  	return true
  end
  
  function _M.endHangRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	local chapterId = msg.chapterId --关卡id
  	local cancel = msg.cancel  --是否是取消
  	
  	local advHang = role:getProperty("advHang")
  	local info = advHang[chapterId]
  	if not info then return end 
  
  	local chapterData = csvdb["adv_chapterCsv"][chapterId]
  	if not chapterData then return end
  	
  	local reward, isFull
  	if skynet.timex() >= info.time then
  		reward = role:award(chapterData.idleReward)
  	else
  		if cancel then
  			if role.dailyData:getProperty("advC") <= 0 then 
  				isFull = true
  			else
  				role.dailyData:updateProperty({field = "advC", delta = -1})
  			end
  		else
46fac6f1   zhouahaihai   酱料
171
172
173
  			return
  		end
  	end
09be9059   zhouhaihai   冒险接口
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
  	
  	role:changeUpdates({{type = "advHang", field = chapterId, value = nil}})
  
  	SendPacket(actionCodes.Adv_endHangRpc, MsgPack.pack({reward = reward, isFull = isFull}))
  	return true
  end
  
  function _M.buyAdvCountRpc(agent , data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	
  	local count = msg.count --购买次数
  	if math.illegalNum(count, 1, math.min(globalCsv.adv_daily_buy_count - role.dailyData:getProperty("advBC"), role.dailyData:getProperty("advC"))) then return end
  
  	local cost = {[ItemId.Diamond] = count * globalCsv.adv_daily_buy_cost}
  	if not role:checkItemEnough(cost) then return end
  	role:costItems(cost)
  	role.dailyData:updateProperty({field = "advC", delta = -count})
7104d350   zhouhaihai   购买体力 计数
192
  	role.dailyData:updateProperty({field = "advBC", delta = count})
09be9059   zhouhaihai   冒险接口
193
194
  	
  	SendPacket(actionCodes.Adv_buyAdvCountRpc, '')
46fac6f1   zhouahaihai   酱料
195
196
197
  	return true
  end
  
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
198
199
200
201
202
203
204
205
206
207
208
209
  function _M.finishTaskRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	local adv = role:getAdvData()
  	local taskId = msg.taskId  -- -1 则是主线任务
  	local status, reward
  	if taskId == -1 then
  		status, reward = adv:finishMTask()
  	else
  		status, reward = adv:finishTask(taskId)
  	end
f99f48df   zhouhaihai   冒险任务
210
  	adv:updateTask()
4faef572   zhouhaihai   冒险任务,冒险扫荡, 冒险中继
211
212
213
214
215
  	if not status then return end
  	SendPacket(actionCodes.Adv_finishTaskRpc, MsgPack.pack({reward = reward}))
  	return true
  end
  
46fac6f1   zhouahaihai   酱料
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
  -- 点击地块(解锁)(触发事件)
  function _M.clickBlockRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	local adv = role:getAdvData()
  	local status = adv:clickBlock(msg.roomId, msg.blockId, msg)
  	if not status then return end
  	SendPacket(actionCodes.Adv_clickBlockRpc, MsgPack.pack({events = adv:popBackEvents()}))
  	return true
  end
  
  --use item 使用背包道具
  function _M.useItemRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	local adv = role:getAdvData()
  	local status = adv:useItem(msg.itemId, msg.count, msg.target) -- target {roomId = 1, blockId = 1} 选择的目标
  	if not status then return end
  	SendPacket(actionCodes.Adv_useItemRpc, MsgPack.pack({events = adv:popBackEvents()}))
  	return true
  end
  
42f2d1d3   suhongyang   战斗内技能序列逻辑
240
  --使用营养技能
d27ad5e0   suhongyang   使用营养技
241
  function _M.usePotionRpc(agent, data)
46fac6f1   zhouahaihai   酱料
242
243
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
d27ad5e0   suhongyang   使用营养技
244
245
246
247
  	local dishLevel = role.dinerData:getProperty("dishTree"):getv(msg.potionId, 0)
  	if dishLevel == 0 then
  		return
  	end
46fac6f1   zhouahaihai   酱料
248
  	local adv = role:getAdvData()
d27ad5e0   suhongyang   使用营养技
249
  	local status = adv:usePotion(msg.potionId, dishLevel, msg.target) -- target {roomId = 1, blockId = 1} 选择的目标
46fac6f1   zhouahaihai   酱料
250
  	if not status then return end
d27ad5e0   suhongyang   使用营养技
251
  	SendPacket(actionCodes.Adv_usePotionRpc, MsgPack.pack({events = adv:popBackEvents()}))
46fac6f1   zhouahaihai   酱料
252
253
  	return true
  end
23d89d13   zhouahaihai   冒险 结构
254
  
ec87b4a5   zhouahaihai   冒险 完善
255
256
257
258
259
260
261
262
263
264
  --退出
  function _M.exitAdvRpc(agent, data)
  	local role = agent.role
  	-- local msg = MsgPack.unpack(data)
  	local adv = role:getAdvData()
  	local status = adv:exit() -- target {roomId = 1, blockId = 1} 选择的目标
  	SendPacket(actionCodes.Adv_exitAdvRpc, MsgPack.pack({events = adv:popBackEvents()}))
  	return true
  end 
  
12f7b52c   zhouhaihai   冒险战斗
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
  --开始战斗
  function _M.startBattleRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	-- 校验一下信息
  	local roomId = msg.roomId
  	local blockId = msg.blockId
  	local monsterId = msg.monsterId
  	local enemyId = msg.enemyId
  	if not enemyId then return end
  
  	local adv = role:getAdvData()
  	local enemy = adv.battle:getEnemyById(enemyId)
  
  	if enemy.monsterId ~= monsterId or enemy.roomId ~= roomId or enemy.blockId ~= blockId or enemy.lock or enemy.isDead then return end
  
  	local key = tostring(math.random())
  	adv.__battleCache = {
  		enemyId = enemyId,
  		key = key
  	}
  	SendPacket(actionCodes.Adv_startBattleRpc, MsgPack.pack({key = key}))
  	return true
  end
  
  -- 结束战斗
  function _M.endBattleRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  	local roomId = msg.roomId
  	local blockId = msg.blockId
  	local monsterId = msg.monsterId
  	local enemyId = msg.enemyId
  	local key =  msg.key
  	local player = msg.player
  
  	if not player or not player.hp or not player.sp or not enemyId or not key then return end
  	local adv = role:getAdvData()
  	-- 校验
  	if not adv.__battleCache then return end
  	if adv.__battleCache.enemyId ~= enemyId then return end
  	local enemy = adv.battle:getEnemyById(enemyId)
  	if enemy.monsterId ~= monsterId or enemy.roomId ~= roomId or enemy.blockId ~= blockId then return end
  	adv.__battleCache = nil
  
  	
  	local status = adv:clickBlock(roomId, blockId, {player = player})
  	if not status then return end
  	SendPacket(actionCodes.Adv_endBattleRpc, MsgPack.pack({events = adv:popBackEvents()}))
  	return true
  end
  
bab30666   zhouhaihai   增加通用功能等级 字段
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
  function _M.workshopRpc(agent, data)
  	local role = agent.role
  	local msg = MsgPack.unpack(data)
  
  	local id = msg.id 
  	local count = msg.count or 1
  	local mergeData = csvdb["adv_mergeCsv"][id]
  	if not mergeData then return 1 end
  
  	if not role:isFuncOpen(FuncOpenType.AdvWS) or role:getFuncLv(FuncOpenType.AdvWS) < mergeData.unlock then return 2 end
  
  	local advWs = role.dailyData:getProperty("advWs")
  	if math.illegalNum(count, 1, mergeData.limit - (advWs[id] or 0)) then return 3 end
  
  	local cost = mergeData.formula:toNumMap()
  	for k, v in pairs(cost) do
  		cost[k] = v * count
  	end
  	if not role:checkItemEnough(cost) then return 4 end
  
  	role:costItems(cost)
  	advWs[id] = (advWs[id] or 0) + count
ad88ba14   zhouhaihai   工坊 bug
340
  	role.dailyData:updateProperty({field = "advWs", value = advWs})
bab30666   zhouhaihai   增加通用功能等级 字段
341
342
343
344
  	local reward = role:award({[id] = count})
  	SendPacket(actionCodes.Adv_workshopRpc, MsgPack.pack({reward = reward}))
  	return true
  end
12f7b52c   zhouhaihai   冒险战斗
345
  
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
346
  
23d89d13   zhouahaihai   冒险 结构
347
  return _M