2006-04-16 20:25:54 +02:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
import sys
|
|
|
|
|
|
|
|
import pygtk
|
|
|
|
pygtk.require('2.0')
|
|
|
|
import gtk
|
|
|
|
import gtk.gdk
|
|
|
|
import gtk.glade
|
|
|
|
import gnome
|
|
|
|
import gnome.ui
|
2006-04-20 12:27:58 +02:00
|
|
|
import scipy
|
2006-04-25 11:53:35 +02:00
|
|
|
import pango
|
|
|
|
from system import project, workflow, dataset, logger, plots, navigator, dialogs
|
|
|
|
|
2006-04-16 20:25:54 +02:00
|
|
|
|
|
|
|
PROGRAM_NAME = 'fluent'
|
|
|
|
VERSION = '0.1.0'
|
|
|
|
GLADEFILENAME = 'system/fluent.glade'
|
|
|
|
|
|
|
|
class FluentApp:
|
|
|
|
|
2006-04-25 14:19:25 +02:00
|
|
|
def __init__(self, wf):
|
2006-04-16 20:25:54 +02:00
|
|
|
# Application variables
|
2006-04-22 23:46:44 +02:00
|
|
|
self.project = None
|
2006-04-20 12:27:58 +02:00
|
|
|
self.current_data = None
|
2006-04-26 14:11:23 +02:00
|
|
|
self._last_view = None
|
|
|
|
self._plot_toolbar = None
|
2006-04-24 11:53:07 +02:00
|
|
|
|
2006-04-16 20:25:54 +02:00
|
|
|
gtk.glade.set_custom_handler(self.custom_object_factory)
|
2006-04-19 21:59:55 +02:00
|
|
|
self.widget_tree = gtk.glade.XML(GLADEFILENAME, 'appwindow')
|
2006-04-25 14:19:25 +02:00
|
|
|
self.workflow = wf(self)
|
2006-04-22 23:46:44 +02:00
|
|
|
|
|
|
|
def set_project(self, project):
|
|
|
|
logger.log('notice', 'Creating a new project')
|
|
|
|
self.project = project
|
2006-04-20 17:30:29 +02:00
|
|
|
self.workflow.add_project(self.project)
|
2006-04-22 23:46:44 +02:00
|
|
|
self.navigator_view.add_project(self.project)
|
|
|
|
|
|
|
|
def set_workflow(self, workflow):
|
|
|
|
self.workflow = workflow
|
|
|
|
self.wf_menu.set_workflow(self.workflow)
|
2006-04-16 20:25:54 +02:00
|
|
|
|
|
|
|
def custom_object_factory(self, glade, function_name, widget_name,\
|
|
|
|
str1, str2, int1, int2):
|
|
|
|
handler = getattr(self, function_name)
|
|
|
|
return handler(str1, str2, int1, int2)
|
|
|
|
|
|
|
|
def create_logview(self, str1, str2, int1, int2):
|
|
|
|
# Set up log view
|
|
|
|
self.log_view = logger.LogView(logger.logger)
|
2006-04-26 15:29:10 +02:00
|
|
|
# self.log_view.set_level('notice')
|
2006-04-16 20:25:54 +02:00
|
|
|
self.log_view.show()
|
|
|
|
return self.log_view
|
|
|
|
|
2006-04-18 00:30:53 +02:00
|
|
|
def create_main_view(self, str1, str2, int1, int2):
|
2006-04-26 14:11:23 +02:00
|
|
|
self.main_view = plots.MainView(self._update_toolbar)
|
2006-04-18 00:30:53 +02:00
|
|
|
self.main_view.show()
|
|
|
|
return self.main_view
|
|
|
|
|
2006-04-26 14:11:23 +02:00
|
|
|
def _update_toolbar(self, view):
|
|
|
|
logger.log("debug", "view changed to %s" % view)
|
|
|
|
# don't do anything on no change
|
|
|
|
if self._last_view == view:
|
|
|
|
return
|
|
|
|
self._last_view = view
|
|
|
|
|
|
|
|
window = self.widget_tree.get_widget('plot_toolbar_dock')
|
|
|
|
if self._plot_toolbar:
|
|
|
|
window.remove(self._plot_toolbar)
|
|
|
|
|
|
|
|
self._plot_toolbar = view.get_toolbar()
|
|
|
|
if self._plot_toolbar:
|
|
|
|
window.add(self._plot_toolbar)
|
|
|
|
|
2006-04-17 22:27:39 +02:00
|
|
|
def create_small_view(self, str1, str2, int1, int2):
|
|
|
|
self.small_view = plots.SmallView()
|
|
|
|
self.small_view.show()
|
|
|
|
return self.small_view
|
|
|
|
|
2006-04-20 12:27:58 +02:00
|
|
|
def create_large_view(self, str1, str2, int1, int2,project):
|
2006-04-17 22:27:39 +02:00
|
|
|
self.large_view = plots.LargeView()
|
|
|
|
self.large_view.show()
|
|
|
|
return self.large_view
|
|
|
|
|
2006-04-16 20:25:54 +02:00
|
|
|
def create_navigator_view(self, str1, str2, int1, int2):
|
2006-04-22 23:46:44 +02:00
|
|
|
# tree = self.project.data_tree
|
|
|
|
self.navigator_view = navigator.NavigatorView(None, self)
|
2006-04-16 20:25:54 +02:00
|
|
|
self.navigator_view.show()
|
|
|
|
return self.navigator_view
|
|
|
|
|
|
|
|
def show(self):
|
|
|
|
self.init_gui()
|
|
|
|
|
|
|
|
def init_gui(self):
|
2006-04-19 21:59:55 +02:00
|
|
|
self['appwindow'].set_size_request(800, 600)
|
2006-04-16 20:25:54 +02:00
|
|
|
|
|
|
|
# Set up workflow
|
2006-04-22 23:46:44 +02:00
|
|
|
self.wf_menu = workflow.WorkflowView(self.workflow)
|
|
|
|
self.wf_menu.show()
|
|
|
|
self['workflow_vbox'].pack_end(self.wf_menu)
|
2006-04-19 20:25:44 +02:00
|
|
|
|
2006-04-16 20:25:54 +02:00
|
|
|
# Set up plot toolbar
|
2006-04-19 21:59:55 +02:00
|
|
|
# self['plot_toolbar_dock'].add(plot.get_toolbar(self.app))
|
2006-04-16 20:25:54 +02:00
|
|
|
|
|
|
|
# Connect signals
|
|
|
|
signals = {'on_quit1_activate' : (gtk.main_quit),
|
|
|
|
'on_appwindow_delete_event' : (gtk.main_quit),
|
2006-04-17 22:27:39 +02:00
|
|
|
'on_zoom_in_button_clicked' : (self.on_single_view),
|
2006-04-22 23:46:44 +02:00
|
|
|
'on_zoom_out_button_clicked' : (self.on_multiple_view),
|
2006-04-22 23:56:30 +02:00
|
|
|
'on_new1_activate' : (self.on_create_project),
|
|
|
|
'on_button_new_clicked' : (self.on_create_project),
|
2006-04-25 20:06:21 +02:00
|
|
|
'on_workflow_refresh_clicked' : (self.on_workflow_refresh_clicked),
|
2006-04-27 11:55:19 +02:00
|
|
|
'on_index1_activate' : (self.on_help_index),
|
|
|
|
'on_about1_activate' : (self.on_help_about),
|
|
|
|
'on_report_bug1_activate' : (self.on_help_report_bug)}
|
2006-04-16 20:25:54 +02:00
|
|
|
self.widget_tree.signal_autoconnect(signals)
|
|
|
|
|
|
|
|
# Log that we've set up the app now
|
|
|
|
logger.log('debug', 'Program started')
|
|
|
|
|
|
|
|
def change_plot(self, plot):
|
2006-04-18 00:30:53 +02:00
|
|
|
pt = self.widget_tree.get_widget('main_view')
|
|
|
|
pt.insert_view(plot)
|
2006-04-16 20:25:54 +02:00
|
|
|
|
2006-04-17 22:27:39 +02:00
|
|
|
def on_single_view(self, button):
|
2006-04-18 00:30:53 +02:00
|
|
|
nb = self.widget_tree.get_widget('main_view')
|
|
|
|
nb.goto_large()
|
2006-04-17 22:27:39 +02:00
|
|
|
|
|
|
|
def on_multiple_view(self, button):
|
2006-04-18 00:30:53 +02:00
|
|
|
nb = self.widget_tree.get_widget('main_view')
|
|
|
|
nb.goto_small()
|
2006-04-16 20:25:54 +02:00
|
|
|
|
2006-04-19 21:59:55 +02:00
|
|
|
def __getitem__(self, key):
|
|
|
|
return self.widget_tree.get_widget(key)
|
|
|
|
|
2006-04-22 23:46:44 +02:00
|
|
|
def on_create_project(self, *rest):
|
|
|
|
d = dialogs.CreateProjectDruid(self)
|
|
|
|
d.run()
|
|
|
|
|
2006-04-22 23:56:30 +02:00
|
|
|
def on_help_about(self, *rest):
|
|
|
|
widget_tree = gtk.glade.XML(GLADEFILENAME, 'aboutdialog')
|
|
|
|
about = widget_tree.get_widget('aboutdialog')
|
|
|
|
about.run()
|
|
|
|
|
2006-04-27 11:55:19 +02:00
|
|
|
def on_help_index(self, *ignored):
|
|
|
|
gnome.help_display_uri('https://dev.pvv.org/projects/fluent/wiki/help')
|
|
|
|
|
|
|
|
def on_help_report_bug(self, *ignored):
|
|
|
|
gnome.help_display_uri('https://dev.pvv.org/projects/fluent/newticket')
|
|
|
|
|
2006-04-25 20:06:21 +02:00
|
|
|
def on_workflow_refresh_clicked(self, *ignored):
|
|
|
|
try:
|
|
|
|
reload(sys.modules[self.workflow.__class__.__module__])
|
|
|
|
except Exception, e:
|
|
|
|
logger.log('warning', 'Cannot reload workflow')
|
|
|
|
logger.log('warning', e)
|
|
|
|
else:
|
|
|
|
logger.log('notice', 'Successfully reloaded workflow')
|
2006-04-27 11:55:19 +02:00
|
|
|
|