Beispiel #1
0
 def __init__(self, settings, database, project=None):
     super(PlotsMath, self).__init__()
     self.ui = Ui_PlotsMath()
     self.ui.setupUi(self)
     self.settings = settings
     self.project=project
     self.plot = QtCommons.nestWidget(self.ui.plot, QMathPlotWidget())
     self.reference_dialog = ReferenceSpectraDialog(database)
     self.reference_dialog.fits_picked.connect(self.open_fits)
     self.toolbar = QToolBar('Instrument Response Toolbar')
     open_btn = QtCommons.addToolbarPopup(self.toolbar, text="Open...", icon_file=':/new_open_20')
     open_file_action = open_btn.menu().addAction('FITS file')
     open_btn.menu().addAction('Reference library', self.reference_dialog.show)
     self.blackbody_menu = blackbody.BlackBodyAction(self.blackbody, open_btn.menu())
     
     if project:
         save_result = QtCommons.addToolbarPopup(self.toolbar, text='Save', icon_file=':/save_20')
         save_result.menu().addAction('As File', lambda: QtCommons.save_file('Save Operation Result...', FITS_EXTS, lambda f: self.save(f[0]), project.path))
         save_result.menu().addAction('As Instrument Response', self.save_project_instrument_response)
         open_file_action.triggered.connect(lambda: QtCommons.open_file('Open FITS Spectrum',FITS_EXTS, lambda f: self.open_fits(f[0]), project.path))
     else:
         open_file_action.triggered.connect(lambda: open_file_sticky('Open FITS Spectrum',FITS_EXTS, lambda f: self.open_fits(f[0]), self.settings, CALIBRATED_PROFILE, [RAW_PROFILE]))
         self.toolbar.addAction(QIcon(':/save_20'), 'Save', lambda: save_file_sticky('Save Operation Result...', 'FITS file (.fit)', lambda f: self.save(f[0]), self.settings, MATH_OPERATION, [CALIBRATED_PROFILE]))
         
     self.toolbar.addAction('Set operand', self.set_operand)
     self.toolbar.addSeparator()
     self.toolbar.addAction(self.ui.actionZoom)
     self.ui.actionZoom.triggered.connect(self.start_zoom)
     self.toolbar.addAction(self.ui.actionReset_Zoom)
     self.ui.actionReset_Zoom.triggered.connect(self.reset_zoom)
     self.toolbar.addSeparator()
     self.operands_model = QStandardItemModel()
     self.ui.operands_listview.setModel(self.operands_model)
     remove_btn = QtCommons.addToolbarPopup(self.toolbar, text='Remove...')
     remove_btn.menu().addAction(self.ui.actionSelectPointsToRemove)
     remove_btn.menu().addAction("Before point", lambda: spectrum_trim_dialog(self.spectrum, 'before', self.plot.axes, lambda: self.draw(), self, before_removal=self.undo.save_undo))
     remove_btn.menu().addAction("After point", lambda: spectrum_trim_dialog(self.spectrum, 'after', self.plot.axes, lambda: self.draw(), self, before_removal=self.undo.save_undo))
     self.ui.clear_operands.clicked.connect(self.operands_model.clear)
     self.ui.remove_operand.clicked.connect(lambda: self.operands_model.removeRows(self.ui.operands_listview.selectionModel().selectedRows()[0].row(), 1))
         
     self.operands_model.rowsInserted.connect(lambda: self.ui.clear_operands.setEnabled(self.operands_model.rowCount() > 0) )
     self.operands_model.rowsRemoved.connect(lambda: self.ui.clear_operands.setEnabled(self.operands_model.rowCount() > 0) )
     self.ui.operands_listview.selectionModel().selectionChanged.connect(lambda s, u: self.ui.remove_operand.setEnabled(len(s)))
     self.ui.actionSelectPointsToRemove.triggered.connect(self.pick_rm_points)
     self.undo = Undo(None, self.draw)
     self.undo.add_actions(self.toolbar)
     self.ui.spline_factor.valueChanged.connect(self.factor_valueChanged)
     self.ui.spline_degrees.valueChanged.connect(lambda v: self.draw())
     self.ui.spline_factor_auto.toggled.connect(lambda v: self.draw())
     self.ui.spline_factor_auto.toggled.connect(lambda v: self.ui.spline_factor.setEnabled(not v))
     self.ui.execute.clicked.connect(self.execute_operation)
     self.plot.figure.tight_layout()