Expose spooled up value to stats panels
This commit is contained in:
@@ -67,6 +67,7 @@ class Drone(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
""" Build object. Assumes proper and valid item already set """
|
""" Build object. Assumes proper and valid item already set """
|
||||||
self.__charge = None
|
self.__charge = None
|
||||||
self.__baseVolley = None
|
self.__baseVolley = None
|
||||||
|
self.__baseRemoteReps = None
|
||||||
self.__miningyield = None
|
self.__miningyield = None
|
||||||
self.__itemModifiedAttributes = ModifiedAttributeDict()
|
self.__itemModifiedAttributes = ModifiedAttributeDict()
|
||||||
self.__itemModifiedAttributes.original = self.__item.attributes
|
self.__itemModifiedAttributes.original = self.__item.attributes
|
||||||
@@ -125,12 +126,12 @@ class Drone(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
return DmgTypes(0, 0, 0, 0)
|
return DmgTypes(0, 0, 0, 0)
|
||||||
if self.__baseVolley is None:
|
if self.__baseVolley is None:
|
||||||
dmgGetter = self.getModifiedChargeAttr if self.hasAmmo else self.getModifiedItemAttr
|
dmgGetter = self.getModifiedChargeAttr if self.hasAmmo else self.getModifiedItemAttr
|
||||||
dmgMult = self.amountActive * (self.getModifiedItemAttr("damageMultiplier") or 1)
|
dmgMult = self.amountActive * (self.getModifiedItemAttr("damageMultiplier", 1))
|
||||||
self.__baseVolley = DmgTypes(
|
self.__baseVolley = DmgTypes(
|
||||||
em=(dmgGetter("emDamage") or 0) * dmgMult,
|
em=(dmgGetter("emDamage", 0)) * dmgMult,
|
||||||
thermal=(dmgGetter("thermalDamage") or 0) * dmgMult,
|
thermal=(dmgGetter("thermalDamage", 0)) * dmgMult,
|
||||||
kinetic=(dmgGetter("kineticDamage") or 0) * dmgMult,
|
kinetic=(dmgGetter("kineticDamage", 0)) * dmgMult,
|
||||||
explosive=(dmgGetter("explosiveDamage") or 0) * dmgMult)
|
explosive=(dmgGetter("explosiveDamage", 0)) * dmgMult)
|
||||||
volley = DmgTypes(
|
volley = DmgTypes(
|
||||||
em=self.__baseVolley.em * (1 - getattr(targetResists, "emAmount", 0)),
|
em=self.__baseVolley.em * (1 - getattr(targetResists, "emAmount", 0)),
|
||||||
thermal=self.__baseVolley.thermal * (1 - getattr(targetResists, "thermalAmount", 0)),
|
thermal=self.__baseVolley.thermal * (1 - getattr(targetResists, "thermalAmount", 0)),
|
||||||
@@ -152,6 +153,30 @@ class Drone(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
explosive=volley.explosive * dpsFactor)
|
explosive=volley.explosive * dpsFactor)
|
||||||
return dps
|
return dps
|
||||||
|
|
||||||
|
def getRemoteReps(self):
|
||||||
|
if self.amountActive <= 0:
|
||||||
|
return (None, 0)
|
||||||
|
if self.__baseRemoteReps is None:
|
||||||
|
droneShield = self.getModifiedItemAttr("shieldBonus", 0)
|
||||||
|
droneArmor = self.getModifiedItemAttr("armorDamageAmount", 0)
|
||||||
|
droneHull = self.getModifiedItemAttr("structureDamageAmount", 0)
|
||||||
|
if droneShield:
|
||||||
|
rrType = "Shield"
|
||||||
|
rrAmount = droneShield
|
||||||
|
elif droneArmor:
|
||||||
|
rrType = "Armor"
|
||||||
|
rrAmount = droneArmor
|
||||||
|
elif droneHull:
|
||||||
|
rrType = "Hull"
|
||||||
|
rrAmount = droneHull
|
||||||
|
else:
|
||||||
|
rrType = None
|
||||||
|
rrAmount = 0
|
||||||
|
if rrAmount:
|
||||||
|
rrAmount *= self.amountActive / (self.cycleTime / 1000)
|
||||||
|
self.__baseRemoteReps = (rrType, rrAmount)
|
||||||
|
return self.__baseRemoteReps
|
||||||
|
|
||||||
def changeType(self, typeID):
|
def changeType(self, typeID):
|
||||||
self.itemID = typeID
|
self.itemID = typeID
|
||||||
self.init()
|
self.init()
|
||||||
@@ -214,6 +239,7 @@ class Drone(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
|
|
||||||
def clear(self):
|
def clear(self):
|
||||||
self.__baseVolley = None
|
self.__baseVolley = None
|
||||||
|
self.__baseRemoteReps = None
|
||||||
self.__miningyield = None
|
self.__miningyield = None
|
||||||
self.itemModifiedAttributes.clear()
|
self.itemModifiedAttributes.clear()
|
||||||
self.chargeModifiedAttributes.clear()
|
self.chargeModifiedAttributes.clear()
|
||||||
|
|||||||
@@ -122,16 +122,16 @@ class FighterAbility(object):
|
|||||||
if not self.dealsDamage or not self.active:
|
if not self.dealsDamage or not self.active:
|
||||||
return DmgTypes(0, 0, 0, 0)
|
return DmgTypes(0, 0, 0, 0)
|
||||||
if self.attrPrefix == "fighterAbilityLaunchBomb":
|
if self.attrPrefix == "fighterAbilityLaunchBomb":
|
||||||
em = self.fighter.getModifiedChargeAttr("emDamage") or 0
|
em = self.fighter.getModifiedChargeAttr("emDamage", 0)
|
||||||
therm = self.fighter.getModifiedChargeAttr("thermalDamage") or 0
|
therm = self.fighter.getModifiedChargeAttr("thermalDamage", 0)
|
||||||
kin = self.fighter.getModifiedChargeAttr("kineticDamage") or 0
|
kin = self.fighter.getModifiedChargeAttr("kineticDamage", 0)
|
||||||
exp = self.fighter.getModifiedChargeAttr("explosiveDamage") or 0
|
exp = self.fighter.getModifiedChargeAttr("explosiveDamage", 0)
|
||||||
else:
|
else:
|
||||||
em = self.fighter.getModifiedItemAttr("{}DamageEM".format(self.attrPrefix)) or 0
|
em = self.fighter.getModifiedItemAttr("{}DamageEM".format(self.attrPrefix), 0)
|
||||||
therm = self.fighter.getModifiedItemAttr("{}DamageTherm".format(self.attrPrefix)) or 0
|
therm = self.fighter.getModifiedItemAttr("{}DamageTherm".format(self.attrPrefix), 0)
|
||||||
kin = self.fighter.getModifiedItemAttr("{}DamageKin".format(self.attrPrefix)) or 0
|
kin = self.fighter.getModifiedItemAttr("{}DamageKin".format(self.attrPrefix), 0)
|
||||||
exp = self.fighter.getModifiedItemAttr("{}DamageExp".format(self.attrPrefix)) or 0
|
exp = self.fighter.getModifiedItemAttr("{}DamageExp".format(self.attrPrefix), 0)
|
||||||
dmgMult = self.fighter.amountActive * (self.fighter.getModifiedItemAttr("{}DamageMultiplier".format(self.attrPrefix)) or 1)
|
dmgMult = self.fighter.amountActive * self.fighter.getModifiedItemAttr("{}DamageMultiplier".format(self.attrPrefix), 1)
|
||||||
volley = DmgTypes(
|
volley = DmgTypes(
|
||||||
em=em * dmgMult * (1 - getattr(targetResists, "emAmount", 0)),
|
em=em * dmgMult * (1 - getattr(targetResists, "emAmount", 0)),
|
||||||
thermal=therm * dmgMult * (1 - getattr(targetResists, "thermalAmount", 0)),
|
thermal=therm * dmgMult * (1 - getattr(targetResists, "thermalAmount", 0)),
|
||||||
|
|||||||
@@ -123,6 +123,7 @@ class Fit(object):
|
|||||||
self.__ehp = None
|
self.__ehp = None
|
||||||
self.__weaponDpsMap = {}
|
self.__weaponDpsMap = {}
|
||||||
self.__weaponVolleyMap = {}
|
self.__weaponVolleyMap = {}
|
||||||
|
self.__remoteRepMap = {}
|
||||||
self.__minerYield = None
|
self.__minerYield = None
|
||||||
self.__droneDps = None
|
self.__droneDps = None
|
||||||
self.__droneVolley = None
|
self.__droneVolley = None
|
||||||
@@ -136,12 +137,6 @@ class Fit(object):
|
|||||||
self.__capUsed = None
|
self.__capUsed = None
|
||||||
self.__capRecharge = None
|
self.__capRecharge = None
|
||||||
self.__calculatedTargets = []
|
self.__calculatedTargets = []
|
||||||
self.__remoteReps = {
|
|
||||||
"Armor" : None,
|
|
||||||
"Shield" : None,
|
|
||||||
"Hull" : None,
|
|
||||||
"Capacitor": None,
|
|
||||||
}
|
|
||||||
self.factorReload = False
|
self.factorReload = False
|
||||||
self.boostsFits = set()
|
self.boostsFits = set()
|
||||||
self.gangBoosts = None
|
self.gangBoosts = None
|
||||||
@@ -402,6 +397,7 @@ class Fit(object):
|
|||||||
self.__effectiveTank = None
|
self.__effectiveTank = None
|
||||||
self.__weaponDpsMap = {}
|
self.__weaponDpsMap = {}
|
||||||
self.__weaponVolleyMap = {}
|
self.__weaponVolleyMap = {}
|
||||||
|
self.__remoteRepMap = {}
|
||||||
self.__minerYield = None
|
self.__minerYield = None
|
||||||
self.__effectiveSustainableTank = None
|
self.__effectiveSustainableTank = None
|
||||||
self.__sustainableTank = None
|
self.__sustainableTank = None
|
||||||
@@ -417,9 +413,6 @@ class Fit(object):
|
|||||||
self.ecmProjectedStr = 1
|
self.ecmProjectedStr = 1
|
||||||
# self.commandBonuses = {}
|
# self.commandBonuses = {}
|
||||||
|
|
||||||
for remoterep_type in self.__remoteReps:
|
|
||||||
self.__remoteReps[remoterep_type] = None
|
|
||||||
|
|
||||||
del self.__calculatedTargets[:]
|
del self.__calculatedTargets[:]
|
||||||
del self.__extraDrains[:]
|
del self.__extraDrains[:]
|
||||||
|
|
||||||
@@ -1368,93 +1361,27 @@ class Fit(object):
|
|||||||
self.__capStable = True
|
self.__capStable = True
|
||||||
self.__capState = 100
|
self.__capState = 100
|
||||||
|
|
||||||
@property
|
def getRemoteReps(self, spoolType=None, spoolAmount=None):
|
||||||
def remoteReps(self):
|
if (spoolType, spoolAmount) not in self.__remoteRepMap:
|
||||||
force_recalc = False
|
remoteReps = {}
|
||||||
for remote_type in self.__remoteReps:
|
|
||||||
if self.__remoteReps[remote_type] is None:
|
|
||||||
force_recalc = True
|
|
||||||
break
|
|
||||||
|
|
||||||
if force_recalc is False:
|
for module in self.modules:
|
||||||
return self.__remoteReps
|
rrType, rrAmount = module.getRemoteReps(spoolType=spoolType, spoolAmount=spoolAmount)
|
||||||
|
if rrType:
|
||||||
|
if rrType not in remoteReps:
|
||||||
|
remoteReps[rrType] = 0
|
||||||
|
remoteReps[rrType] += rrAmount
|
||||||
|
|
||||||
# We are rerunning the recalcs. Explicitly set to 0 to make sure we don't duplicate anything and correctly set
|
for drone in self.drones:
|
||||||
# all values to 0.
|
rrType, rrAmount = drone.getRemoteReps()
|
||||||
for remote_type in self.__remoteReps:
|
if rrType:
|
||||||
self.__remoteReps[remote_type] = 0
|
if rrType not in remoteReps:
|
||||||
|
remoteReps[rrType] = 0
|
||||||
|
remoteReps[rrType] += rrAmount
|
||||||
|
|
||||||
for stuff in chain(self.modules, self.drones):
|
self.__remoteRepMap[(spoolType, spoolAmount)] = remoteReps
|
||||||
if stuff.item:
|
|
||||||
if stuff.item.ID == 10250:
|
|
||||||
pass
|
|
||||||
remote_type = None
|
|
||||||
|
|
||||||
# Only apply the charged multiplier if we have a charge in our ancil reppers (#1135)
|
return self.__remoteRepMap[(spoolType, spoolAmount)]
|
||||||
if stuff.charge:
|
|
||||||
modifier = stuff.getModifiedItemAttr("chargedArmorDamageMultiplier", 1)
|
|
||||||
else:
|
|
||||||
modifier = 1
|
|
||||||
|
|
||||||
if isinstance(stuff, Module) and (stuff.isEmpty or stuff.state < State.ACTIVE):
|
|
||||||
continue
|
|
||||||
elif isinstance(stuff, Drone):
|
|
||||||
# drones don't have fueled charges, so simply override modifier with the amount of drones active
|
|
||||||
modifier = stuff.amountActive
|
|
||||||
|
|
||||||
# Covert cycleTime to seconds
|
|
||||||
duration = stuff.cycleTime / 1000
|
|
||||||
|
|
||||||
# Skip modules with no duration.
|
|
||||||
if not duration:
|
|
||||||
continue
|
|
||||||
|
|
||||||
remote_module_groups = {
|
|
||||||
"Remote Armor Repairer": "Armor",
|
|
||||||
"Ancillary Remote Armor Repairer": "Armor",
|
|
||||||
"Mutadaptive Remote Armor Repairer": "Armor",
|
|
||||||
"Remote Hull Repairer": "Hull",
|
|
||||||
"Remote Shield Booster": "Shield",
|
|
||||||
"Ancillary Remote Shield Booster": "Shield",
|
|
||||||
"Remote Capacitor Transmitter": "Capacitor",
|
|
||||||
}
|
|
||||||
|
|
||||||
module_group = stuff.item.group.name
|
|
||||||
|
|
||||||
if module_group in remote_module_groups:
|
|
||||||
remote_type = remote_module_groups[module_group]
|
|
||||||
elif not isinstance(stuff, Drone):
|
|
||||||
# Module isn't in our list of remote rep modules, bail
|
|
||||||
continue
|
|
||||||
|
|
||||||
if remote_type == "Hull":
|
|
||||||
hp = stuff.getModifiedItemAttr("structureDamageAmount", 0)
|
|
||||||
elif remote_type == "Armor":
|
|
||||||
hp = stuff.getModifiedItemAttr("armorDamageAmount", 0)
|
|
||||||
elif remote_type == "Shield":
|
|
||||||
hp = stuff.getModifiedItemAttr("shieldBonus", 0)
|
|
||||||
elif remote_type == "Capacitor":
|
|
||||||
hp = stuff.getModifiedItemAttr("powerTransferAmount", 0)
|
|
||||||
else:
|
|
||||||
droneShield = stuff.getModifiedItemAttr("shieldBonus", 0)
|
|
||||||
droneArmor = stuff.getModifiedItemAttr("armorDamageAmount", 0)
|
|
||||||
droneHull = stuff.getModifiedItemAttr("structureDamageAmount", 0)
|
|
||||||
if droneShield:
|
|
||||||
remote_type = "Shield"
|
|
||||||
hp = droneShield
|
|
||||||
elif droneArmor:
|
|
||||||
remote_type = "Armor"
|
|
||||||
hp = droneArmor
|
|
||||||
elif droneHull:
|
|
||||||
remote_type = "Hull"
|
|
||||||
hp = droneHull
|
|
||||||
else:
|
|
||||||
hp = 0
|
|
||||||
|
|
||||||
if hp > 0 and duration > 0:
|
|
||||||
self.__remoteReps[remote_type] += (hp * modifier) / duration
|
|
||||||
|
|
||||||
return self.__remoteReps
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def hp(self):
|
def hp(self):
|
||||||
|
|||||||
@@ -171,6 +171,7 @@ class Module(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
self.__charge = None
|
self.__charge = None
|
||||||
|
|
||||||
self.__baseVolley = None
|
self.__baseVolley = None
|
||||||
|
self.__baseRemoteReps = None
|
||||||
self.__miningyield = None
|
self.__miningyield = None
|
||||||
self.__reloadTime = None
|
self.__reloadTime = None
|
||||||
self.__reloadForce = None
|
self.__reloadForce = None
|
||||||
@@ -436,15 +437,15 @@ class Module(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
return DmgTypes(0, 0, 0, 0)
|
return DmgTypes(0, 0, 0, 0)
|
||||||
if self.__baseVolley is None:
|
if self.__baseVolley is None:
|
||||||
dmgGetter = self.getModifiedChargeAttr if self.charge else self.getModifiedItemAttr
|
dmgGetter = self.getModifiedChargeAttr if self.charge else self.getModifiedItemAttr
|
||||||
dmgMult = self.getModifiedItemAttr("damageMultiplier") or 1
|
dmgMult = self.getModifiedItemAttr("damageMultiplier", 1)
|
||||||
self.__baseVolley = DmgTypes(
|
self.__baseVolley = DmgTypes(
|
||||||
em=(dmgGetter("emDamage") or 0) * dmgMult,
|
em=(dmgGetter("emDamage", 0)) * dmgMult,
|
||||||
thermal=(dmgGetter("thermalDamage") or 0) * dmgMult,
|
thermal=(dmgGetter("thermalDamage", 0)) * dmgMult,
|
||||||
kinetic=(dmgGetter("kineticDamage") or 0) * dmgMult,
|
kinetic=(dmgGetter("kineticDamage", 0)) * dmgMult,
|
||||||
explosive=(dmgGetter("explosiveDamage") or 0) * dmgMult)
|
explosive=(dmgGetter("explosiveDamage", 0)) * dmgMult)
|
||||||
spoolMultiplier = 1 + calculateSpoolup(
|
spoolMultiplier = 1 + calculateSpoolup(
|
||||||
self.getModifiedItemAttr("damageMultiplierBonusMax") or 0,
|
self.getModifiedItemAttr("damageMultiplierBonusMax", 0),
|
||||||
self.getModifiedItemAttr("damageMultiplierBonusPerCycle") or 0,
|
self.getModifiedItemAttr("damageMultiplierBonusPerCycle", 0),
|
||||||
self.cycleTime / 1000,
|
self.cycleTime / 1000,
|
||||||
spoolType if spoolType is not None else self.spoolType,
|
spoolType if spoolType is not None else self.spoolType,
|
||||||
# Using spool type as condition as it should define if we're using
|
# Using spool type as condition as it should define if we're using
|
||||||
@@ -472,6 +473,55 @@ class Module(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
explosive=volley.explosive * dpsFactor)
|
explosive=volley.explosive * dpsFactor)
|
||||||
return dps
|
return dps
|
||||||
|
|
||||||
|
def getRemoteReps(self, spoolType=None, spoolAmount=None):
|
||||||
|
if self.isEmpty or self.state < State.ACTIVE:
|
||||||
|
return (None, 0)
|
||||||
|
|
||||||
|
def getBaseRemoteReps(module):
|
||||||
|
remoteModuleGroups = {
|
||||||
|
"Remote Armor Repairer": "Armor",
|
||||||
|
"Ancillary Remote Armor Repairer": "Armor",
|
||||||
|
"Mutadaptive Remote Armor Repairer": "Armor",
|
||||||
|
"Remote Hull Repairer": "Hull",
|
||||||
|
"Remote Shield Booster": "Shield",
|
||||||
|
"Ancillary Remote Shield Booster": "Shield",
|
||||||
|
"Remote Capacitor Transmitter": "Capacitor"}
|
||||||
|
rrType = remoteModuleGroups.get(module.item.group.name, None)
|
||||||
|
if not rrType:
|
||||||
|
return None, 0
|
||||||
|
if rrType == "Hull":
|
||||||
|
rrAmount = module.getModifiedItemAttr("structureDamageAmount", 0)
|
||||||
|
elif rrType == "Armor":
|
||||||
|
rrAmount = module.getModifiedItemAttr("armorDamageAmount", 0)
|
||||||
|
elif rrType == "Shield":
|
||||||
|
rrAmount = module.getModifiedItemAttr("shieldBonus", 0)
|
||||||
|
elif rrType == "Capacitor":
|
||||||
|
rrAmount = module.getModifiedItemAttr("powerTransferAmount", 0)
|
||||||
|
else:
|
||||||
|
return None, 0
|
||||||
|
if rrAmount:
|
||||||
|
rrAmount *= 1 / (self.cycleTime / 1000)
|
||||||
|
if module.item.group.name == "Ancillary Remote Armor Repairer" and module.charge:
|
||||||
|
rrAmount *= module.getModifiedItemAttr("chargedArmorDamageMultiplier", 1)
|
||||||
|
|
||||||
|
return rrType, rrAmount
|
||||||
|
|
||||||
|
if self.__baseRemoteReps is None:
|
||||||
|
self.__baseRemoteReps = getBaseRemoteReps(self)
|
||||||
|
|
||||||
|
rrType, rrAmount = self.__baseRemoteReps
|
||||||
|
if rrType and rrAmount and self.item.group.name == "Mutadaptive Remote Armor Repairer":
|
||||||
|
spoolMultiplier = 1 + calculateSpoolup(
|
||||||
|
self.getModifiedItemAttr("repairMultiplierBonusMax", 0),
|
||||||
|
self.getModifiedItemAttr("repairMultiplierBonusPerCycle", 0),
|
||||||
|
self.cycleTime / 1000,
|
||||||
|
spoolType if spoolType is not None else self.spoolType,
|
||||||
|
# Using spool type as condition as it should define if we're using
|
||||||
|
# passed spoolup parameters or not
|
||||||
|
spoolAmount if spoolType is not None else self.spoolAmount)
|
||||||
|
rrAmount *= spoolMultiplier
|
||||||
|
return rrType, rrAmount
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def reloadTime(self):
|
def reloadTime(self):
|
||||||
# Get reload time from attrs first, then use
|
# Get reload time from attrs first, then use
|
||||||
@@ -724,6 +774,7 @@ class Module(HandledItem, HandledCharge, ItemAttrShortcut, ChargeAttrShortcut):
|
|||||||
|
|
||||||
def clear(self):
|
def clear(self):
|
||||||
self.__baseVolley = None
|
self.__baseVolley = None
|
||||||
|
self.__baseRemoteReps = None
|
||||||
self.__miningyield = None
|
self.__miningyield = None
|
||||||
self.__reloadTime = None
|
self.__reloadTime = None
|
||||||
self.__reloadForce = None
|
self.__reloadForce = None
|
||||||
|
|||||||
@@ -153,7 +153,7 @@ class FirepowerViewFull(StatsView):
|
|||||||
if preSpool == postSpool:
|
if preSpool == postSpool:
|
||||||
return None
|
return None
|
||||||
else:
|
else:
|
||||||
return "Spoolup {} spread: {}-{}".format(
|
return "Spoolup {}: {}-{}".format(
|
||||||
statName,
|
statName,
|
||||||
formatAmount(preSpool, *fmt_options),
|
formatAmount(preSpool, *fmt_options),
|
||||||
formatAmount(postSpool, *fmt_options))
|
formatAmount(postSpool, *fmt_options))
|
||||||
@@ -161,7 +161,7 @@ class FirepowerViewFull(StatsView):
|
|||||||
stats = (
|
stats = (
|
||||||
(
|
(
|
||||||
"labelFullDpsWeapon",
|
"labelFullDpsWeapon",
|
||||||
lambda: fit.getWeaponDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getWeaponDps().total,
|
||||||
lambda: fit.getWeaponDps(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
lambda: fit.getWeaponDps(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
||||||
lambda: fit.getWeaponDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getWeaponDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
||||||
3, 0, 0, "%s DPS", "DPS"),
|
3, 0, 0, "%s DPS", "DPS"),
|
||||||
@@ -173,27 +173,29 @@ class FirepowerViewFull(StatsView):
|
|||||||
3, 0, 0, "%s DPS", "DPS"),
|
3, 0, 0, "%s DPS", "DPS"),
|
||||||
(
|
(
|
||||||
"labelFullVolleyTotal",
|
"labelFullVolleyTotal",
|
||||||
lambda: fit.getTotalVolley(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getTotalVolley().total,
|
||||||
lambda: fit.getTotalVolley(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
lambda: fit.getTotalVolley(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
||||||
lambda: fit.getTotalVolley(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getTotalVolley(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
||||||
3, 0, 0, "%s", "volley"),
|
3, 0, 0, "%s", "volley"),
|
||||||
(
|
(
|
||||||
"labelFullDpsTotal",
|
"labelFullDpsTotal",
|
||||||
lambda: fit.getTotalDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getTotalDps().total,
|
||||||
lambda: fit.getTotalDps(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
lambda: fit.getTotalDps(spoolType=SpoolType.SCALE, spoolAmount=0).total,
|
||||||
lambda: fit.getTotalDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
lambda: fit.getTotalDps(spoolType=SpoolType.SCALE, spoolAmount=1).total,
|
||||||
3, 0, 0, "%s", "DPS"))
|
3, 0, 0, "%s", "DPS"))
|
||||||
|
|
||||||
counter = 0
|
counter = 0
|
||||||
for labelName, val, preSpoolVal, postSpoolVal, prec, lowest, highest, valueFormat, statName in stats:
|
for labelName, val, preSpoolVal, fullSpoolVal, prec, lowest, highest, valueFormat, statName in stats:
|
||||||
label = getattr(self, labelName)
|
label = getattr(self, labelName)
|
||||||
preSpoolVal = preSpoolVal() if fit is not None else 0
|
|
||||||
postSpoolVal = postSpoolVal() if fit is not None else 0
|
|
||||||
val = val() if fit is not None else 0
|
val = val() if fit is not None else 0
|
||||||
|
preSpoolVal = preSpoolVal() if fit is not None else 0
|
||||||
|
fullSpoolVal = fullSpoolVal() if fit is not None else 0
|
||||||
|
# TODO: temporary override, should be removed when spoolup settings are implemented
|
||||||
|
val = fullSpoolVal
|
||||||
if self._cachedValues[counter] != val:
|
if self._cachedValues[counter] != val:
|
||||||
valueStr = formatAmount(val, prec, lowest, highest)
|
valueStr = formatAmount(val, prec, lowest, highest)
|
||||||
label.SetLabel(valueFormat % valueStr)
|
label.SetLabel(valueFormat % valueStr)
|
||||||
valueStrTooltip = dpsToolTip(preSpoolVal, postSpoolVal, statName, (prec, lowest, highest))
|
valueStrTooltip = dpsToolTip(preSpoolVal, fullSpoolVal, statName, (prec, lowest, highest))
|
||||||
if valueStrTooltip:
|
if valueStrTooltip:
|
||||||
label.SetToolTip(wx.ToolTip(valueStrTooltip))
|
label.SetToolTip(wx.ToolTip(valueStrTooltip))
|
||||||
self._cachedValues[counter] = val
|
self._cachedValues[counter] = val
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ import wx
|
|||||||
from gui.statsView import StatsView
|
from gui.statsView import StatsView
|
||||||
from gui.bitmap_loader import BitmapLoader
|
from gui.bitmap_loader import BitmapLoader
|
||||||
from gui.utils.numberFormatter import formatAmount
|
from gui.utils.numberFormatter import formatAmount
|
||||||
|
from eos.utils.spoolSupport import SpoolType
|
||||||
|
|
||||||
|
|
||||||
class OutgoingViewFull(StatsView):
|
class OutgoingViewFull(StatsView):
|
||||||
@@ -51,10 +52,10 @@ class OutgoingViewFull(StatsView):
|
|||||||
counter = 0
|
counter = 0
|
||||||
|
|
||||||
rr_list = [
|
rr_list = [
|
||||||
("RemoteCapacitor", "Capacitor:", "capacitorInfo", "Capacitor GJ/s per second transferred remotely."),
|
("RemoteCapacitor", "Capacitor:", "capacitorInfo", "Capacitor GJ per second restored remotely"),
|
||||||
("RemoteShield", "Shield:", "shieldActive", "Shield hitpoints per second repaired remotely."),
|
("RemoteShield", "Shield:", "shieldActive", "Shield HP per second repaired remotely"),
|
||||||
("RemoteArmor", "Armor:", "armorActive", "Armor hitpoints per second repaired remotely."),
|
("RemoteArmor", "Armor:", "armorActive", "Armor HP per second repaired remotely"),
|
||||||
("RemoteHull", "Hull:", "hullActive", "Hull hitpoints per second repaired remotely."),
|
("RemoteHull", "Hull:", "hullActive", "Hull HP per second repaired remotely"),
|
||||||
]
|
]
|
||||||
|
|
||||||
for outgoingType, label, image, tooltip in rr_list:
|
for outgoingType, label, image, tooltip in rr_list:
|
||||||
@@ -81,23 +82,43 @@ class OutgoingViewFull(StatsView):
|
|||||||
# If we did anything intresting, we'd update our labels to reflect the new fit's stats here
|
# If we did anything intresting, we'd update our labels to reflect the new fit's stats here
|
||||||
|
|
||||||
stats = [
|
stats = [
|
||||||
("labelRemoteArmor", lambda: fit.remoteReps["Armor"], 3, 0, 0, "%s HP/s", None),
|
(
|
||||||
("labelRemoteShield", lambda: fit.remoteReps["Shield"], 3, 0, 0, "%s HP/s", None),
|
"labelRemoteArmor",
|
||||||
("labelRemoteHull", lambda: fit.remoteReps["Hull"], 3, 0, 0, "%s HP/s", None),
|
lambda: fit.getRemoteReps().get("Armor"),
|
||||||
("labelRemoteCapacitor", lambda: fit.remoteReps["Capacitor"], 3, 0, 0, "%s GJ/s", None),
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Armor", 0),
|
||||||
]
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Armor", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteShield",
|
||||||
|
lambda: fit.getRemoteReps().get("Shield"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Shield", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Shield", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteHull",
|
||||||
|
lambda: fit.getRemoteReps().get("Hull"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Hull", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Hull", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteCapacitor",
|
||||||
|
lambda: fit.getRemoteReps().get("Capacitor"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Capacitor", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Capacitor", 0),
|
||||||
|
3, 0, 0, "%s GJ/s", None)]
|
||||||
|
|
||||||
counter = 0
|
counter = 0
|
||||||
for labelName, value, prec, lowest, highest, valueFormat, altFormat in stats:
|
for labelName, val, preSpoolVal, fullSpoolVal, prec, lowest, highest, valueFormat, altFormat in stats:
|
||||||
label = getattr(self, labelName)
|
label = getattr(self, labelName)
|
||||||
value = value() if fit is not None else 0
|
val = val() if fit is not None else 0
|
||||||
value = value if value is not None else 0
|
preSpoolVal = preSpoolVal() if fit is not None else 0
|
||||||
if self._cachedValues[counter] != value:
|
fullSpoolVal = fullSpoolVal() if fit is not None else 0
|
||||||
valueStr = formatAmount(value, prec, lowest, highest)
|
# TODO: temporary override, should be removed when spoolup settings are implemented
|
||||||
|
val = fullSpoolVal
|
||||||
|
if self._cachedValues[counter] != val:
|
||||||
|
valueStr = formatAmount(val, prec, lowest, highest)
|
||||||
label.SetLabel(valueFormat % valueStr)
|
label.SetLabel(valueFormat % valueStr)
|
||||||
tipStr = valueFormat % valueStr if altFormat is None else altFormat % value
|
self._cachedValues[counter] = val
|
||||||
label.SetToolTip(wx.ToolTip(tipStr))
|
|
||||||
self._cachedValues[counter] = value
|
|
||||||
counter += 1
|
counter += 1
|
||||||
self.panel.Layout()
|
self.panel.Layout()
|
||||||
self.headerPanel.Layout()
|
self.headerPanel.Layout()
|
||||||
|
|||||||
@@ -21,6 +21,7 @@
|
|||||||
import wx
|
import wx
|
||||||
from gui.statsView import StatsView
|
from gui.statsView import StatsView
|
||||||
from gui.utils.numberFormatter import formatAmount
|
from gui.utils.numberFormatter import formatAmount
|
||||||
|
from eos.utils.spoolSupport import SpoolType
|
||||||
|
|
||||||
|
|
||||||
class OutgoingViewMinimal(StatsView):
|
class OutgoingViewMinimal(StatsView):
|
||||||
@@ -50,10 +51,10 @@ class OutgoingViewMinimal(StatsView):
|
|||||||
counter = 0
|
counter = 0
|
||||||
|
|
||||||
rr_list = [
|
rr_list = [
|
||||||
("RemoteCapacitor", "Capacitor:", "capacitorInfo", "Capacitor GJ/s per second transferred remotely."),
|
("RemoteCapacitor", "Capacitor:", "capacitorInfo", "Capacitor GJ per second restored remotely"),
|
||||||
("RemoteShield", "Shield:", "shieldActive", "Shield hitpoints per second repaired remotely."),
|
("RemoteShield", "Shield:", "shieldActive", "Shield HP per second repaired remotely"),
|
||||||
("RemoteArmor", "Armor:", "armorActive", "Armor hitpoints per second repaired remotely."),
|
("RemoteArmor", "Armor:", "armorActive", "Armor HP per second repaired remotely"),
|
||||||
("RemoteHull", "Hull:", "hullActive", "Hull hitpoints per second repaired remotely."),
|
("RemoteHull", "Hull:", "hullActive", "Hull HP per second repaired remotely"),
|
||||||
]
|
]
|
||||||
|
|
||||||
for outgoingType, label, image, tooltip in rr_list:
|
for outgoingType, label, image, tooltip in rr_list:
|
||||||
@@ -80,23 +81,43 @@ class OutgoingViewMinimal(StatsView):
|
|||||||
# If we did anything intresting, we'd update our labels to reflect the new fit's stats here
|
# If we did anything intresting, we'd update our labels to reflect the new fit's stats here
|
||||||
|
|
||||||
stats = [
|
stats = [
|
||||||
("labelRemoteArmor", lambda: fit.remoteReps["Armor"], 3, 0, 0, "%s HP/s", None),
|
(
|
||||||
("labelRemoteShield", lambda: fit.remoteReps["Shield"], 3, 0, 0, "%s HP/s", None),
|
"labelRemoteArmor",
|
||||||
("labelRemoteHull", lambda: fit.remoteReps["Hull"], 3, 0, 0, "%s HP/s", None),
|
lambda: fit.getRemoteReps().get("Armor"),
|
||||||
("labelRemoteCapacitor", lambda: fit.remoteReps["Capacitor"], 3, 0, 0, "%s GJ/s", None),
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Armor", 0),
|
||||||
]
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Armor", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteShield",
|
||||||
|
lambda: fit.getRemoteReps().get("Shield"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Shield", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Shield", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteHull",
|
||||||
|
lambda: fit.getRemoteReps().get("Hull"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Hull", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Hull", 0),
|
||||||
|
3, 0, 0, "%s HP/s", None),
|
||||||
|
(
|
||||||
|
"labelRemoteCapacitor",
|
||||||
|
lambda: fit.getRemoteReps().get("Capacitor"),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=0).get("Capacitor", 0),
|
||||||
|
lambda: fit.getRemoteReps(spoolType=SpoolType.SCALE, spoolAmount=1).get("Capacitor", 0),
|
||||||
|
3, 0, 0, "%s GJ/s", None)]
|
||||||
|
|
||||||
counter = 0
|
counter = 0
|
||||||
for labelName, value, prec, lowest, highest, valueFormat, altFormat in stats:
|
for labelName, val, preSpoolVal, fullSpoolVal, prec, lowest, highest, valueFormat, altFormat in stats:
|
||||||
label = getattr(self, labelName)
|
label = getattr(self, labelName)
|
||||||
value = value() if fit is not None else 0
|
val = val() if fit is not None else 0
|
||||||
value = value if value is not None else 0
|
preSpoolVal = preSpoolVal() if fit is not None else 0
|
||||||
if self._cachedValues[counter] != value:
|
fullSpoolVal = fullSpoolVal() if fit is not None else 0
|
||||||
valueStr = formatAmount(value, prec, lowest, highest)
|
# TODO: temporary override, should be removed when spoolup settings are implemented
|
||||||
|
val = fullSpoolVal
|
||||||
|
if self._cachedValues[counter] != val:
|
||||||
|
valueStr = formatAmount(val, prec, lowest, highest)
|
||||||
label.SetLabel(valueFormat % valueStr)
|
label.SetLabel(valueFormat % valueStr)
|
||||||
tipStr = valueFormat % valueStr if altFormat is None else altFormat % value
|
self._cachedValues[counter] = val
|
||||||
label.SetToolTip(wx.ToolTip(tipStr))
|
|
||||||
self._cachedValues[counter] = value
|
|
||||||
counter += 1
|
counter += 1
|
||||||
self.panel.Layout()
|
self.panel.Layout()
|
||||||
self.headerPanel.Layout()
|
self.headerPanel.Layout()
|
||||||
|
|||||||
Reference in New Issue
Block a user