# ============================================================================= # Copyright (C) 2010 Diego Duclos # # This file is part of pyfa. # # pyfa is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # pyfa is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with pyfa. If not, see . # ============================================================================= from gui.builtinGraphs.base import FitDataCache from eos.const import FittingModuleState class ProjectedDataCache(FitDataCache): def getProjModData(self, fit): try: projectedData = self._data[fit.ID]['modules'] except KeyError: # Format of items for both: (boost strength, optimal, falloff, stacking group) webMods = [] tpMods = [] projectedData = self._data.setdefault(fit.ID, {})['modules'] = (webMods, tpMods) for mod in fit.modules: if mod.state <= FittingModuleState.ONLINE: continue if 'remoteWebifierFalloff' in mod.item.effects or 'structureModuleEffectStasisWebifier' in mod.item.effects: webMods.append((mod.getModifiedItemAttr('speedFactor'), mod.maxRange or 0, mod.falloff or 0, 'default')) if 'doomsdayAOEWeb' in mod.item.effects: maxRange = max(0, (mod.maxRange or 0) + mod.getModifiedItemAttr('doomsdayAOERange') - fit.ship.getModifiedItemAttr('radius')) webMods.append((mod.getModifiedItemAttr('speedFactor'), maxRange, mod.falloff or 0, 'default')) if 'remoteTargetPaintFalloff' in mod.item.effects or 'structureModuleEffectTargetPainter' in mod.item.effects: tpMods.append((mod.getModifiedItemAttr('signatureRadiusBonus'), mod.maxRange or 0, mod.falloff or 0, 'default')) if 'doomsdayAOEPaint' in mod.item.effects: maxRange = max(0, (mod.maxRange or 0) + mod.getModifiedItemAttr('doomsdayAOERange') - fit.ship.getModifiedItemAttr('radius')) tpMods.append((mod.getModifiedItemAttr('signatureRadiusBonus'), maxRange, mod.falloff or 0, 'default')) return projectedData def getProjDroneData(self, fit): try: projectedData = self._data[fit.ID]['drones'] except KeyError: # Format of items for both: (boost strength, optimal, falloff, stacking group, speed, radius) webMods = [] tpMods = [] projectedData = self._data.setdefault(fit.ID, {})['drones'] = (webMods, tpMods) for drone in fit.drones: if drone.amountActive <= 0: continue if 'remoteWebifierEntity' in drone.item.effects: webMods.extend(drone.amountActive * (( drone.getModifiedItemAttr('speedFactor'), drone.maxRange or 0, drone.falloff or 0, 'default', drone.getModifiedItemAttr('maxVelocity'), drone.getModifiedItemAttr('radius')),)) if 'remoteTargetPaintEntity' in drone.item.effects: webMods.extend(drone.amountActive * (( drone.getModifiedItemAttr('signatureRadiusBonus'), drone.maxRange or 0, drone.falloff or 0, 'default', drone.getModifiedItemAttr('maxVelocity'), drone.getModifiedItemAttr('radius')),)) return projectedData