* fluent, *.py: Data and plots returned from functions will now show up in
the navigator window.
This commit is contained in:
@@ -4,29 +4,6 @@ import gobject
|
||||
import plots
|
||||
import logger
|
||||
|
||||
class NavigatorStore (gtk.TreeStore):
|
||||
def __init__(self,project):
|
||||
gtk.TreeStore.__init__(self, gobject.TYPE_STRING, plots.Plot)
|
||||
self.project = project
|
||||
iter = self.append(None)
|
||||
self.set_value(iter, 0, ('Sine Plot'))
|
||||
self.set_value(iter, 1, (plots.SinePlot(project)))
|
||||
|
||||
iter = self.append(None)
|
||||
self.set_value(iter, 0, ('Scatter Plot'))
|
||||
self.set_value(iter, 1, (plots.ScatterPlot(project)))
|
||||
|
||||
iter = self.append(None)
|
||||
self.set_value(iter, 0, ('Scatter Plot 2'))
|
||||
self.set_value(iter, 1, (plots.ScatterPlot(project)))
|
||||
|
||||
def plot_at(self, path):
|
||||
iter = self.get_iter(path)
|
||||
plot = self.get_value(iter, 1)
|
||||
if plot:
|
||||
plot.show()
|
||||
return plot
|
||||
|
||||
class NavigatorView (gtk.TreeView):
|
||||
def __init__(self, nav, app):
|
||||
gtk.TreeView.__init__(self, nav)
|
||||
@@ -43,6 +20,8 @@ class NavigatorView (gtk.TreeView):
|
||||
logger.log('debug', 'Initializing naviagor window')
|
||||
|
||||
def row_activated_handler(self, widget, path, column):
|
||||
plot = self.navigator.plot_at(path)
|
||||
|
||||
iter = self.navigator.get_iter(path)
|
||||
object = self.navigator.get_value(iter, 2)
|
||||
logger.log('notice', 'Button pressed')
|
||||
self.app.change_plot(plot)
|
||||
self.app.change_plot(object)
|
||||
|
||||
@@ -73,7 +73,6 @@ class SmallView (gtk.Table):
|
||||
def set_child(self, child, col, row):
|
||||
cur_widget = self.child_views[col][row]
|
||||
cur_widget.disconnect(cur_widget.parent_signalling)
|
||||
print cur_widget
|
||||
self.remove(cur_widget)
|
||||
self.attach(child, col, col+1, row, row+1)
|
||||
child.parent_signalling = child.connect('button_press_event', self.__view_button_event__)
|
||||
|
||||
@@ -1,8 +1,15 @@
|
||||
import dataset
|
||||
import plots
|
||||
import scipy
|
||||
import gobject
|
||||
import gtk
|
||||
|
||||
class Project:
|
||||
def __init__(self,name="Testing"):
|
||||
self.data_tree = gtk.TreeStore(gobject.TYPE_STRING,
|
||||
gobject.TYPE_STRING,
|
||||
gobject.TYPE_PYOBJECT)
|
||||
|
||||
self.name = name
|
||||
self.dim_names = []
|
||||
self._observers = {}
|
||||
@@ -39,6 +46,26 @@ class Project:
|
||||
"""Returns the current selection object"""
|
||||
return self.sel_obj.current_selection
|
||||
|
||||
def add_data(self, parent, data):
|
||||
"""Adds a set of data and plots to the navigator.
|
||||
|
||||
This method is usually called after a Function in a workflow
|
||||
has finished and returns its output."""
|
||||
for d in data:
|
||||
if isinstance(d, dataset.Dataset):
|
||||
self.add_dataset(d)
|
||||
self.data_tree_insert(None, 'data', d)
|
||||
elif isinstance(d, plots.Plot):
|
||||
# self.add_view(d)
|
||||
self.data_tree_insert(None, 'view', d)
|
||||
|
||||
def data_tree_insert(self, parent, text, data):
|
||||
tree = self.data_tree
|
||||
iter = tree.append(parent)
|
||||
tree.set_value(iter, 0, text)
|
||||
tree.set_value(iter, 1, type(data))
|
||||
tree.set_value(iter, 2, data)
|
||||
|
||||
def add_dataset(self,dataset):
|
||||
"""Appends a new Dataset to the project."""
|
||||
self.datasets.append(dataset)
|
||||
@@ -52,6 +79,11 @@ class Project:
|
||||
dim_name = dim_name + "_t"
|
||||
return dim_name
|
||||
|
||||
|
||||
|
||||
def object_at(self, path):
|
||||
"Returns the object at a given path in the tree."
|
||||
iter = self.get_iter(path)
|
||||
object = self.get_value(iter, 2)
|
||||
if object:
|
||||
object.show()
|
||||
return object
|
||||
|
||||
|
||||
@@ -92,7 +92,7 @@ class WorkflowView (gtk.VBox):
|
||||
project = self.workflow.app.project
|
||||
new_data = function.run(project.current_data)
|
||||
if new_data != None:
|
||||
project.current_data = new_data
|
||||
project.add_data(None, new_data)
|
||||
logger.log('debug', 'Function ended: %s' % function.name)
|
||||
|
||||
def button_click_handler(self, button):
|
||||
|
||||
Reference in New Issue
Block a user