Updates to Spell Charge functions.

main
ck 1 year ago
parent 6fd60c6a4f
commit 3d203c280c
  1. 15
      src/EventManager/EventManager.lua
  2. 56
      src/Spell/Spell.lua
  3. 42
      src/Unit/Unit.lua

@ -40,8 +40,8 @@ function EventManager:New()
end end
end) end)
self:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function(event) self:RegisterWoWEvent("COMBAT_LOG_EVENT_UNFILTERED", function()
self:CLEUHandler(event, CombatLogGetCurrentEventInfo()) self:CLEUHandler(CombatLogGetCurrentEventInfo())
end) end)
return self return self
@ -125,19 +125,18 @@ function EventManager:RegisterCombatEvent(subevent, handler)
end end
end end
---@param event "COMBAT_LOG_EVENT_UNFILTERED"
---@param timestamp number ---@param timestamp number
---@param subevent string ---@param subevent string
---@param ... any ---@param ... any
function EventManager:CLEUHandler(event, timestamp, subevent, ...) function EventManager:CLEUHandler(timestamp, subevent, ...)
if self.selfCombatEventHandlers[subevent] and select(2, ...) == UnitGUID("player") then if self.selfCombatEventHandlers[subevent] and select(2, ...) == UnitGUID("player") then
for _, handler in pairs(self.selfCombatEventHandlers[subevent]) do for _, callback in ipairs(self.selfCombatEventHandlers[subevent]) do
handler(timestamp, subevent, ...) callback(timestamp, subevent, ...)
end end
end end
if self.CombatEventHandlers[subevent] then if self.CombatEventHandlers[subevent] then
for _, handler in pairs(self.CombatEventHandlers[subevent]) do for _, callback in ipairs(self.CombatEventHandlers[subevent]) do
handler(timestamp, subevent, ...) callback(timestamp, subevent, ...)
end end
end end
end end

@ -114,23 +114,6 @@ function Spell:GetCooldown()
return select(2, GetSpellCooldown(self:GetID())) return select(2, GetSpellCooldown(self:GetID()))
end end
-- Get the full cooldown (time until all charges are available)
---@return number
function Spell:GetFullRechargeTime()
local start, duration, enabled = GetSpellCooldown(self:GetID())
if enabled == 0 then
return 0
end
local charges, maxCharges, chargeStart, chargeDuration = GetSpellCharges(self:GetID())
if charges == maxCharges then
return 0
end
local totalChargeTime = ((maxCharges - charges) * chargeDuration) - ((chargeStart + chargeDuration) - GetTime())
return totalChargeTime
end
-- Return the castable function -- Return the castable function
function Spell:GetCastableFunction() function Spell:GetCastableFunction()
return self.CastableIfFunc return self.CastableIfFunc
@ -296,9 +279,10 @@ function Spell:IsUsable()
end end
-- Check if the spell is castable -- Check if the spell is castable
---@param override? boolean
---@return boolean ---@return boolean
function Spell:IsKnownAndUsable() function Spell:IsKnownAndUsable(override)
return self:IsKnown() and not self:IsOnCooldown() and self:IsUsable() return self:IsKnown(override) and not self:IsOnCooldown() and self:IsUsable()
end end
-- Check if the spell is castable -- Check if the spell is castable
@ -441,29 +425,41 @@ function Spell:GetMaxCharges()
return select(2, GetSpellCharges(self:GetID())) return select(2, GetSpellCharges(self:GetID()))
end end
---@return number
function Spell:GetCastLength() function Spell:GetCastLength()
return select(4, GetSpellInfo(self:GetID())) return select(4, GetSpellInfo(self:GetID()))
end end
-- Get the spells charges -- Get the full cooldown (time until all charges are available)
---@return number ---@return number
function Spell:GetChargesFractional() function Spell:GetFullRechargeTime()
local charges, maxCharges, start, duration = GetSpellCharges(self:GetID()) local charges, maxCharges, _, duration = GetSpellCharges(self:GetID())
if not charges or not maxCharges or charges == maxCharges then
return 0
end
return (maxCharges - self:GetChargesFractional()) * duration
end
function Spell:Recharge()
local charges, maxCharges, startTime, duration = GetSpellCharges(self:GetID())
if charges == maxCharges then if charges == maxCharges then
return maxCharges return charges
end end
if charges == 0 then local recharge = startTime + duration - GetTime()
return 0 return recharge > 0 and recharge or 0
end end
local timeSinceStart = GetTime() - start -- Get the spells charges plus fractional
local timeLeft = duration - timeSinceStart ---@return number
local timePerCharge = duration / maxCharges function Spell:GetChargesFractional()
local chargesFractional = charges + (timeLeft / timePerCharge) local charges, maxCharges, _, duration = GetSpellCharges(self:GetID())
return chargesFractional if charges == maxCharges then
return charges
end
return charges + ((duration - self:Recharge()) / duration)
end end
-- Get the spells charges remaining -- Get the spells charges remaining

@ -513,25 +513,47 @@ function Unit:GetLOSSourcePosition()
end end
local losFlag = bit.bor(0x10) local losFlag = bit.bor(0x10)
-- Check if the unit can see another unit -- Check if the unit can see another unit
---@param targetUnit Unit ---@param unit Unit
---@return boolean ---@return boolean
function Unit:CanSee(targetUnit) function Unit:CanSee(unit)
local npcId = targetUnit:GetID() -- mechagon smoke cloud
if npcId and losBlacklist[npcId] then -- local mechagonID = 2097
return true -- local smokecloud = 298602
-- local name, instanceType, difficultyID, difficultyName, maxPlayers, dynamicDifficulty, isDynamic, instanceID, instanceGroupSize, LfgDungeonID =
-- GetInstanceInfo()
-- otherUnit = otherUnit and otherUnit or "player"
-- if instanceID == 2097 then
-- if (self:debuff(smokecloud, unit) and not self:debuff(smokecloud, otherUnit))
-- or (self:debuff(smokecloud, otherUnit) and not self:debuff(smokecloud, unit))
-- then
-- return false
-- end
-- end
local ax, ay, az = ObjectPosition(self:GetOMToken())
local ah = ObjectHeight(self:GetOMToken())
local attx, atty, attz = GetUnitAttachmentPosition(unit:GetOMToken(), 34)
if not attx or not ax then
return false
end end
local src = self:GetLOSSourcePosition() if not ah then
local dst = targetUnit:GetHitSphere() return false
end
if (src.x == 0 and src.y == 0 and src.z == 0) or (dst.x == 0 and dst.y == 0 and dst.z == 0) then if (ax == 0 and ay == 0 and az == 0) or (attx == 0 and atty == 0 and attz == 0) then
return true return true
end end
local contactPoint = src + (dst - src):directionOrZero() * math.min(targetUnit:GetDistance(self), self:GetCombatReach()) if not attx or not ax then
return false
end
local x, y, z = TraceLine(src.x, src.y, src.z, contactPoint.x, contactPoint.y, contactPoint.z, losFlag) local x, y, z = TraceLine(ax, ay, az + ah, attx, atty, attz, losFlag)
if x ~= 0 or y ~= 0 or z ~= 0 then if x ~= 0 or y ~= 0 or z ~= 0 then
return false return false
else else

Loading…
Cancel
Save