Blame view

src/adv/AdvBattle.lua 6.22 KB
36c30c5c   zhouahaihai   冒险
1
  local Player, Enemy = table.unpack(require "adv.advPlayer")
46fac6f1   zhouahaihai   酱料
2
  local Buff = require "adv.AdvBuff"
32bca13b   zhouahaihai   bug
3
  local Passive = require "adv.AdvPassive"
36c30c5c   zhouahaihai   冒险
4
  local Battle = class("Battle")
46fac6f1   zhouahaihai   酱料
5
6
7
  function Battle:ctor(adv)
  	self.adv = adv
  	self.player = nil --玩家
02c4de8d   zhouahaihai   增加 固有技
8
  	self.isNewPlayer = false
a734980c   suhongyang   冒险战斗数据打完以前不存储
9
  	self.enemy = nil
46fac6f1   zhouahaihai   酱料
10
  	self.enemys = {} --怪
e459a5fc   suhongyang   战斗回合检查同步以及回合数据缓存
11
  	self.tempData = {} -- 临时回合数据
46fac6f1   zhouahaihai   酱料
12
13
14
  	self:initPlayer()
  	self:initEnemys()
  	self:initAfter()
02c4de8d   zhouahaihai   增加 固有技
15
16
17
  	if self.isNewPlayer then
  		self.player:triggerPassive(Passive.BORN_ONCE)
  	end
46fac6f1   zhouahaihai   酱料
18
19
20
21
22
23
24
  end
  
  function Battle:initAfter()
  	self.player:initAfter(self.adv.advTeam.player)
  	for _, enemy in pairs(self.enemys) do
  		enemy:initAfter(self.adv.rooms[enemy.roomId].blocks[enemy.blockId].event.enemy)
  	end
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
25
26
27
28
  	if self.adv.advTeam.enemyId then
  		local enemy = self:getEnemyById(self.adv.advTeam.enemyId)
  		self.enemy = enemy
  	end
46fac6f1   zhouahaihai   酱料
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
  end
  
  function Battle:initPlayer()
  	if not next(self.adv.advTeam.heros) then return end
  	if not self.adv.advTeam.player then
  		local hp = 0
  		local player = {}
  		player.passives = {}
  		for slot, heroId in pairs(self.adv.advTeam.heros) do
  			if self.adv.owner.heros[heroId] then
  				hp = hp + self.adv.owner.heros[heroId]:getProperty("battleV")
  				local advSkillId = csvdb["unitCsv"][self.adv.owner.heros[heroId]:getSkinId()]["adv"]
  				if advSkillId > 1000 then
  					table.insert(player.passives, {id = advSkillId, level = self.adv.owner.heros[heroId]:getSkillLevel(4)})
  				end
  			end
  		end
a41b9076   zhouhaihai   增加羁绊方法
46
47
  		local activeRelation = self.adv.owner:getHeroActiveRelation()
  		-- todo
46fac6f1   zhouahaihai   酱料
48
  		player.hp = hp
384bb077   zhouahaihai   挂机
49
  		player.atk = tonumber(string.format("%0.0f", player.hp * 0.1)) --todo 系数是临时的
e996b82a   zhouahaihai   冒险增加防御属性
50
  		player.def = 0
46fac6f1   zhouahaihai   酱料
51
52
53
  		player.miss = 0
  		player.hit = 100
  		self.adv.advTeam.player = player
02c4de8d   zhouahaihai   增加 固有技
54
  		self.isNewPlayer = true
46fac6f1   zhouahaihai   酱料
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  	end
  	self.player = Player.new(self, self.adv.advTeam.player)
  end
  
  function Battle:initEnemys()
  	for _, room in pairs(self.adv.rooms) do
  		for _, block in pairs(room.blocks) do
  			self:addEnemy(room, block)	
  		end
  	end
  end
  
  function Battle:addEnemy(room, block)
  	if block.event and (block.event.etype == AdvEventType.BOSS or block.event.etype == AdvEventType.Monster) then
  		if not block.event.enemy then
  			local enemyCsv = csvdb["event_monsterCsv"][block.event.id]
  			local enemy = {}
  			enemy.hp = enemyCsv.hp + enemyCsv.levelhp * self.adv.advInfo.level
  			enemy.atk = enemyCsv.atk + enemyCsv.levelatk * self.adv.advInfo.level
  			enemy.hit = enemyCsv.hit + enemyCsv.levelhit * self.adv.advInfo.level
  			enemy.miss = enemyCsv.miss + enemyCsv.levelmiss * self.adv.advInfo.level
e996b82a   zhouahaihai   冒险增加防御属性
76
  			enemy.def = enemyCsv.def + enemyCsv.leveldef * self.adv.advInfo.level
46fac6f1   zhouahaihai   酱料
77
78
79
80
81
  			enemy.passives = {}
  			for _, id in ipairs(enemyCsv.passive:toArray(true, "=")) do
  				table.insert(enemy.passives, {id = id})
  			end
  			block.event.enemy = enemy
46fac6f1   zhouahaihai   酱料
82
  		end
02c4de8d   zhouahaihai   增加 固有技
83
84
85
  		local player = Enemy.new(self, block.event.mId or 999, block.event.id, room.roomId, block.blockId, not block.isOpen, block.event.enemy)
  		table.insert(self.enemys, player)
  		return player
46fac6f1   zhouahaihai   酱料
86
87
88
89
90
  	end 
  end
  
  function Battle:getEnemy(roomId, blockId)
  	for _, enemy in ipairs(self.enemys) do
36c30c5c   zhouahaihai   冒险
91
  		if enemy.roomId == roomId and enemy.blockId == blockId then
46fac6f1   zhouahaihai   酱料
92
93
94
95
96
97
98
99
100
101
102
103
  			return enemy
  		end
  	end
  end
  
  function Battle:getEnemyById(id)
  	for _, enemy in ipairs(self.enemys) do
  		if enemy.id == id then
  			return enemy
  		end
  	end
  end
39a6e08b   suhongyang   冒险战斗内逻辑调整
104
105
106
107
108
109
  
  function Battle:getRBByEnemyId(enemyId)
  	local enemy = self:getEnemyById(enemyId)
  	return enemy.roomId, enemy.blockId
  end
  
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
110
111
112
113
114
115
116
  function Battle:isBattleEnd()
  	if not self.enemy then
  		return true
  	end
  end
  
  --战斗开始
ae9a74b5   suhongyang   返回miss,快速战斗逻辑
117
  function Battle:battleBegin(roomId, blockId, isQuick)
e459a5fc   suhongyang   战斗回合检查同步以及回合数据缓存
118
  	self.tempData = {} -- 清理上次战斗数据
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
119
  	if self.enemy then
e459a5fc   suhongyang   战斗回合检查同步以及回合数据缓存
120
  		self.player:reset(self.adv.advTeam.player)
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
121
122
  		self.enemy:reset(self.adv.rooms[self.enemy.roomId].blocks[self.enemy.blockId].event.enemy)
  	end
46fac6f1   zhouahaihai   酱料
123
124
  	local enemy = self:getEnemy(roomId, blockId)
  	if enemy then
8cec27ce   suhongyang   战斗开始
125
  		self.adv:backBattleBegin()
a734980c   suhongyang   冒险战斗数据打完以前不存储
126
  		self.enemy = enemy
821f2b60   suhongyang   冒险战斗完善,增加battlebe...
127
  		self.player:battleBegin()
a734980c   suhongyang   冒险战斗数据打完以前不存储
128
  		self.enemy:battleBegin()
ae9a74b5   suhongyang   返回miss,快速战斗逻辑
129
130
131
132
133
134
135
  		if not isQuick then
  			self:doBattleTurn()
  			return
  		end
  		while not enemy.isDead and not self.player.isDead do
  			self:doBattleTurn()
  		end
39a6e08b   suhongyang   冒险战斗内逻辑调整
136
137
138
  	end
  end
  
e459a5fc   suhongyang   战斗回合检查同步以及回合数据缓存
139
140
141
142
143
144
145
  -- 检查回合数同步
  function Battle:checkTurn(turn)
  	if self.tempData[turn] then
  		return true
  	end
  end
  
39a6e08b   suhongyang   冒险战斗内逻辑调整
146
147
  -- 战斗内一回合
  function Battle:doBattleTurn()
a734980c   suhongyang   冒险战斗数据打完以前不存储
148
  	local enemy = self.enemy
39a6e08b   suhongyang   冒险战斗内逻辑调整
149
150
151
152
153
154
155
156
157
158
159
160
  	-- 玩家先出手
  	self.adv:backAtk(nil, enemy.id)
  	self:doPlayerTurn(self.player, enemy)
  	--是否无法攻击
  	if not enemy.isDead and not enemy:hadBuff(Buff.CANT_BACK_ATK) then
  		self.adv:backAtk(enemy.id, nil)
  		self:doPlayerTurn(enemy, self.player)
  	end
  	-- 判定死亡
  	if enemy.isDead or self.player.isDead then
  		local deadPlayer = enemy.isDead and enemy or self.player
  		deadPlayer:battleEnd()
a734980c   suhongyang   冒险战斗数据打完以前不存储
161
  		self.enemy = nil
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
162
163
  	else
  		self.adv:backTurnEnd()
46fac6f1   zhouahaihai   酱料
164
  	end
a88a35fd   suhongyang   Fix bug
165
  	self:getTempDB()
46fac6f1   zhouahaihai   酱料
166
  end
39a6e08b   suhongyang   冒险战斗内逻辑调整
167
168
169
  
  --战斗内角色回合逻辑
  function Battle:doPlayerTurn(atkPlayer, hurtPlayer)
7c55db1f   suhongyang   Buff逻辑完善,buff生效次数...
170
  	atkPlayer:beforeTurn()
42f2d1d3   suhongyang   战斗内技能序列逻辑
171
172
173
174
175
  	if #(atkPlayer.skillOrder) > 0 then
  		atkPlayer:releaseSpecialSkill()
  	else
  		hurtPlayer:hurt(atkPlayer:getHurtValue(), atkPlayer, {hurtType = 1})
  	end
7c55db1f   suhongyang   Buff逻辑完善,buff生效次数...
176
177
178
  	atkPlayer:afterTurn()
  	atkPlayer:clearTurn()
  end
39a6e08b   suhongyang   冒险战斗内逻辑调整
179
  
46fac6f1   zhouahaihai   酱料
180
181
  --触发全员被动技能
  function Battle:triggerPassive(condType, params)
02c4de8d   zhouahaihai   增加 固有技
182
183
184
185
  	self.player:triggerPassive(condType, params)
  	for _, enemy in ipairs(self.enemys) do
  		enemy:triggerPassive(condType, params)
  	end
46fac6f1   zhouahaihai   酱料
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
  end
  
  --回合
  function Battle:afterRound()
  	self.player:afterRound()
  	table.sort(self.enemys, function(e1, e2)
  		return e1.id < e2.id
  	end)
  	for _, enemy in ipairs(self.enemys) do
  		enemy:afterRound()
  	end
  	self.player:clearRound()
  	for _, enemy in ipairs(self.enemys) do
  		enemy:clearRound()
  	end
  	for i = #self.enemys, 1, -1 do
  		if self.enemys[i].isDead then
  			self.adv:enemyDead(self.enemys[i].roomId, self.enemys[i].blockId)
  			self.enemys[i]:clear()
  			table.remove(self.enemys, i)
  		end
  	end
ec87b4a5   zhouahaihai   冒险 完善
208
  
46fac6f1   zhouahaihai   酱料
209
  	if self.player.isDead then
4b7c7c96   zhouahaihai   增加 清空 挂机 冒险gm 角色经验
210
  		self.adv:over(false)
46fac6f1   zhouahaihai   酱料
211
212
213
  	end
  end
  
e459a5fc   suhongyang   战斗回合检查同步以及回合数据缓存
214
215
216
217
218
219
220
221
222
223
  -- 写入临时数据
  function Battle:getTempDB()
  	local turnDB = {}
  	if self.enemy then
  		turnDB.enemy = self.enemy:getDB()
  	end
  	turnDB.player = self.player:getDB()
  	table.insert(self.tempData, turnDB)
  end
  
46fac6f1   zhouahaihai   酱料
224
225
  --写入数据
  function Battle:getDB()
ae20365b   suhongyang   Revert "修改冒险战斗逻辑"
226
227
228
229
230
231
  	if not self.enemy then
  		self.adv.advTeam.enemyId = nil
  	else
  		self.adv.advTeam.enemyId = self.enemy.id
  		return
  	end
46fac6f1   zhouahaihai   酱料
232
233
234
235
236
  	self.adv.advTeam.player = self.player:getDB()
  	for _, enemy in ipairs(self.enemys) do
  		local block = self.adv.rooms[enemy.roomId].blocks[enemy.blockId]
  		block.event.enemy = enemy:getDB()
  	end
46fac6f1   zhouahaihai   酱料
237
238
  end
  
36c30c5c   zhouahaihai   冒险
239
  return Battle