From 84ec236d1c62bd1059dbab358ce35db813085fec Mon Sep 17 00:00:00 2001 From: Eduardo Dantas Date: Sat, 27 Jan 2024 08:17:38 -0300 Subject: [PATCH 1/2] fix: remove spear life leech amount (#2155) Resolves #2135 --- data/items/items.xml | 2 -- 1 file changed, 2 deletions(-) diff --git a/data/items/items.xml b/data/items/items.xml index c57bafaf745..666ee75b1f5 100644 --- a/data/items/items.xml +++ b/data/items/items.xml @@ -7360,8 +7360,6 @@ - - From 57b3fb498ed2aa00314073d05819a338c4d0f552 Mon Sep 17 00:00:00 2001 From: Luan Luciano Date: Sat, 27 Jan 2024 08:39:16 -0300 Subject: [PATCH 2/2] improve: boss mechanics Outburst (#2130) Using BossLever system. More clean core. --------- Co-authored-by: Eduardo Dantas --- data-otservbr-global/lib/core/storages.lua | 7 +- .../heart_of_destruction/outburst_lever.lua | 169 ++++-------------- .../charging_out_death.lua | 11 +- .../heart_of_destruction/outburst_charge.lua | 61 +++---- .../spells/monster/outburst_explode.lua | 16 +- 5 files changed, 82 insertions(+), 182 deletions(-) diff --git a/data-otservbr-global/lib/core/storages.lua b/data-otservbr-global/lib/core/storages.lua index 460a751f2ba..34487c7adf6 100644 --- a/data-otservbr-global/lib/core/storages.lua +++ b/data-otservbr-global/lib/core/storages.lua @@ -3065,10 +3065,11 @@ GlobalStorage = { }, }, HeartOfDestruction = { - -- Reserved storage from 60172 - 60180 + -- Reserved storage from 60172 - 60190 ChargedAnomaly = 60172, - EradicatorWeak = 60178, - EradicatorReleaseT = 60179, + OutburstStage = 60180, + OutburstHealth = 60181, + OutburstChargingKilled = 60182, }, FuryGates = 65000, Yakchal = 65001, diff --git a/data-otservbr-global/scripts/actions/quests/heart_of_destruction/outburst_lever.lua b/data-otservbr-global/scripts/actions/quests/heart_of_destruction/outburst_lever.lua index c1838f42fc4..6e377900bde 100644 --- a/data-otservbr-global/scripts/actions/quests/heart_of_destruction/outburst_lever.lua +++ b/data-otservbr-global/scripts/actions/quests/heart_of_destruction/outburst_lever.lua @@ -1,134 +1,41 @@ --- FUNCTIONS -local function doCheckArea() - local upConer = { x = 32223, y = 31273, z = 14 } -- upLeftCorner - local downConer = { x = 32246, y = 31297, z = 14 } -- downRightCorner - - for i = upConer.x, downConer.x do - for j = upConer.y, downConer.y do - for k = upConer.z, downConer.z do - local room = { x = i, y = j, z = k } - local tile = Tile(room) - if tile then - local creatures = tile:getCreatures() - if creatures and #creatures > 0 then - for _, creature in pairs(creatures) do - local player = Player(creature) - if player then - return true - end - end - end - end - end - end - end - return false -end - -local function clearArea() - local upConer = { x = 32223, y = 31273, z = 14 } -- upLeftCorner - local downConer = { x = 32246, y = 31297, z = 14 } -- downRightCorner - - for i = upConer.x, downConer.x do - for j = upConer.y, downConer.y do - for k = upConer.z, downConer.z do - local room = { x = i, y = j, z = k } - local tile = Tile(room) - if tile then - local creatures = tile:getCreatures() - if creatures and #creatures > 0 then - for _, creatureUid in pairs(creatures) do - local creature = Creature(creatureUid) - if creature then - if creature:isPlayer() then - creature:teleportTo({ x = 32208, y = 31372, z = 14 }) - elseif creature:isMonster() then - creature:remove() - end - end - end - end - end - end - end - end - stopEvent(areaOutburst1) -end --- FUNCTIONS END - -local heartDestructionOutburst = Action() -function heartDestructionOutburst.onUse(player, item, fromPosition, itemEx, toPosition) - local config = { - playerPositions = { - Position(32207, 31284, 14), - Position(32207, 31285, 14), - Position(32207, 31286, 14), - Position(32207, 31287, 14), - Position(32207, 31288, 14), - }, - - newPos = { x = 32234, y = 31292, z = 14 }, - } - - local pushPos = { x = 32207, y = 31284, z = 14 } - - if item.actionid == 14331 then - if item.itemid == 8911 then - if player:getPosition().x == pushPos.x and player:getPosition().y == pushPos.y and player:getPosition().z == pushPos.z then - local storePlayers = {} - for i = 1, #config.playerPositions do - local tile = Tile(Position(config.playerPositions[i])) - if tile then - local playerTile = tile:getTopCreature() - if playerTile and playerTile:isPlayer() then - storePlayers[#storePlayers + 1] = playerTile - end - end - end - - if doCheckArea() == false then - clearArea() - - local players - - for i = 1, #storePlayers do - players = storePlayers[i] - if not player:canFightBoss("Outburst") then - return players:sendTextMessage(MESSAGE_EVENT_ADVANCE, "You need wait to fight again") - end - config.playerPositions[i]:sendMagicEffect(CONST_ME_POFF) - players:teleportTo(config.newPos) - players:setBossCooldown("Outburst", os.time() + configManager.getNumber(configKeys.BOSS_DEFAULT_TIME_TO_FIGHT_AGAIN)) - end - Position(config.newPos):sendMagicEffect(11) - - areaOutburst1 = addEvent(clearArea, 15 * 60000) - - Game.createMonster("Spark of Destruction", { x = 32229, y = 31282, z = 14 }, false, true) - Game.createMonster("Spark of Destruction", { x = 32230, y = 31287, z = 14 }, false, true) - Game.createMonster("Spark of Destruction", { x = 32237, y = 31287, z = 14 }, false, true) - Game.createMonster("Spark of Destruction", { x = 32238, y = 31282, z = 14 }, false, true) - Game.createMonster("Outburst", { x = 32234, y = 31284, z = 14 }, false, true) - - outburstStage = 0 - outburstHealth = 290000 - - local vortex = Tile({ x = 32225, y = 31285, z = 14 }):getItemById(23482) - if vortex then - vortex:transform(23483) - vortex:setActionId(14350) - end - else - player:sendTextMessage(19, "Someone is in the area.") - end - else - return true +local config = { + boss = { + name = "Outburst", + position = Position(32234, 31284, 14), + }, + playerPositions = { + { pos = Position(32207, 31284, 14), teleport = Position(32234, 31292, 14), effect = CONST_ME_TELEPORT }, + { pos = Position(32207, 31285, 14), teleport = Position(32234, 31292, 14), effect = CONST_ME_TELEPORT }, + { pos = Position(32207, 31286, 14), teleport = Position(32234, 31292, 14), effect = CONST_ME_TELEPORT }, + { pos = Position(32207, 31287, 14), teleport = Position(32234, 31292, 14), effect = CONST_ME_TELEPORT }, + { pos = Position(32207, 31288, 14), teleport = Position(32234, 31292, 14), effect = CONST_ME_TELEPORT }, + }, + specPos = { + from = Position(32223, 31273, 14), + to = Position(32246, 31297, 14), + }, + monsters = { + { name = "Spark of Destruction", pos = Position(32229, 31282, 14) }, + { name = "Spark of Destruction", pos = Position(32230, 31287, 14) }, + { name = "Spark of Destruction", pos = Position(32237, 31287, 14) }, + { name = "Spark of Destruction", pos = Position(32238, 31282, 14) }, + }, + onUseExtra = function() + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstStage, 0) + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth, 290000) + + local tile = Tile(Position(32225, 31285, 14)) + if tile then + local vortex = tile:getItemById(23482) + if vortex then + vortex:transform(23483) + vortex:setActionId(14350) end end - item:transform(item.itemid == 8911 and 8912 or 8911) - end - return true -end + end, + exit = Position(32208, 31372, 14), +} -heartDestructionOutburst:aid(14331) -heartDestructionOutburst:register() +local lever = BossLever(config) +lever:aid(14331) +lever:register() diff --git a/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/charging_out_death.lua b/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/charging_out_death.lua index a947c7db56a..f8bf3ac8354 100644 --- a/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/charging_out_death.lua +++ b/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/charging_out_death.lua @@ -1,8 +1,13 @@ local chargingOutDeath = CreatureEvent("ChargingOutDeath") + function chargingOutDeath.onDeath(creature) - if chargingOutKilled == false then - local monster = Game.createMonster("outburst", { x = 32234, y = 31285, z = 14 }, false, true) - monster:addHealth(-monster:getHealth() + outburstHealth, COMBAT_PHYSICALDAMAGE) + local chargingOutKilled = Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstChargingKilled) + if chargingOutKilled < 1 then + local monster = Game.createMonster("Outburst", Position(32234, 31285, 14), false, true) + if monster then + local outburstHealth = Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth) > 0 and Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth) or 0 + monster:addHealth(-monster:getHealth() + outburstHealth, COMBAT_PHYSICALDAMAGE) + end end return true end diff --git a/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/outburst_charge.lua b/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/outburst_charge.lua index 3cbcea513ec..62b46e616e7 100644 --- a/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/outburst_charge.lua +++ b/data-otservbr-global/scripts/creaturescripts/quests/heart_of_destruction/outburst_charge.lua @@ -1,50 +1,37 @@ +local function createSpawnChargingOutburst(stage) + Game.createMonster("Spark of Destruction", Position(32229, 31282, 14), false, true) + Game.createMonster("Spark of Destruction", Position(32230, 31287, 14), false, true) + Game.createMonster("Spark of Destruction", Position(32237, 31287, 14), false, true) + Game.createMonster("Spark of Destruction", Position(32238, 31282, 14), false, true) + Game.createMonster("Charging Outburst", Position(32234, 31284, 14), false, true) + + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstStage, stage) + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstChargingKilled, -1) +end + local outburstCharge = CreatureEvent("OutburstCharge") + function outburstCharge.onThink(creature) if not creature or not creature:isMonster() then return false end - local hp = (creature:getHealth() / creature:getMaxHealth()) * 100 - if hp <= 80 and outburstStage == 0 then - outburstHealth = creature:getHealth() + local outburstStage = Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstStage) > 0 and Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstStage) or 0 + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth, creature:getHealth()) + + local hpPercent = (creature:getHealth() / creature:getMaxHealth()) * 100 + if hpPercent <= 80 and outburstStage == 0 then creature:remove() - Game.createMonster("spark of destruction", { x = 32229, y = 31282, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32230, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32237, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32238, y = 31282, z = 14 }, false, true) - Game.createMonster("charging outburst", { x = 32234, y = 31284, z = 14 }, false, true) - outburstStage = 1 - chargingOutKilled = false - elseif hp <= 60 and outburstStage == 1 then - outburstHealth = creature:getHealth() + createSpawnChargingOutburst(1) + elseif hpPercent <= 60 and outburstStage == 1 then creature:remove() - Game.createMonster("spark of destruction", { x = 32229, y = 31282, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32230, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32237, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32238, y = 31282, z = 14 }, false, true) - Game.createMonster("charging outburst", { x = 32234, y = 31284, z = 14 }, false, true) - outburstStage = 2 - chargingOutKilled = false - elseif hp <= 40 and outburstStage == 2 then - outburstHealth = creature:getHealth() + createSpawnChargingOutburst(2) + elseif hpPercent <= 40 and outburstStage == 2 then creature:remove() - Game.createMonster("spark of destruction", { x = 32229, y = 31282, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32230, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32237, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32238, y = 31282, z = 14 }, false, true) - Game.createMonster("charging outburst", { x = 32234, y = 31284, z = 14 }, false, true) - outburstStage = 3 - chargingOutKilled = false - elseif hp <= 20 and outburstStage == 3 then - outburstHealth = creature:getHealth() + createSpawnChargingOutburst(3) + elseif hpPercent <= 20 and outburstStage == 3 then creature:remove() - Game.createMonster("spark of destruction", { x = 32229, y = 31282, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32230, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32237, y = 31287, z = 14 }, false, true) - Game.createMonster("spark of destruction", { x = 32238, y = 31282, z = 14 }, false, true) - Game.createMonster("charging outburst", { x = 32234, y = 31284, z = 14 }, false, true) - outburstStage = 4 - chargingOutKilled = false + createSpawnChargingOutburst(4) end return true end diff --git a/data-otservbr-global/scripts/spells/monster/outburst_explode.lua b/data-otservbr-global/scripts/spells/monster/outburst_explode.lua index 7bb458af527..aeff02e3cae 100644 --- a/data-otservbr-global/scripts/spells/monster/outburst_explode.lua +++ b/data-otservbr-global/scripts/spells/monster/outburst_explode.lua @@ -31,7 +31,7 @@ local combat = Combat() combat:setParameter(COMBAT_PARAM_TYPE, COMBAT_ENERGYDAMAGE) combat:setParameter(COMBAT_PARAM_EFFECT, CONST_ME_PURPLEENERGY) -arr = { +local spellArea = { { 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 }, { 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0 }, { 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 }, @@ -47,7 +47,7 @@ arr = { { 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 }, } -local area = createCombatArea(arr) +local area = createCombatArea(spellArea) combat:setArea(area) local function delayedCastSpell(creature, var) @@ -68,16 +68,16 @@ end local spell = Spell("instant") function spell.onCastSpell(creature, var) - local from = creature:getId() - outExplode() delayedCastSpell(creature, var) - chargingOutKilled = true + Game.setStorageValue(GlobalStorage.HeartOfDestruction.OutburstChargingKilled, 1) addEvent(removeOutburst, 1000, creature.uid) - local monster = Game.createMonster("Outburst", { x = 32234, y = 31284, z = 14 }, false, true) - monster:addHealth(-monster:getHealth() + outburstHealth, COMBAT_PHYSICALDAMAGE) - transferBossPoints(from, monster:getId()) + local monster = Game.createMonster("Outburst", Position(32234, 31284, 14), false, true) + if monster then + local outburstHealth = Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth) > 0 and Game.getStorageValue(GlobalStorage.HeartOfDestruction.OutburstHealth) or 0 + monster:addHealth(-monster:getHealth() + outburstHealth, COMBAT_PHYSICALDAMAGE) + end return true end