97 lines
3.2 KiB
Python
97 lines
3.2 KiB
Python
# =============================================================================
|
|
# 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 <http://www.gnu.org/licenses/>.
|
|
# =============================================================================
|
|
|
|
import gui.mainFrame
|
|
from eos.graph import Data
|
|
from eos.graph.fitDpsRange import FitDpsRangeGraph as EosFitDpsRangeGraph
|
|
from gui.bitmap_loader import BitmapLoader
|
|
from gui.graph import Graph
|
|
from service.attribute import Attribute
|
|
|
|
|
|
class FitDpsRangeGraph(Graph):
|
|
|
|
propertyAttributeMap = {"angle": "maxVelocity",
|
|
"distance": "maxRange",
|
|
"signatureRadius": "signatureRadius",
|
|
"velocity": "maxVelocity"}
|
|
|
|
propertyLabelMap = {"angle": "Target Angle (degrees)",
|
|
"distance": "Distance to Target (km)",
|
|
"signatureRadius": "Target Signature Radius (m)",
|
|
"velocity": "Target Velocity (m/s)"}
|
|
|
|
defaults = EosFitDpsRangeGraph.defaults.copy()
|
|
|
|
def __init__(self):
|
|
Graph.__init__(self)
|
|
self.defaults["distance"] = "0-100"
|
|
self.name = "DPS vs. Range"
|
|
self.fitDpsRange = None
|
|
self.mainFrame = gui.mainFrame.MainFrame.getInstance()
|
|
|
|
def getFields(self):
|
|
return self.defaults
|
|
|
|
def getLabels(self):
|
|
return self.propertyLabelMap
|
|
|
|
def getIcons(self):
|
|
icons = {}
|
|
sAttr = Attribute.getInstance()
|
|
for key, attrName in self.propertyAttributeMap.items():
|
|
iconFile = sAttr.getAttributeInfo(attrName).iconID
|
|
bitmap = BitmapLoader.getBitmap(iconFile, "icons")
|
|
if bitmap:
|
|
icons[key] = bitmap
|
|
|
|
return icons
|
|
|
|
def getPoints(self, fit, fields):
|
|
fitDpsRange = getattr(self, "fitDpsRange", None)
|
|
if fitDpsRange is None or fitDpsRange.fit != fit:
|
|
fitDpsRange = self.fitDpsRange = EosFitDpsRangeGraph(fit)
|
|
|
|
fitDpsRange.clearData()
|
|
variable = None
|
|
for fieldName, value in fields.items():
|
|
d = Data(fieldName, value)
|
|
if not d.isConstant():
|
|
if variable is None:
|
|
variable = fieldName
|
|
else:
|
|
# We can't handle more then one variable atm, OOPS FUCK OUT
|
|
return False, "Can only handle 1 variable"
|
|
|
|
fitDpsRange.setData(d)
|
|
|
|
if variable is None:
|
|
return False, "No variable"
|
|
|
|
x = []
|
|
y = []
|
|
for point, val in fitDpsRange.getIterator():
|
|
x.append(point[variable])
|
|
y.append(val)
|
|
|
|
return x, y
|
|
|
|
|
|
FitDpsRangeGraph.register()
|