local BattleHelper = require "app/module/battle/helper/battle_helper" local BattleScheduler = require "app/module/battle/helper/battle_scheduler" local BattleController = class("BattleController") local BATTLE_BOARD_SKILL_HANDLE = require "app/module/battle/skill/battle_board_skill_handle" local BATTLE_ROGUE_SKILL_HANDLE = require "app/module/battle/skill/battle_rogue_skill_handle" local ELIMINATION_TOUCH_EVENT = GConst.ELIMINATION_TOUCH_EVENT local BattleConst = GConst.BattleConst -- *************各个子模块的战斗需要重写的方法 START************* function BattleController:getChapterId() return 0 end function BattleController:getInitBoard() return {} end function BattleController:getNotInvolvedSkills() return {} end function BattleController:getSealElementType() return {} end -- 战斗对应的ui function BattleController:getBattleUIPath() return "app/ui/battle/battle_ui" end -- 战斗结束 function BattleController:controllBattleEnd() end -- 不同模块的战斗需要初始化的东西 function BattleController:initOther() end -- 需要额外加载的资源 function BattleController:loadOtherRes(callback) return callback() end -- 一共有多少波 function BattleController:getMaxWave() return 1 end function BattleController:initDefUnits(callback) callback() end function BattleController:tick(dt) end function BattleController:onLinkChange() for posId, entity in pairs(self.battleData:getGridEnties()) do if entity:getCell() then entity:getCell():showHighLight(false) end end local sequence = self.battleData:getGridSequence() local elementTypeMap = {} local posIdMap = {} local mainElementType for _, info in ipairs(sequence) do posIdMap[info.posId] = true local entity = self.battleData:getGridEntity(info.posId) if not entity:getSkillId() then local elementType = entity:getElementType() elementTypeMap[elementType] = (elementTypeMap[elementType] or 0) + 1 mainElementType = elementType end if entity:getCell() then entity:getCell():showHighLight(true) end end for posId, info in pairs(self.battleData:getSkillInfluenceGrids()) do local entity = self.battleData:getGridEntity(posId) if not posIdMap[posId] then posIdMap[posId] = true if not entity:getSkillId() then local elementType = entity:getElementType() elementTypeMap[elementType] = (elementTypeMap[elementType] or 0) + 1 end end if entity:getCell() and info.direction ~= BattleConst.BOARD_RANGE_TYPE.RANDOM then entity:getCell():showCircle(true) end end self.battleUI:refreshSkill(elementTypeMap) Logger.logHighlight("---------onLinkChange--------------") Logger.printTable(elementTypeMap) if mainElementType then Logger.logHighlight("mainElementType " .. mainElementType) end end -- *************各个子模块的战斗需要重写的方法 END************* function BattleController:ctor() self.battleData = DataManager.BattleData end function BattleController:init(params) params = params or {} self.chapterId = self:getChapterId() self.waveIndex = 1 self.atkUnits = {} self.defUnits = {} self.allUnits = {} self.effectTexts = {} self.instructions = {} self.time = 0 self.battleData:init() BattleScheduler:init() BattleHelper:init() self:prepareFight() self:battleStart() end function BattleController:prepareFight() local count = 0 local totalCount = 3 local function onPreloadFinished() count = count + 1 if count == totalCount then self:onLoadComplete() end end UIManager:closeAllUI() self.battleUI = UIManager:showUI(self:getBattleUIPath()) self.battleUI:setController(self) self.battleUI:addLoadUICompleteListener(function() BattleHelper:setEffectTextCache(self.battleUI:getBattleNumber()) self:initAtkUnits(onPreloadFinished) self:initDefUnits(onPreloadFinished) self:generateBoard() end) self:loadOtherRes(onPreloadFinished) end function BattleController:initAtkUnits(callback) local atkTeam = self.battleData:getAtkTeam() local count = 0 local totalCount = atkTeam:getMembersCount() local function onloadFinished() count = count + 1 if count == totalCount then callback() end end local members = atkTeam:getAllMembers() for k, v in pairs(members) do local modelId = v:getModelId() BattleHelper:loadBattleHeroModel(modelId, self.battleUI:getBattleNode(), function(spineObject) local heroComp = spineObject:addLuaComponent(BattleConst.TYPEOF_LUA_COMP.BATTLE_HERO_COMPONENT) heroComp:initWithEntity(modelId, v, self) self.atkUnits[v:getMatchType()] = heroComp table.insert(self.allUnits, heroComp) if not v:getIsMainUnit() then heroComp:hideOutsideScreen() end onloadFinished() end) end if totalCount == 0 then callback() end end function BattleController:getOtherSideMainUnit(side) if side == BattleConst.SIDE_ATK then return self.defMainUnit else return self.atkMainUnit end end function BattleController:onLoadComplete() self:battleStart() end function BattleController:battleStart() self.isBattleStart = true self.tickSid = BattleScheduler:scheduleGlobal(function(dt) self:_tick(dt) end, 0) end function BattleController:onTouchEvent(eventType, posId) local entity = self.battleData:getGridEntity(posId) if not entity:canLink() then return end if eventType == ELIMINATION_TOUCH_EVENT.DOWN then if #self.battleData:getGridSequence() > 0 then self.battleData:clearGridSequence() end self.battleData:insertGridSequence(posId, self:snapshotBoard()) local skillEntity = self.battleData:getSkillEntityBySkillId(entity:getSkillId()) local maskElementType = entity:getElementType(skillEntity) self.battleUI:showBoardMask(maskElementType) self:findSkillInfluenceGrids() self:onLinkChange() elseif eventType == ELIMINATION_TOUCH_EVENT.ENTER then local sequence = self.battleData:getGridSequence() local info = sequence[#sequence] local lastPosId = info and info.posId if not lastPosId then return end local outLineMap = BattleConst.GRID_OUT_LINE_POS_ID[lastPosId] if not outLineMap or not outLineMap[posId] then return end if self.battleData:alreadyInsertSequence(posId) then local info = sequence[#sequence - 1] local beforePosId = info and info.posId if not beforePosId then return end if beforePosId == posId then -- 进入的是倒数第二个,则移除倒数第一个 local snapshot = self.battleData:removeGridSequence(lastPosId) if snapshot then -- 如果有快照,则恢复一次 for posId, info in pairs(snapshot) do local entity = self.battleData:getGridEntity(posId) if entity then entity:setInfoBySnapshop(info) end end end local lastEntity = self.battleData:getGridEntity(beforePosId) local lastSkillEntity = self.battleData:getSkillEntityBySkillId(lastEntity:getSkillId()) local maskElementType = lastEntity:getElementType(lastSkillEntity) self.battleUI:showBoardMask(maskElementType) self:findSkillInfluenceGrids() self:onLinkChange() return end end local skillId = entity:getSkillId() local skillEntity = self.battleData:getSkillEntityBySkillId(skillId) local elementType = entity:getElementType(skillEntity) local lastEntity = self.battleData:getGridEntity(lastPosId) local lastSkillId = lastEntity:getSkillId() local lastSkillEntity = self.battleData:getSkillEntityBySkillId(lastSkillId) local lastElementType = lastEntity:getElementType(lastSkillEntity) if skillEntity and self.battleData:getSequenceHadSkill() then return end if not elementType or not lastElementType then else if lastElementType ~= elementType then return end end local maskElementType = elementType or lastElementType self.battleUI:showBoardMask(maskElementType) self.battleData:insertGridSequence(posId, self:snapshotBoard()) if lastEntity:getNeedChangePos() and not entity:getNeedChangePos() then -- 需要移动到队列末尾 local lastSkillId = lastEntity:getSkillId() local skillId = entity:getSkillId() self:setGridSkillId(lastPosId, skillId) self:setGridSkillId(posId, lastSkillId) end local newElementType = elementType or lastElementType if newElementType then entity:setElementType(newElementType) lastEntity:setElementType(newElementType) end entity:addLinkSkillCount() self:findSkillInfluenceGrids() self:onLinkChange() elseif eventType == ELIMINATION_TOUCH_EVENT.EXIT then else -- 取消和抬起 self.battleUI:showBoardMask(nil) local sequence = self.battleData:getGridSequence() local count = #sequence if count < BattleConst.ELIMINATION_MIN_COUNT then if count <= 0 then self.battleData:clearGridSequence() self:onLinkChange() return end local snapshot = self.battleData:removeGridSequence(sequence[1].posId) if snapshot then -- 如果有快照,则恢复一次 for posId, info in pairs(snapshot) do local entity = self.battleData:getGridEntity(posId) if entity then entity:setInfoBySnapshop(info) end end end self.battleData:clearGridSequence() self:onLinkChange() return end self:onLinkOver() end end function BattleController:onLinkOver() local sequence = self.battleData:getGridSequence() local count = #sequence if count < BattleConst.ELIMINATION_MIN_COUNT then return end local skillId = self.battleData:getSequenceHadSkill() local skillEntity local linkElementType local influenceElementType if skillId then skillEntity = self.battleData:getSkillEntityBySkillId(skillId) end local elementTypeMap = {} local eliminationPosIds = {} local boomGridIds = {} for _, info in ipairs(sequence) do if not eliminationPosIds[info.posId] then local entity = self.battleData:getGridEntity(info.posId) if not entity:getSkillId() then local elementType = entity:getElementType() elementTypeMap[elementType] = (elementTypeMap[elementType] or 0) + 1 linkElementType = elementType end local outline = BattleConst.GRID_OUT_LINE_POS_ID[info.posId] for aroundPosId, _ in pairs(outline) do boomGridIds[aroundPosId] = true end local entity = self.battleData:getGridEntity(info.posId) entity:setIsIdle(true) eliminationPosIds[info.posId] = true end end for posId, _ in pairs(self.battleData:getSkillInfluenceGrids()) do local entity = self.battleData:getGridEntity(posId) if not entity:getIsIdle() then if entity:isEmptyIdle() then entity:setIsIdle(true) if not eliminationPosIds[posId] then eliminationPosIds[posId] = true table.insert(sequence, {posId = posId}) end if not entity:getSkillId() then local elementType = entity:getElementType() elementTypeMap[elementType] = (elementTypeMap[elementType] or 0) + 1 if not influenceElementType then influenceElementType = {} end influenceElementType[elementType] = true end else boomGridIds[posId] = true end end end for posId, status in pairs(boomGridIds) do if not eliminationPosIds[posId] then local entity = self.battleData:getGridEntity(posId) if entity then local elementTypeInvalid = entity:isElmentTypeInvalid() entity:addAroundEliminationCount() if entity:getIsIdle() then eliminationPosIds[posId] = true table.insert(sequence, {posId = posId, noAni = elementTypeInvalid}) if not entity:getSkillId() and not elementTypeInvalid then local elementType = entity:getElementType() elementTypeMap[elementType] = (elementTypeMap[elementType] or 0) + 1 end end end end end self.battleData:addSkillEnergy(elementTypeMap) self.battleData:clearGridSequence() self.battleUI:disableUITouch() self.battleUI:eliminationAni(sequence, function() self:generateInstructions(skillEntity, linkElementType, influenceElementType, elementTypeMap) self:exeInstructions(function() self:fillBoard() end) end) end function BattleController:fillBoard() local pathMap = {} local columnCount = {} local gridMap = {} for c = 1, BattleConst.COLUMN_COUNT do for r = BattleConst.ROW_COUNT, 1, -1 do local posId = ModuleManager.BattleManager:getPosId(r, c) local entity = self.battleData:getGridEntity(posId) if entity:getIsIdle() then self:fillThisPos(posId, columnCount, gridMap) end end end while true do local find = false for c = 1, BattleConst.COLUMN_COUNT do local list = gridMap[c] if list and list[1] then -- 此列有需要填充的元素 local entity = table.remove(list, 1) if entity then self.battleData:setGridInfo(entity:getPosId(), self:getRandomGridInfo()) end find = true end end if not find then break end end for c = 1, BattleConst.COLUMN_COUNT do for r = BattleConst.ROW_COUNT, 1, -1 do local posId = ModuleManager.BattleManager:getPosId(r, c) local entity = self.battleData:getGridEntity(posId) if #entity:getPath() > 0 then pathMap[posId] = entity:getPath() entity:clearPath() end end end self.battleUI:fallGrid(pathMap, function() self:onFillBoardOver() self.battleUI:enableUITouch() ---- 临时 -- local list = {BattleConst.GRID_TYPE.SNOW_BOX, BattleConst.GRID_TYPE.SOLID_SNOW, BattleConst.GRID_TYPE.VINES, BattleConst.GRID_TYPE.ICE} -- local gridType = list[math.random(1, 4)] -- self:generateGridType(gridType) -- ModuleManager.BattleManager:showSelectSkillUI(self:getRandomSkillList()) -- self:generateBoard() end) end function BattleController:onFillBoardOver() self:generateSkill() self.battleUI:refreshSkill() end function BattleController:generateInstructions(skillEntity, elementType, influenceElementType, elementTypeMap) ---- 加buff if skillEntity then if skillEntity:getLinkAtkp() > 0 and elementType then local attrType = BattleConst.ELEMENT_TYPE_ATKP_NAME[elementType] if attrType then table.insert(self.instructions, { name = BattleConst.INSTRUCTION_NAME.ADD_CUR_ROUND_ATTR, attr = { type = attrType, num = skillEntity:getLinkAtkp() } }) end end if skillEntity:getInInfluenceAtkp() > 0 and influenceElementType then for elementType, _ in pairs(influenceElementType) do local attrType = BattleConst.ELEMENT_TYPE_ATKP_NAME[elementType] if attrType then table.insert(self.instructions, { name = BattleConst.INSTRUCTION_NAME.ADD_CUR_ROUND_ATTR, attr = { type = attrType, num = skillEntity:getInInfluenceAtkp() } }) end end end end local elementTypeCount = 0 ---- 援助 for element, count in pairs(elementTypeMap) do if element == elementType then elementTypeCount = count else table.insert(self.instructions, { name = BattleConst.INSTRUCTION_NAME.ASSISTING, count = count, skillMatch = element, }) end end ---- 普攻 if elementTypeCount > 0 then table.insert(self.instructions, { name = BattleConst.INSTRUCTION_NAME.GENERAL_ATTACK, count = elementTypeCount, skillMatch = elementType }) end ---- 技能 if skillEntity then table.insert(self.instructions, { name = BattleConst.INSTRUCTION_NAME.PLAY_SKILL, skillMatch = elementType }) end end function BattleController:exeInstructions(callback) Logger.logHighlight("--------exeInstructions----------") Logger.printTable(self.instructions) if #self.instructions <= 0 then callback() return end local instruction = table.remove(self.instructions) local func = BattleController._doInstruction[instruction.name] if func then func(self, instruction, callback) else callback() end end function BattleController:generateBoard() local boardList, _ = self:getInitBoard() if self.curBoardIndex and self.curBoardIndex >= #boardList then return end if not self.battleUI then return end local skillCount = 0 local skillList = {} for posId, entity in pairs(self.battleData:getGridEnties()) do if entity:getSkillId() then table.insert(skillList, {skillId = entity:getSkillId(), posId = posId}) skillCount = skillCount + 1 end end self.battleUI:cacheSkillAni(skillList, false, function() self.curBoardIndex = (self.curBoardIndex or 0) + 1 local board = boardList[self.curBoardIndex] self.battleData:refreshBoard(board) self.battleUI:initGridCell() if skillCount > 0 then local posidList = {} for posId, entity in pairs(self.battleData:getGridEnties()) do if entity:isEmptyIdle() then table.insert(posidList, posId) end end posidList = table.shuffle(posidList) local newSkillId = {} for index, info in ipairs(skillList) do if posidList[1] then newSkillId[index] = info newSkillId[index].posId = table.remove(posidList) else break end end self.battleUI:cacheSkillAni(newSkillId, true) end end) end function BattleController:generateSkill() local map = {} for _, skillEntity in pairs(self.battleData:getSkillEntities()) do if skillEntity:getEnergyEnough() then map[skillEntity:getPosition()] = skillEntity:getSkillId() end end for elementType, skillId in pairs(map) do local list = self:getSkillElementList(elementType, 1, true) for _, posId in ipairs(list) do self:setGridSkillId(posId, skillId) end end end function BattleController:setGridSkillId(posId, skillId) local entity = self.battleData:getGridEntity(posId) if entity then entity:setSkilId(skillId) local skillEntity = self.battleData:getSkillEntityBySkillId(skillId) if skillEntity and entity:getElementType() ~= skillEntity:getPosition() then entity:setElementType(skillEntity:getPosition()) end end end function BattleController:generateGridType(gridType) if not gridType then return end local list = {} local count = 0 for posId, entity in pairs(self.battleData:getGridEnties()) do if entity:isEmptyIdle() then table.insert(list, entity) count = count + 1 end end if count > 0 then local entity = list[math.random(1, count)] self.battleData:setGridInfo(entity:getPosId(), {gridType = gridType, elementType = entity:getElementType()}) end end function BattleController:getSkillElementList(elementType, count, useAlternate) local result = {} local gridEntities = self.battleData:getGridEnties() if not gridEntities then return result end local sameElementList = {} local alternateList = {} local addCount = 0 for row = 1, BattleConst.ROW_COUNT do for column = 1, BattleConst.COLUMN_COUNT do local posId = ModuleManager.BattleManager:getPosId(row, column) local entity = gridEntities[posId] if entity and entity:canChangeInfo() then if entity:getElementType() == elementType then table.insert(sameElementList, posId) else table.insert(alternateList, posId) end end end local remainCount = count - addCount if remainCount <= 0 then return result end for i = 1, remainCount do if not sameElementList[i] then break end table.insert(result, table.remove(sameElementList, math.random(1, #sameElementList))) addCount = addCount + 1 if addCount >= count then return result end end if addCount < count and useAlternate then for i = 1, count - addCount do if not alternateList[1] then break end table.insert(result, table.remove(alternateList, math.random(1, #alternateList))) addCount = addCount + 1 if addCount >= count then return result end end end if addCount >= count then return result end end return result end ---- 从一个点直接遍历所有相关的路径 function BattleController:fillThisPos(posId, columnCount, gridMap) local entity = self.battleData:getGridEntity(posId) if not entity or not entity:getIsIdle() then return end local list = BattleConst.UP_LINE_FILL_LIST[posId] if not list[1] then -- 第一排 local rc = ModuleManager.BattleManager:getPosRC(posId) local c = rc.c if not columnCount[c] then columnCount[c] = 0 end columnCount[c] = columnCount[c] + 1 local fallPosId = posId local fallEntity = self.battleData:getGridEntity(fallPosId) if not fallEntity then -- 异常情况,理论上不可能不存在 return end local newStartPosId for i = columnCount[c], 1, -1 do newStartPosId = ModuleManager.BattleManager:getFirstLineLastRowPosId(i, c) local curPos = ModuleManager.BattleManager:getPosInfo(newStartPosId) fallEntity:addPath({x = curPos.x, y = curPos.y}) end local curPos = ModuleManager.BattleManager:getPosInfo(posId) fallEntity:addPath({x = curPos.x, y = curPos.y}) self.battleData:exchangeGridEntities(posId, fallPosId) if not gridMap[c] then gridMap[c] = {} end table.insert(gridMap[c], fallEntity) else for index, fallPosId in ipairs(list) do local fallEntity = self.battleData:getGridEntity(fallPosId) if not fallEntity then -- 异常情况,理论上不可能不存在 return end if fallEntity then if not fallEntity:isCantFallType() then if fallEntity:getIsIdle() then self:fillThisPos(fallPosId, columnCount, gridMap) end fallEntity = self.battleData:getGridEntity(fallPosId) if not fallEntity:getIsIdle() then if not fallEntity:getPath()[1] then local curPos = ModuleManager.BattleManager:getPosInfo(fallPosId) fallEntity:addPath({x = curPos.x, y = curPos.y}) end local curPos = ModuleManager.BattleManager:getPosInfo(posId) fallEntity:addPath({x = curPos.x, y = curPos.y}) self.battleData:exchangeGridEntities(posId, fallPosId) self:fillThisPos(fallPosId, columnCount, gridMap) return end end end end end end function BattleController:getRandomGridInfo() local list, fixedRandomGrid = self:getInitBoard() local fixedRandomList = fixedRandomGrid[self.curBoardIndex] local gridType = 0 local elementType if fixedRandomList and fixedRandomList[1] then elementType = table.remove(fixedRandomList, 1) else local map = self.battleData:getElementTypeMap() local indexs = {} local typeList = {} for typeName, typeNum in pairs(BattleConst.ELEMENT_TYPE) do if not self:getSealElementType()[typeNum] and self.battleData:getSkillEntityByElement(typeNum) then local weight = ((map[typeNum] or 0) + 1) * BattleConst.ELEMENT_WIGHT if weight > BattleConst.MAX_ELEMENT_WIGHT then weight = BattleConst.MAX_ELEMENT_WIGHT end table.insert(indexs, weight) table.insert(typeList, typeNum) end end local index = GFunc.getRandomIndex(indexs) elementType = typeList[index] end return {gridType = gridType, elementType = elementType} end function BattleController:findSkillInfluenceGrids() local girds = self.battleData:clearSkillInfluenceGrids() for posId, _ in pairs(girds) do local entity = self.battleData:getGridEntity(posId) if entity:getCell() then entity:getCell():showCircle(false) end end local sequence = self.battleData:getGridSequence() local sequenceEntities = {} for _, info in ipairs(sequence) do local entity = self.battleData:getGridEntity(info.posId) table.insert(sequenceEntities, entity) end for _, info in ipairs(sequence) do local entity = self.battleData:getGridEntity(info.posId) local skillId = entity:getSkillId() if skillId then local skillEntity = self.battleData:getSkillEntityBySkillId(skillId) if skillEntity then BATTLE_BOARD_SKILL_HANDLE.activeBoardSkill(info.posId, skillEntity, self.battleData:getGridEnties(), sequenceEntities) end end end end function BattleController:getRandomSkillList(getCount) getCount = getCount or BattleConst.SKILL_SELECT_COUNT local result = {} local cfg = ConfigManager:getConfig("skill_rogue") local skillPool = self.battleData:getSkillPool() local map = {} local count = 0 local newSkillPool = {} local skillWeight = {} for _, skillId in ipairs(skillPool) do local skillCfg = cfg[skillId] if skillCfg and not skillCfg.limit_times or self.battleData:getSkillCount(skillId) < skillCfg.limit_times then if not map[skillId] then table.insert(newSkillPool, skillId) table.insert(skillWeight, skillCfg.weight) count = count + 1 map[skillId] = true end end end if count > 0 then local index = GFunc.getRandomIndex(skillWeight) local skillId = table.remove(newSkillPool, index) table.remove(skillWeight, index) count = count - 1 table.insert(result, skillId) getCount = getCount - 1 end for skillId, info in ipairs(cfg) do if not self:getNotInvolvedSkills()[skillId] then if info.universal then if not info.limit_times or self.battleData:getSkillCount(skillId) < info.limit_times then if not map[skillId] then table.insert(newSkillPool, skillId) table.insert(skillWeight, info.weight) count = count + 1 end end end end end for i = 1, getCount do local index = GFunc.getRandomIndex(skillWeight) local skillId = table.remove(newSkillPool, index) table.remove(skillWeight, index) count = count - 1 table.insert(result, skillId) end result = table.shuffle(result) return result end function BattleController:onSelectSkill(skillId) self.battleData:addSkillCount(skillId) BATTLE_ROGUE_SKILL_HANDLE.takeEffect(skillId, self.battleData, self) end function BattleController:changeElementType(count, elementType) local list = {} for _, entity in pairs(self.battleData:getGridEnties()) do if entity:canChangeInfo() and entity:getElementType() ~= elementType then table.insert(list, entity) end end for i = 1, count do if not list[1] then break end local entity = table.remove(list, math.random(1, #list)) if entity then entity:setElementType(elementType) end end end function BattleController:addHeroAttr(attrName, value) Logger.logHighlight("------addHeroAttr------ " .. attrName .. " " .. value) -- if attrName == then -- -- body -- elseif attrName == then -- -- body -- elseif attrName == then' -- -- body -- elseif attrName == then -- -- body -- elseif attrName == then -- -- body -- else -- end end function BattleController:changeSkillId(elementType, skillId) Logger.logHighlight("------changeSkillId------ " .. elementType .. " " .. skillId) end function BattleController:addSkillReleaseCount(elementType, count) Logger.logHighlight("------addSkillReleaseCount------ " .. elementType .. " " .. count) end function BattleController:addSkillEffectParams(elementType, effect) Logger.logHighlight("------addSkillEffectParams------ " .. elementType .. " " .. json.encode(effect)) end function BattleController:addSkillRound(elementType, effect) Logger.logHighlight("------addSkillRound------ " .. elementType .. " " .. json.encode(effect)) end function BattleController:addSkillEffect(elementType, effects) Logger.logHighlight("------addSkillEffect------ " .. elementType .. " " .. json.encode(effects)) end ---- 快照一次棋盘 function BattleController:snapshotBoard() local snapshot = {} for _, entity in pairs(self.battleData:getGridEnties()) do snapshot[entity:getPosId()] = entity:getSnapshoptInfo() end return snapshot end function BattleController:_tick(dt) if self.isPause then return end self.time = self.time + dt for k, v in ipairs(self.allUnits) do v:tick(dt) end local count = #self.effectTexts for i = count, 1, -1 do self.effectTexts[i]:tick(dt) if self.effectTexts[i]:getDuration() < 0 then BattleHelper:recycleEffectText(self.effectTexts[i]) table.remove(self.effectTexts, i) end end self:tick(dt) end function BattleController:clear() if self.alreadyClear then return end self.alreadyClear = true if self.tickSid then BattleScheduler:unscheduleGlobal(self.tickSid) self.tickSid = nil end BattleScheduler:clear() BattleHelper:clear() end function BattleController:endBattleAndExit() ModuleManager.BattleManager:exitBattle() end function BattleController:showEffectNumber(num, x, y) local effectTextComp = BattleHelper:getEffectText(self.battleUI:getNumberNode()) effectTextComp:showEffectNumber(num, x, y) table.insert(self.effectTexts, effectTextComp) end local function _addCurRoundAttr(self, instruction, callback) callback() end local function _assisting(self, instruction, callback) callback() end local function _generalAttack(self, instruction, callback) local hero = self.atkUnits[instruction.skillMatch] if hero == nil then return callback() end self.atkMainUnit = hero hero:useNormalSkill(instruction.count, callback) end local function _playSkill(self, instruction, callback) callback() end BattleController._doInstruction = { [BattleConst.INSTRUCTION_NAME.ADD_CUR_ROUND_ATTR] = _addCurRoundAttr, [BattleConst.INSTRUCTION_NAME.ASSISTING] = _assisting, [BattleConst.INSTRUCTION_NAME.GENERAL_ATTACK] = _generalAttack, [BattleConst.INSTRUCTION_NAME.PLAY_SKILL] = _playSkill, } return BattleController