Move more stuff away from the frame

This commit is contained in:
DarkPhoenix
2019-06-18 16:12:27 +03:00
parent 3359d8cb88
commit 4ca3f10bc9
4 changed files with 158 additions and 202 deletions

View File

@@ -1,24 +0,0 @@
# =============================================================================
# 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 wx.lib.newevent
RefreshGraph, REFRESH_GRAPH = wx.lib.newevent.NewEvent()

View File

@@ -30,8 +30,6 @@ import gui.globalEvents as GE
import gui.mainFrame import gui.mainFrame
from gui.bitmap_loader import BitmapLoader from gui.bitmap_loader import BitmapLoader
from gui.builtinGraphs.base import Graph from gui.builtinGraphs.base import Graph
from service.fit import Fit
from .events import REFRESH_GRAPH
from .panel import GraphControlPanel from .panel import GraphControlPanel
@@ -70,6 +68,11 @@ class GraphFrame(wx.Frame):
pyfalog.warning('Matplotlib is not enabled. Skipping initialization.') pyfalog.warning('Matplotlib is not enabled. Skipping initialization.')
return return
wx.Frame.__init__(self, parent, title='pyfa: Graph Generator', style=style, size=(520, 390))
self.mainFrame = gui.mainFrame.MainFrame.getInstance()
self.SetIcon(wx.Icon(BitmapLoader.getBitmap('graphs_small', 'gui')))
# Remove matplotlib font cache, see #234 # Remove matplotlib font cache, see #234
try: try:
cache_dir = mpl._get_cachedir() cache_dir = mpl._get_cachedir()
@@ -79,19 +82,14 @@ class GraphFrame(wx.Frame):
if os.access(cache_dir, os.W_OK | os.X_OK) and os.path.isfile(cache_file): if os.access(cache_dir, os.W_OK | os.X_OK) and os.path.isfile(cache_file):
os.remove(cache_file) os.remove(cache_file)
wx.Frame.__init__(self, parent, title='pyfa: Graph Generator', style=style, size=(520, 390))
i = wx.Icon(BitmapLoader.getBitmap('graphs_small', 'gui'))
self.SetIcon(i)
self.mainFrame = gui.mainFrame.MainFrame.getInstance()
mainSizer = wx.BoxSizer(wx.VERTICAL) mainSizer = wx.BoxSizer(wx.VERTICAL)
# Graph selector # Layout - graph selector
self.graphSelection = wx.Choice(self, wx.ID_ANY, style=0) self.graphSelection = wx.Choice(self, wx.ID_ANY, style=0)
self.graphSelection.Bind(wx.EVT_CHOICE, self.OnGraphSwitched)
mainSizer.Add(self.graphSelection, 0, wx.EXPAND) mainSizer.Add(self.graphSelection, 0, wx.EXPAND)
# Plot area # Layout - plot area
self.figure = Figure(figsize=(5, 3), tight_layout={'pad': 1.08}) self.figure = Figure(figsize=(5, 3), tight_layout={'pad': 1.08})
rgbtuple = wx.SystemSettings.GetColour(wx.SYS_COLOUR_BTNFACE).Get() rgbtuple = wx.SystemSettings.GetColour(wx.SYS_COLOUR_BTNFACE).Get()
clr = [c / 255. for c in rgbtuple] clr = [c / 255. for c in rgbtuple]
@@ -105,45 +103,29 @@ class GraphFrame(wx.Frame):
mainSizer.Add(wx.StaticLine(self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL), 0, wx.EXPAND) mainSizer.Add(wx.StaticLine(self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL), 0, wx.EXPAND)
# Graph control panel # Layout - graph control panel
self.ctrlPanel = GraphControlPanel(self, self) self.ctrlPanel = GraphControlPanel(self, self)
mainSizer.Add(self.ctrlPanel, 0, wx.EXPAND | wx.ALL, 0) mainSizer.Add(self.ctrlPanel, 0, wx.EXPAND | wx.ALL, 0)
# Setup - graph selector
for view in Graph.views: for view in Graph.views:
view = view() self.graphSelection.Append(view.name, view())
self.graphSelection.Append(view.name, view)
self.graphSelection.SetSelection(0) self.graphSelection.SetSelection(0)
self.updateGraphWidgets() self.ctrlPanel.updateControlsForView(self.getView())
self.sl1 = wx.StaticLine(self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL)
mainSizer.Add(self.sl1, 0, wx.EXPAND)
# Event bindings
self.ctrlPanel.fitList.fitList.Bind(wx.EVT_LEFT_DCLICK, self.OnLeftDClick)
self.ctrlPanel.fitList.fitList.Bind(wx.EVT_CONTEXT_MENU, self.OnContextMenu)
self.Bind(REFRESH_GRAPH, self.OnRefreshGraph)
self.ctrlPanel.showY0Cb.Bind(wx.EVT_CHECKBOX, self.OnNonDestructiveControlsUpdate)
self.mainFrame.Bind(GE.FIT_CHANGED, self.OnFitChanged)
self.mainFrame.Bind(GE.FIT_REMOVED, self.OnFitRemoved)
self.Bind(wx.EVT_CLOSE, self.closeEvent) self.Bind(wx.EVT_CLOSE, self.closeEvent)
self.Bind(wx.EVT_CHAR_HOOK, self.kbEvent) self.Bind(wx.EVT_CHAR_HOOK, self.kbEvent)
self.Bind(wx.EVT_CHOICE, self.graphChanged) self.mainFrame.Bind(GE.FIT_CHANGED, self.OnFitChanged)
from gui.builtinStatsViews.resistancesViewFull import EFFECTIVE_HP_TOGGLED # Grr crclar gons from gui.builtinStatsViews.resistancesViewFull import EFFECTIVE_HP_TOGGLED # Grr crclar gons
self.mainFrame.Bind(EFFECTIVE_HP_TOGGLED, self.OnEhpToggled) self.mainFrame.Bind(EFFECTIVE_HP_TOGGLED, self.OnEhpToggled)
self.contextMenu = wx.Menu()
removeItem = wx.MenuItem(self.contextMenu, 1, 'Remove Fit')
self.contextMenu.Append(removeItem)
self.contextMenu.Bind(wx.EVT_MENU, self.ContextMenuHandler, removeItem)
self.SetSizer(mainSizer) self.SetSizer(mainSizer)
self.draw()
self.Fit() self.Fit()
self.SetMinSize(self.GetSize()) self.SetMinSize(self.GetSize())
def handleDrag(self, type, fitID):
if type == 'fit':
self.AppendFitToList(fitID)
def closeEvent(self, event): def closeEvent(self, event):
self.closeWindow() self.closeWindow()
event.Skip() event.Skip()
@@ -154,22 +136,8 @@ class GraphFrame(wx.Frame):
if keycode == wx.WXK_ESCAPE and mstate.GetModifiers() == wx.MOD_NONE: if keycode == wx.WXK_ESCAPE and mstate.GetModifiers() == wx.MOD_NONE:
self.closeWindow() self.closeWindow()
return return
elif keycode == 65 and mstate.GetModifiers() == wx.MOD_CONTROL:
self.ctrlPanel.fitList.fitList.selectAll()
elif keycode in (wx.WXK_DELETE, wx.WXK_NUMPAD_DELETE) and mstate.GetModifiers() == wx.MOD_NONE:
self.removeFits(self.getSelectedFits())
event.Skip() event.Skip()
def OnContextMenu(self, event):
if self.getSelectedFits():
self.PopupMenu(self.contextMenu)
def ContextMenuHandler(self, event):
selectedMenuItem = event.GetId()
if selectedMenuItem == 1: # Copy was chosen
fits = self.getSelectedFits()
self.removeFits(fits)
def OnEhpToggled(self, event): def OnEhpToggled(self, event):
event.Skip() event.Skip()
view = self.getView() view = self.getView()
@@ -179,65 +147,38 @@ class GraphFrame(wx.Frame):
def OnFitChanged(self, event): def OnFitChanged(self, event):
event.Skip() event.Skip()
view = self.getView() self.getView().clearCache(key=event.fitID)
view.clearCache(key=event.fitID)
self.draw() self.draw()
def OnFitRemoved(self, event): def OnGraphSwitched(self, event):
event.Skip() self.clearCache()
fit = next((f for f in self.ctrlPanel.fits if f.ID == event.fitID), None) self.ctrlPanel.updateControlsForView(self.getView())
if fit is not None: self.draw()
self.removeFits([fit])
def graphChanged(self, event):
self.ctrlPanel.selectedY = None
self.updateGraphWidgets()
event.Skip() event.Skip()
def closeWindow(self): def closeWindow(self):
from gui.builtinStatsViews.resistancesViewFull import EFFECTIVE_HP_TOGGLED # Grr gons from gui.builtinStatsViews.resistancesViewFull import EFFECTIVE_HP_TOGGLED # Grr gons
self.ctrlPanel.fitList.fitList.Unbind(wx.EVT_LEFT_DCLICK, handler=self.OnLeftDClick)
self.mainFrame.Unbind(GE.FIT_CHANGED, handler=self.OnFitChanged) self.mainFrame.Unbind(GE.FIT_CHANGED, handler=self.OnFitChanged)
self.mainFrame.Unbind(GE.FIT_REMOVED, handler=self.OnFitRemoved)
self.mainFrame.Unbind(EFFECTIVE_HP_TOGGLED, handler=self.OnEhpToggled) self.mainFrame.Unbind(EFFECTIVE_HP_TOGGLED, handler=self.OnEhpToggled)
self.ctrlPanel.unbindExternalEvents()
self.Destroy() self.Destroy()
def getView(self): def getView(self):
return self.graphSelection.GetClientData(self.graphSelection.GetSelection()) return self.graphSelection.GetClientData(self.graphSelection.GetSelection())
def getValues(self): def clearCache(self, key=None):
values = {} self.getView().clearCache(key=key)
for fieldHandle, field in self.ctrlPanel.fields.items():
values[fieldHandle] = field.GetValue()
return values def draw(self):
def OnNonDestructiveControlsUpdate(self, event):
event.Skip()
self.draw()
def OnRefreshGraph(self, event):
self.draw()
def updateGraphWidgets(self):
view = self.getView()
self.ctrlPanel.updateControlsForView(view)
self.draw()
def draw(self, event=None):
global mpl_version global mpl_version
if event is not None:
event.Skip()
# todo: FIX THIS, see #1430. draw() is not being unbound properly when the window closes, this is an easy fix, # todo: FIX THIS, see #1430. draw() is not being unbound properly when the window closes, this is an easy fix,
# but not a proper solution # but not a proper solution
if not self: if not self:
pyfalog.warning('GraphFrame handled event, however GraphFrame no longer exists. Ignoring event') pyfalog.warning('GraphFrame handled event, however GraphFrame no longer exists. Ignoring event')
return return
values = self.getValues() values = self.ctrlPanel.getValues()
view = self.getView() view = self.getView()
self.subplot.clear() self.subplot.clear()
self.subplot.grid(True) self.subplot.grid(True)
@@ -255,7 +196,7 @@ class GraphFrame(wx.Frame):
self.subplot.set(xlabel=view.xDef.axisLabel, ylabel=view.yDefs[chosenY].axisLabel) self.subplot.set(xlabel=view.xDef.axisLabel, ylabel=view.yDefs[chosenY].axisLabel)
for fit in self.ctrlPanel.fits: for fit in self.ctrlPanel.fitList.fits:
try: try:
xs, ys = view.getPlotPoints(fit, extraInputs, xRange, 100, chosenY) xs, ys = view.getPlotPoints(fit, extraInputs, xRange, 100, chosenY)
@@ -318,44 +259,3 @@ class GraphFrame(wx.Frame):
self.canvas.draw() self.canvas.draw()
self.Refresh() self.Refresh()
def AppendFitToList(self, fitID):
sFit = Fit.getInstance()
fit = sFit.getFit(fitID)
if fit not in self.ctrlPanel.fits:
self.ctrlPanel.fits.append(fit)
self.ctrlPanel.fitList.fitList.update(self.ctrlPanel.fits)
self.draw()
def OnLeftDClick(self, event):
row, _ = self.ctrlPanel.fitList.fitList.HitTest(event.Position)
if row != -1:
try:
fit = self.ctrlPanel.fits[row]
except IndexError:
pass
else:
self.removeFits([fit])
def removeFits(self, fits):
toRemove = [f for f in fits if f in self.ctrlPanel.fits]
if not toRemove:
return
for fit in toRemove:
self.ctrlPanel.fits.remove(fit)
self.ctrlPanel.fitList.fitList.update(self.ctrlPanel.fits)
view = self.getView()
for fit in fits:
view.clearCache(key=fit.ID)
self.draw()
def getSelectedFits(self):
fits = []
for row in self.ctrlPanel.fitList.fitList.getSelectedRows():
try:
fit = self.ctrlPanel.fits[row]
except IndexError:
continue
fits.append(fit)
return fits

View File

@@ -22,47 +22,118 @@
import wx import wx
import gui.display import gui.display
import gui.globalEvents as GE
from service.fit import Fit
class FitList(wx.Panel): class FitList(gui.display.Display):
def __init__(self, parent): DEFAULT_COLS = (
wx.Panel.__init__(self, parent) 'Base Icon',
self.mainSizer = wx.BoxSizer(wx.VERTICAL) 'Base Name')
self.SetSizer(self.mainSizer)
def __init__(self, graphFrame, parent):
super().__init__(parent)
self.graphFrame = graphFrame
self.fits = []
self.fitList = FitDisplay(self)
self.mainSizer.Add(self.fitList, 1, wx.EXPAND)
fitToolTip = wx.ToolTip('Drag a fit into this list to graph it') fitToolTip = wx.ToolTip('Drag a fit into this list to graph it')
self.fitList.SetToolTip(fitToolTip) self.SetToolTip(fitToolTip)
fit = Fit.getInstance().getFit(self.graphFrame.mainFrame.getActiveFit())
if fit is not None:
self.fits.append(fit)
self.update(self.fits)
self.contextMenu = wx.Menu()
removeItem = wx.MenuItem(self.contextMenu, 1, 'Remove Fit')
self.contextMenu.Append(removeItem)
self.contextMenu.Bind(wx.EVT_MENU, self.ContextMenuHandler, removeItem)
self.graphFrame.mainFrame.Bind(GE.FIT_REMOVED, self.OnFitRemoved)
self.Bind(wx.EVT_LEFT_DCLICK, self.OnLeftDClick)
self.Bind(wx.EVT_CHAR_HOOK, self.kbEvent)
self.Bind(wx.EVT_CONTEXT_MENU, self.OnContextMenu)
class FitDisplay(gui.display.Display): def kbEvent(self, event):
keycode = event.GetKeyCode()
mstate = wx.GetMouseState()
if keycode == 65 and mstate.GetModifiers() == wx.MOD_CONTROL:
self.selectAll()
elif keycode in (wx.WXK_DELETE, wx.WXK_NUMPAD_DELETE) and mstate.GetModifiers() == wx.MOD_NONE:
self.removeFits(self.getSelectedFits())
event.Skip()
DEFAULT_COLS = ['Base Icon', def OnLeftDClick(self, event):
'Base Name'] row, _ = self.HitTest(event.Position)
if row != -1:
try:
fit = self.fits[row]
except IndexError:
pass
else:
self.removeFits([fit])
def __init__(self, parent): def OnContextMenu(self, event):
gui.display.Display.__init__(self, parent) if self.getSelectedFits():
self.PopupMenu(self.contextMenu)
def ContextMenuHandler(self, event):
selectedMenuItem = event.GetId()
if selectedMenuItem == 1:
fits = self.getSelectedFits()
self.removeFits(fits)
def OnFitRemoved(self, event):
event.Skip()
fit = next((f for f in self.fits if f.ID == event.fitID), None)
if fit is not None:
self.removeFits([fit])
def getSelectedFits(self):
fits = []
for row in self.getSelectedRows():
try:
fit = self.fits[row]
except IndexError:
continue
fits.append(fit)
return fits
def removeFits(self, fits):
toRemove = [f for f in fits if f in self.fits]
if not toRemove:
return
for fit in toRemove:
self.fits.remove(fit)
self.update(self.fits)
for fit in fits:
self.graphFrame.clearCache(key=fit.ID)
self.graphFrame.draw()
def unbindExternalEvents(self):
self.graphFrame.mainFrame.Unbind(GE.FIT_REMOVED, handler=self.OnFitRemoved)
def handleDrag(self, type, fitID):
if type == 'fit':
sFit = Fit.getInstance()
fit = sFit.getFit(fitID)
if fit not in self.fits:
self.fits.append(fit)
self.update(self.fits)
self.graphFrame.draw()
class TargetList(wx.Panel): class TargetList(gui.display.Display):
def __init__(self, parent): DEFAULT_COLS = (
wx.Panel.__init__(self, parent) 'Base Icon',
self.mainSizer = wx.BoxSizer(wx.VERTICAL) 'Base Name')
self.SetSizer(self.mainSizer)
self.targetList = TargetDisplay(self) def __init__(self, graphFrame, parent):
self.mainSizer.Add(self.targetList, 1, wx.EXPAND) super().__init__(parent)
self.graphFrame = graphFrame
self.targetFits = []
fitToolTip = wx.ToolTip('Drag a fit into this list to graph it') fitToolTip = wx.ToolTip('Drag a fit into this list to graph it')
self.targetList.SetToolTip(fitToolTip) self.SetToolTip(fitToolTip)
class TargetDisplay(gui.display.Display):
DEFAULT_COLS = ['Base Icon',
'Base Name']
def __init__(self, parent):
gui.display.Display.__init__(self, parent)

View File

@@ -23,7 +23,6 @@ import wx
from gui.bitmap_loader import BitmapLoader from gui.bitmap_loader import BitmapLoader
from service.fit import Fit from service.fit import Fit
from .events import RefreshGraph
from .lists import FitList, TargetList from .lists import FitList, TargetList
@@ -36,8 +35,6 @@ class GraphControlPanel(wx.Panel):
self.fields = {} self.fields = {}
self.selectedY = None self.selectedY = None
self.selectedYRbMap = {} self.selectedYRbMap = {}
self.drawTimer = wx.Timer(self)
self.Bind(wx.EVT_TIMER, self.redrawRequest, self.drawTimer)
mainSizer = wx.BoxSizer(wx.VERTICAL) mainSizer = wx.BoxSizer(wx.VERTICAL)
@@ -45,6 +42,7 @@ class GraphControlPanel(wx.Panel):
viewOptSizer = wx.BoxSizer(wx.VERTICAL) viewOptSizer = wx.BoxSizer(wx.VERTICAL)
self.showY0Cb = wx.CheckBox(self, wx.ID_ANY, 'Always show Y = 0', wx.DefaultPosition, wx.DefaultSize, 0) self.showY0Cb = wx.CheckBox(self, wx.ID_ANY, 'Always show Y = 0', wx.DefaultPosition, wx.DefaultSize, 0)
self.showY0Cb.SetValue(True) self.showY0Cb.SetValue(True)
self.showY0Cb.Bind(wx.EVT_CHECKBOX, self.OnShowY0Change)
viewOptSizer.Add(self.showY0Cb, 0, wx.LEFT | wx.TOP | wx.RIGHT | wx.EXPAND, 5) viewOptSizer.Add(self.showY0Cb, 0, wx.LEFT | wx.TOP | wx.RIGHT | wx.EXPAND, 5)
self.graphSubselSizer = wx.BoxSizer(wx.VERTICAL) self.graphSubselSizer = wx.BoxSizer(wx.VERTICAL)
viewOptSizer.Add(self.graphSubselSizer, 0, wx.ALL | wx.EXPAND, 5) viewOptSizer.Add(self.graphSubselSizer, 0, wx.ALL | wx.EXPAND, 5)
@@ -55,27 +53,33 @@ class GraphControlPanel(wx.Panel):
mainSizer.Add(paramSizer, 0, wx.EXPAND | wx.ALL, 0) mainSizer.Add(paramSizer, 0, wx.EXPAND | wx.ALL, 0)
srcTgtSizer = wx.BoxSizer(wx.HORIZONTAL) srcTgtSizer = wx.BoxSizer(wx.HORIZONTAL)
fit = Fit.getInstance().getFit(self.graphFrame.mainFrame.getActiveFit()) self.fitList = FitList(graphFrame, self)
self.fits = [fit] if fit is not None else []
self.fitList = FitList(self)
self.fitList.SetMinSize((270, -1)) self.fitList.SetMinSize((270, -1))
self.fitList.fitList.update(self.fits)
srcTgtSizer.Add(self.fitList, 1, wx.EXPAND) srcTgtSizer.Add(self.fitList, 1, wx.EXPAND)
self.targets = [] self.targets = []
self.targetList = TargetList(self) self.targetList = TargetList(graphFrame, self)
self.targetList.SetMinSize((270, -1)) self.targetList.SetMinSize((270, -1))
self.targetList.targetList.update(self.targets) self.targetList.update(self.targets)
srcTgtSizer.Add(self.targetList, 1, wx.EXPAND) srcTgtSizer.Add(self.targetList, 1, wx.EXPAND)
mainSizer.Add(srcTgtSizer, 1, wx.EXPAND | wx.ALL, 0) mainSizer.Add(srcTgtSizer, 1, wx.EXPAND | wx.ALL, 0)
self.SetSizer(mainSizer) self.SetSizer(mainSizer)
self.drawTimer = wx.Timer(self)
self.Bind(wx.EVT_TIMER, self.OnDrawTimer, self.drawTimer)
def getValues(self):
values = {}
for fieldHandle, field in self.fields.items():
values[fieldHandle] = field.GetValue()
return values
@property @property
def showY0(self): def showY0(self):
return self.showY0Cb.GetValue() return self.showY0Cb.GetValue()
def updateControlsForView(self, view): def updateControlsForView(self, view):
view.clearCache() self.selectedY = None
self.graphSubselSizer.Clear() self.graphSubselSizer.Clear()
self.inputsSizer.Clear() self.inputsSizer.Clear()
for child in self.Children: for child in self.Children:
@@ -103,7 +107,7 @@ class GraphControlPanel(wx.Panel):
for fieldHandle, fieldDef in (('x', view.xDef), *view.extraInputs.items()): for fieldHandle, fieldDef in (('x', view.xDef), *view.extraInputs.items()):
textBox = wx.TextCtrl(self, wx.ID_ANY, style=0) textBox = wx.TextCtrl(self, wx.ID_ANY, style=0)
self.fields[fieldHandle] = textBox self.fields[fieldHandle] = textBox
textBox.Bind(wx.EVT_TEXT, self.onFieldChanged) textBox.Bind(wx.EVT_TEXT, self.OnFieldChanged)
self.inputsSizer.Add(textBox, 1, wx.EXPAND | wx.ALIGN_CENTER_VERTICAL | wx.ALL, 3) self.inputsSizer.Add(textBox, 1, wx.EXPAND | wx.ALIGN_CENTER_VERTICAL | wx.ALL, 3)
if fieldDef.inputDefault is not None: if fieldDef.inputDefault is not None:
inputDefault = fieldDef.inputDefault inputDefault = fieldDef.inputDefault
@@ -127,22 +131,27 @@ class GraphControlPanel(wx.Panel):
self.inputsSizer.Add(imgLabelSizer, 0, wx.ALIGN_CENTER_VERTICAL) self.inputsSizer.Add(imgLabelSizer, 0, wx.ALIGN_CENTER_VERTICAL)
self.Layout() self.Layout()
def OnShowY0Change(self, event):
event.Skip()
self.graphFrame.draw()
def OnYTypeUpdate(self, event): def OnYTypeUpdate(self, event):
event.Skip() event.Skip()
obj = event.GetEventObject() obj = event.GetEventObject()
formatName = obj.GetLabel() formatName = obj.GetLabel()
self.selectedY = self.selectedYRbMap[formatName] self.selectedY = self.selectedYRbMap[formatName]
self.redrawRequest() self.graphFrame.draw()
def redrawRequest(self, event=None): def OnFieldChanged(self, event):
self.drawTimer.Stop() event.Skip()
wx.PostEvent(self.graphFrame, RefreshGraph())
def delayedDraw(self, event=None):
self.drawTimer.Stop() self.drawTimer.Stop()
self.drawTimer.Start(Fit.getInstance().serviceFittingOptions['marketSearchDelay'], True) self.drawTimer.Start(Fit.getInstance().serviceFittingOptions['marketSearchDelay'], True)
def onFieldChanged(self, event): def OnDrawTimer(self, event):
view = self.graphFrame.getView() event.Skip()
view.clearCache() self.graphFrame.clearCache()
self.delayedDraw() self.graphFrame.draw()
def unbindExternalEvents(self):
self.fitList.unbindExternalEvents()