- Timestamp:
- Sep 26, 2018 2:47:30 AM (6 years ago)
- Branches:
- ESS_GUI, ESS_GUI_batch_fitting, ESS_GUI_bumps_abstraction, ESS_GUI_iss1116, ESS_GUI_opencl, ESS_GUI_ordering, ESS_GUI_sync_sascalc
- Children:
- 428c3b2, a80e182
- Parents:
- 20f4857 (diff), 6d87082 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent. - Location:
- src/sas
- Files:
-
- 1 added
- 1 deleted
- 15 edited
Legend:
- Unmodified
- Added
- Removed
-
src/sas/qtgui/MainWindow/GuiManager.py
r20f4857 r8eea1b1 138 138 self.categoryManagerWidget = CategoryManager(self._parent, manager=self) 139 139 self.grid_window = None 140 self.grid_window = BatchOutputPanel(parent=self) 141 self.grid_subwindow = self._workspace.workspace.addSubWindow(self.grid_window) 142 self.grid_subwindow.setVisible(False) 143 self.grid_window.windowClosedSignal.connect(lambda: self.grid_subwindow.setVisible(False)) 144 140 145 self._workspace.toolBar.setVisible(LocalConfig.TOOLBAR_SHOW) 141 146 self._workspace.actionHide_Toolbar.setText("Show Toolbar") … … 616 621 Display/redisplay the batch fit viewer 617 622 """ 618 if self.grid_window is None: 619 self.grid_window = BatchOutputPanel(parent=self, output_data=output_data) 620 subwindow = self._workspace.workspace.addSubWindow(self.grid_window) 621 622 #self.grid_window = BatchOutputPanel(parent=self, output_data=output_data) 623 self.grid_window.show() 624 return 623 self.grid_subwindow.setVisible(True) 625 624 if output_data: 626 625 self.grid_window.addFitResults(output_data) 627 self.grid_window.show()628 if self.grid_window.windowState() == Qt.WindowMinimized:629 self.grid_window.setWindowState(Qt.WindowActive)630 626 631 627 def actionHide_Toolbar(self): -
src/sas/qtgui/MainWindow/UnitTesting/GuiManagerTest.py
r768387e0 rfa762f4 61 61 self.assertIsInstance(self.manager.ackWidget, Acknowledgements) 62 62 self.assertIsInstance(self.manager.aboutWidget, AboutBox) 63 self.assertIsInstance(self.manager.welcomePanel, WelcomePanel)63 #self.assertIsInstance(self.manager.welcomePanel, WelcomePanel) 64 64 65 65 def skip_testLogging(self): -
src/sas/qtgui/MainWindow/UnitTesting/MainWindowTest.py
r8353d90 rfa762f4 47 47 tmp_main.showMaximized() 48 48 # See that only one subwindow is up 49 self.assertEqual(len(tmp_main.workspace.subWindowList()), 1)49 self.assertEqual(len(tmp_main.workspace.subWindowList()), 2) 50 50 # and that the subwindow is the fitting perspective 51 51 self.assertIsInstance(tmp_main.workspace.subWindowList()[0].widget(), -
src/sas/qtgui/Perspectives/Fitting/FittingLogic.py
ra54bbf2b radf1c2a 223 223 return plots 224 224 225 def getScalarIntermediateResults(self, return_data): 226 """ 227 Returns a dict of scalar-only intermediate results from the return data. 228 """ 229 res = {} 230 for name, int_res in return_data["intermediate_results"].items(): 231 if isinstance(int_res, np.ndarray): 232 continue 233 res[name] = int_res 234 return res 235 225 236 def computeDataRange(self): 226 237 """ -
src/sas/qtgui/Perspectives/Fitting/FittingWidget.py
r9b9ec10 r6d87082 321 321 self.magneticAnglesWidget = QtWidgets.QWidget() 322 322 labl = QtWidgets.QLabel(self.magneticAnglesWidget) 323 pixmap = QtGui.QPixmap(GuiUtils.IMAGES_DIRECTORY_LOCATION + '/M_angles_pic. bmp')323 pixmap = QtGui.QPixmap(GuiUtils.IMAGES_DIRECTORY_LOCATION + '/M_angles_pic.png') 324 324 labl.setPixmap(pixmap) 325 325 self.magneticAnglesWidget.setFixedSize(pixmap.width(), pixmap.height()) … … 2297 2297 # TODO: multishell params in self.kernel_module.details[??] = value 2298 2298 2299 # handle display of effective radius parameter according to radius_effective_mode; pass ER into model if 2300 # necessary 2301 self.processEffectiveRadius() 2302 2299 2303 # Force the chart update when actual parameters changed 2300 2304 if model_column == 1: … … 2303 2307 # Update state stack 2304 2308 self.updateUndo() 2309 2310 def processEffectiveRadius(self): 2311 """ 2312 Checks the value of radius_effective_mode, if existent, and processes radius_effective as necessary. 2313 * mode == 0: This means 'unconstrained'; ensure use can specify ER. 2314 * mode > 0: This means it is constrained to a P(Q)-computed value in sasmodels; prevent user from editing ER. 2315 2316 Note: If ER has been computed, it is passed back to SasView as an intermediate result. That value must be 2317 displayed for the user; that is not dealt with here, but in complete1D. 2318 """ 2319 ER_row = self.getRowFromName("radius_effective") 2320 if ER_row is None: 2321 return 2322 2323 ER_mode_row = self.getRowFromName("radius_effective_mode") 2324 if ER_mode_row is None: 2325 return 2326 2327 try: 2328 ER_mode = int(self._model_model.item(ER_mode_row, 1).text()) 2329 except ValueError: 2330 logging.error("radius_effective_mode was set to an invalid value.") 2331 return 2332 2333 if ER_mode == 0: 2334 # ensure the ER value can be modified by user 2335 self.setParamEditableByRow(ER_row, True) 2336 elif ER_mode > 0: 2337 # ensure the ER value cannot be modified by user 2338 self.setParamEditableByRow(ER_row, False) 2339 else: 2340 logging.error("radius_effective_mode was set to an invalid value.") 2341 2342 def setParamEditableByRow(self, row, editable=True): 2343 """ 2344 Sets whether the user can edit a parameter in the table. If they cannot, the parameter name's font is changed, 2345 the value itself cannot be edited if clicked on, and the parameter may not be fitted. 2346 """ 2347 item_name = self._model_model.item(row, 0) 2348 item_value = self._model_model.item(row, 1) 2349 2350 item_value.setEditable(editable) 2351 2352 if editable: 2353 # reset font 2354 item_name.setFont(QtGui.QFont()) 2355 # reset colour 2356 item_name.setForeground(QtGui.QBrush()) 2357 # make checkable 2358 item_name.setCheckable(True) 2359 else: 2360 # change font 2361 font = QtGui.QFont() 2362 font.setItalic(True) 2363 item_name.setFont(font) 2364 # change colour 2365 item_name.setForeground(QtGui.QBrush(QtGui.QColor(50, 50, 50))) 2366 # make not checkable (and uncheck) 2367 item_name.setCheckState(QtCore.Qt.Unchecked) 2368 item_name.setCheckable(False) 2305 2369 2306 2370 def isCheckable(self, row): … … 2535 2599 self.communicate.plotUpdateSignal.emit([plot]) 2536 2600 2601 # Update radius_effective if relevant 2602 self.updateEffectiveRadius(return_data) 2603 2537 2604 def complete2D(self, return_data): 2538 2605 """ … … 2561 2628 for plot in new_plots: 2562 2629 self.communicate.plotUpdateSignal.emit([plot]) 2630 2631 def updateEffectiveRadius(self, return_data): 2632 """ 2633 Given return data from sasmodels, update the effective radius parameter in the GUI table with the new 2634 calculated value as returned by sasmodels (if the value was returned). 2635 """ 2636 ER_mode_row = self.getRowFromName("radius_effective_mode") 2637 if ER_mode_row is None: 2638 return 2639 try: 2640 ER_mode = int(self._model_model.item(ER_mode_row, 1).text()) 2641 except ValueError: 2642 logging.error("radius_effective_mode was set to an invalid value.") 2643 return 2644 if ER_mode < 1: 2645 # does not need updating if it is not being computed 2646 return 2647 2648 ER_row = self.getRowFromName("radius_effective") 2649 if ER_row is None: 2650 return 2651 2652 scalar_results = self.logic.getScalarIntermediateResults(return_data) 2653 ER_value = scalar_results.get("effective_radius") # note name of key 2654 if ER_value is None: 2655 return 2656 # ensure the model does not recompute when updating the value 2657 self._model_model.blockSignals(True) 2658 self._model_model.item(ER_row, 1).setText(str(ER_value)) 2659 self._model_model.blockSignals(False) 2660 # ensure the view is updated immediately 2661 self._model_model.layoutChanged.emit() 2563 2662 2564 2663 def calculateResiduals(self, fitted_data): -
src/sas/qtgui/Plotting/Plotter.py
r1f34e00 r34f13a83 75 75 if isinstance(data, Data1D): 76 76 self.data = data 77 if not self._data or data is None: 77 78 if not self._data: 78 79 return 79 80 -
src/sas/qtgui/Plotting/Plotter2D.py
r1f34e00 r34f13a83 95 95 self.data = data 96 96 97 if not self._data or data is None:97 if not self._data: 98 98 return 99 99 -
src/sas/qtgui/Plotting/PlotterBase.py
r863ebca r34f13a83 114 114 if not quickplot: 115 115 # Add the toolbar 116 self.toolbar.show() 116 # self.toolbar.show() 117 self.toolbar.hide() # hide for the time being 117 118 # Notify PlotHelper about the new plot 118 119 self.upatePlotHelper() … … 220 221 self.actionPrintImage = self.contextMenu.addAction("Print Image") 221 222 self.actionCopyToClipboard = self.contextMenu.addAction("Copy to Clipboard") 222 self.contextMenu.addSeparator()223 self.actionToggleMenu = self.contextMenu.addAction("Toggle Navigation Menu")223 #self.contextMenu.addSeparator() 224 #self.actionToggleMenu = self.contextMenu.addAction("Toggle Navigation Menu") 224 225 self.contextMenu.addSeparator() 225 226 … … 229 230 self.actionPrintImage.triggered.connect(self.onImagePrint) 230 231 self.actionCopyToClipboard.triggered.connect(self.onClipboardCopy) 231 self.actionToggleMenu.triggered.connect(self.onToggleMenu)232 #self.actionToggleMenu.triggered.connect(self.onToggleMenu) 232 233 233 234 def createContextMenu(self): … … 381 382 Toggle navigation menu visibility in the chart 382 383 """ 383 if self.toolbar.isVisible(): 384 self.toolbar.hide() 385 else: 386 self.toolbar.show() 384 self.toolbar.hide() 385 # Current toolbar menu is too buggy. 386 # Comment out until we support 3.x, then recheck. 387 #if self.toolbar.isVisible(): 388 # self.toolbar.hide() 389 #else: 390 # self.toolbar.show() 387 391 388 392 def offset_graph(self): -
src/sas/qtgui/Plotting/UnitTesting/Plotter2DTest.py
r863ebca r34f13a83 146 146 self.plotter.createContextMenuQuick() 147 147 actions = self.plotter.contextMenu.actions() 148 self.assertEqual(len(actions), 9)148 self.assertEqual(len(actions), 7) 149 149 150 150 # Trigger Print Image and make sure the method is called … … 158 158 159 159 # Trigger Toggle Grid and make sure the method is called 160 self.assertEqual(actions[ 6].text(), "Toggle Grid On/Off")160 self.assertEqual(actions[4].text(), "Toggle Grid On/Off") 161 161 self.plotter.ax.grid = MagicMock() 162 actions[4].trigger() 163 self.assertTrue(self.plotter.ax.grid.called) 164 165 # Trigger Change Scale and make sure the method is called 166 self.assertEqual(actions[6].text(), "Toggle Linear/Log Scale") 167 FigureCanvas.draw_idle = MagicMock() 162 168 actions[6].trigger() 163 self.assertTrue(self.plotter.ax.grid.called)164 165 # Trigger Change Scale and make sure the method is called166 self.assertEqual(actions[8].text(), "Toggle Linear/Log Scale")167 FigureCanvas.draw_idle = MagicMock()168 actions[8].trigger()169 169 self.assertTrue(FigureCanvas.draw_idle.called) 170 170 -
src/sas/qtgui/Plotting/UnitTesting/PlotterBaseTest.py
r863ebca r34f13a83 124 124 125 125 actions = self.plotter.contextMenu.actions() 126 self.assertEqual(len(actions), 6)126 self.assertEqual(len(actions), 4) 127 127 128 128 # Trigger Print Image and make sure the method is called … … 147 147 self.assertTrue(self.clipboard_called) 148 148 149 # Trigger toggle navigation bar and make sure the method is called150 self.assertEqual(actions[4].text(), "Toggle Navigation Menu")151 isShown = self.plotter.toolbar.isVisible()152 self.assertTrue(isShow)153 actions[4].trigger()154 isShown = self.plotter.toolbar.isVisible()155 self.assertFalse(isShow)156 actions[4].trigger()157 isShown = self.plotter.toolbar.isVisible()158 self.assertTrue(isShow)149 ## Trigger toggle navigation bar and make sure the method is called 150 #self.assertEqual(actions[4].text(), "Toggle Navigation Menu") 151 #isShown = self.plotter.toolbar.isVisible() 152 #self.assertTrue(isShow) 153 #actions[4].trigger() 154 #isShown = self.plotter.toolbar.isVisible() 155 #self.assertFalse(isShow) 156 #actions[4].trigger() 157 #isShown = self.plotter.toolbar.isVisible() 158 #self.assertTrue(isShow) 159 159 160 160 -
src/sas/qtgui/Plotting/UnitTesting/PlotterTest.py
r863ebca r34f13a83 103 103 self.plotter.createContextMenuQuick() 104 104 actions = self.plotter.contextMenu.actions() 105 self.assertEqual(len(actions), 9)105 self.assertEqual(len(actions), 7) 106 106 107 107 # Trigger Print Image and make sure the method is called … … 115 115 116 116 # Trigger Toggle Grid and make sure the method is called 117 self.assertEqual(actions[ 6].text(), "Toggle Grid On/Off")117 self.assertEqual(actions[4].text(), "Toggle Grid On/Off") 118 118 self.plotter.ax.grid = MagicMock() 119 actions[4].trigger() 120 self.assertTrue(self.plotter.ax.grid.called) 121 122 # Trigger Change Scale and make sure the method is called 123 self.assertEqual(actions[6].text(), "Change Scale") 124 self.plotter.properties.exec_ = MagicMock(return_value=QtWidgets.QDialog.Rejected) 119 125 actions[6].trigger() 120 self.assertTrue(self.plotter.ax.grid.called)121 122 # Trigger Change Scale and make sure the method is called123 self.assertEqual(actions[8].text(), "Change Scale")124 self.plotter.properties.exec_ = MagicMock(return_value=QtWidgets.QDialog.Rejected)125 actions[8].trigger()126 126 self.assertTrue(self.plotter.properties.exec_.called) 127 127 -
src/sas/qtgui/Utilities/GridPanel.py
r7879745 rfa762f4 18 18 ERROR_COLUMN_CAPTION = " (Err)" 19 19 IS_WIN = (sys.platform == 'win32') 20 windowClosedSignal = QtCore.pyqtSignal() 20 21 def __init__(self, parent = None, output_data=None): 21 22 … … 54 55 # Fill in the table from input data 55 56 self.setupTable(widget=self.tblParams, data=output_data) 56 #TODO: This is not what was inteded to be.57 57 if output_data is not None: 58 58 # Set a table tooltip describing the model … … 64 64 Overwrite QDialog close method to allow for custom widget close 65 65 """ 66 # Maybe we should just minimize67 self. setWindowState(QtCore.Qt.WindowMinimized)66 # notify the parent so it hides this window 67 self.windowClosedSignal.emit() 68 68 event.ignore() 69 69 … … 153 153 Create a new tab with batch fitting results 154 154 """ 155 self.addTabPage() 155 if self.has_data: 156 self.addTabPage() 156 157 # Update the new widget 157 158 # Fill in the table from input data in the last/newest page -
src/sas/qtgui/Utilities/GuiUtils.py
r20f4857 r8eea1b1 29 29 from sas.qtgui.Utilities import CustomDir 30 30 31 ## TODO: CHANGE FOR SHIPPED PATH IN RELEASE32 31 if os.path.splitext(sys.argv[0])[1].lower() != ".py": 33 32 HELP_DIRECTORY_LOCATION = "doc" -
src/sas/qtgui/Utilities/LocalConfig.py
rb764ae5 r6d87082 73 73 _nsf_logo = os.path.join(icon_path, "nsf_logo.png") 74 74 _danse_logo = os.path.join(icon_path, "danse_logo.png") 75 _inst_logo = os.path.join(icon_path, "utlogo. gif")75 _inst_logo = os.path.join(icon_path, "utlogo.png") 76 76 _nist_url = "http://www.nist.gov/" 77 77 _umd_url = "http://www.umd.edu/" -
src/sas/qtgui/Perspectives/Fitting/FittingPerspective.py
r9b9ec10 r20f4857 65 65 self.communicate.copyFitParamsSignal.connect(self.onParamCopy) 66 66 self.communicate.pasteFitParamsSignal.connect(self.onParamPaste) 67 self.communicate.copyExcelFitParamsSignal.connect(self.onExcelCopy) 68 self.communicate.copyLatexFitParamsSignal.connect(self.onLatexCopy) 69 67 70 68 71 # Perspective window not allowed to close by default … … 103 106 def onParamPaste(self): 104 107 self.currentTab.onParameterPaste() 108 109 def onExcelCopy(self): 110 self.currentTab.onParameterCopy("Excel") 111 112 def onLatexCopy(self): 113 self.currentTab.onParameterCopy("Latex") 105 114 106 115 def closeEvent(self, event):
Note: See TracChangeset
for help on using the changeset viewer.