class _CommandFrequencyAnalysis: def GetResources(self): return {'Pixmap': 'fem-frequency-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP("Fem_Frequency_Analysis", "Run frequency analysis with CalculiX ccx"), 'Accel': "R, F", 'ToolTip': QtCore.QT_TRANSLATE_NOOP("Fem_Frequency_Analysis", "Write .inp file and run frequency analysis with CalculiX ccx")} def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() else: print "CalculiX failed ccx finished with error {}".format(ret_code) self.fea = FemTools() self.fea.reset_all() self.fea.set_analysis_type('frequency') message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def IsActive(self): return FreeCADGui.ActiveDocument is not None and FemGui.getActiveAnalysis() is not None
class _CommandQuickAnalysis: def GetResources(self): return {'Pixmap': 'fem-quick-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Run CalculiX ccx"), 'Accel': "R, C", 'ToolTip': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Write .inp file and run CalculiX ccx")} def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() self.show_results_on_mesh() else: print "CalculiX failed ccx finished with error {}".format(ret_code) self.fea = FemTools() self.fea.reset_all() message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def show_results_on_mesh(self): #FIXME proprer mesh refreshing as per FreeCAD.FEM_dialog settings required # or confirmation that it's safe to call restore_result_dialog tp = _ResultControlTaskPanel() tp.restore_result_dialog() def IsActive(self): return FreeCADGui.ActiveDocument is not None and FemGui.getActiveAnalysis() is not None
def calculixFinished(self, exitCode): print "calculixFinished()", exitCode print self.Calculix.state() # Restore previous cwd QtCore.QDir.setCurrent(self.cwd) self.printCalculiXstdout() self.Timer.stop() self.femConsoleMessage("Calculix done!", "#00AA00") self.form.pushButton_generate.setText("Re-run Calculix") print "Loading results...." self.femConsoleMessage("Loading result sets...") self.form.label_Time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start)) fea = FemTools() fea.reset_all() frd_result_file = os.path.splitext(self.inp_file_name)[0] + '.frd' if os.path.isfile(frd_result_file): QApplication.setOverrideCursor(Qt.WaitCursor) ccxFrdReader.importFrd(frd_result_file, FemGui.getActiveAnalysis()) QApplication.restoreOverrideCursor() self.femConsoleMessage("Loading results done!", "#00AA00") else: self.femConsoleMessage("Loading results failed! Results file doesn\'t exist", "#FF0000") self.form.label_Time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start))
def calculixFinished(self, exitCode): print ("calculixFinished() {}".format(exitCode)) print (self.Calculix.state()) # Restore previous cwd QtCore.QDir.setCurrent(self.cwd) self.printCalculiXstdout() self.Timer.stop() self.femConsoleMessage("Calculix done!", "#00AA00") self.form.pb_run_ccx.setText("Re-run CalculiX") self.femConsoleMessage("Loading result sets...") self.form.l_time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start)) fea = FemTools() fea.reset_all() frd_result_file = os.path.splitext(self.inp_file_name)[0] + '.frd' if os.path.isfile(frd_result_file): QApplication.setOverrideCursor(Qt.WaitCursor) ccxFrdReader.importFrd(frd_result_file, FemGui.getActiveAnalysis()) QApplication.restoreOverrideCursor() self.femConsoleMessage("Loading results done!", "#00AA00") else: self.femConsoleMessage("Loading results failed! Results file doesn\'t exist", "#FF0000") self.form.l_time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start))
class _CommandQuickAnalysis(FemCommands): def __init__(self): super(_CommandQuickAnalysis, self).__init__() self.resources = {'Pixmap': 'fem-quick-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Run CalculiX ccx"), 'Accel': "R, C", 'ToolTip': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Write .inp file and run CalculiX ccx")} self.is_active = 'with_solver' def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() self.show_results_on_mesh() self.hide_parts_constraints_show_meshes() else: print ("CalculiX failed ccx finished with error {}".format(ret_code)) self.fea = FemTools() self.fea.reset_all() message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def show_results_on_mesh(self): #FIXME proprer mesh refreshing as per FreeCAD.FEM_dialog settings required # or confirmation that it's safe to call restore_result_dialog import _TaskPanelResultControl tp = _TaskPanelResultControl._TaskPanelResultControl() tp.restore_result_dialog()
class _CommandQuickAnalysis(FemCommands): def __init__(self): super(_CommandQuickAnalysis, self).__init__() self.resources = { 'Pixmap': 'fem-quick-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Run CalculiX ccx"), 'Accel': "R, C", 'ToolTip': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Write .inp file and run CalculiX ccx") } self.is_active = 'with_solver' def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() self.show_results_on_mesh() self.hide_parts_constraints_show_meshes() else: print("CalculiX failed ccx finished with error {}".format( ret_code)) self.fea = FemTools() self.fea.reset_all() message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def show_results_on_mesh(self): #FIXME proprer mesh refreshing as per FreeCAD.FEM_dialog settings required # or confirmation that it's safe to call restore_result_dialog #FIXME if an analysis has multiple results (frequence) the first result object found is restored import _TaskPanelResultControl tp = _TaskPanelResultControl._TaskPanelResultControl() tp.restore_result_dialog()
class _CommandQuickAnalysis: def GetResources(self): return { 'Pixmap': 'fem-quick-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Run CalculiX ccx"), 'Accel': "R, C", 'ToolTip': QtCore.QT_TRANSLATE_NOOP("Fem_Quick_Analysis", "Write .inp file and run CalculiX ccx") } def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() self.show_results_on_mesh() else: print "CalculiX failed ccx finished with error {}".format( ret_code) self.fea = FemTools() self.fea.reset_all() message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def show_results_on_mesh(self): #FIXME proprer mesh refreshing as per FreeCAD.FEM_dialog settings required # or confirmation that it's safe to call restore_result_dialog tp = _ResultControlTaskPanel() tp.restore_result_dialog() def IsActive(self): return FreeCADGui.ActiveDocument is not None and FemGui.getActiveAnalysis( ) is not None
def calculixFinished(self, exitCode): print ("calculixFinished() {}".format(exitCode)) print (self.Calculix.state()) # Restore previous cwd QtCore.QDir.setCurrent(self.cwd) self.printCalculiXstdout() self.Timer.stop() self.femConsoleMessage("CalculiX done!", "#00AA00") self.form.pb_run_ccx.setText("Re-run CalculiX") self.femConsoleMessage("Loading result sets...") self.form.l_time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start)) fea = FemTools() fea.reset_all() fea.inp_file_name = self.inp_file_name QApplication.setOverrideCursor(Qt.WaitCursor) fea.load_results() QApplication.restoreOverrideCursor() self.form.l_time.setText('Time: {0:4.1f}: '.format(time.time() - self.Start))
class _CommandFrequencyAnalysis: def GetResources(self): return { 'Pixmap': 'fem-frequency-analysis', 'MenuText': QtCore.QT_TRANSLATE_NOOP( "Fem_Frequency_Analysis", "Run frequency analysis with CalculiX ccx"), 'Accel': "R, F", 'ToolTip': QtCore.QT_TRANSLATE_NOOP( "Fem_Frequency_Analysis", "Write .inp file and run frequency analysis with CalculiX ccx") } def Activated(self): def load_results(ret_code): if ret_code == 0: self.fea.load_results() else: print "CalculiX failed ccx finished with error {}".format( ret_code) self.fea = FemTools() self.fea.reset_all() self.fea.set_analysis_type('frequency') message = self.fea.check_prerequisites() if message: QtGui.QMessageBox.critical(None, "Missing prerequisite", message) return self.fea.finished.connect(load_results) QtCore.QThreadPool.globalInstance().start(self.fea) def IsActive(self): return FreeCADGui.ActiveDocument is not None and FemGui.getActiveAnalysis( ) is not None
def Activated(self): fea = FemTools() fea.reset_all()
def Activated(self): fea = FemTools() fea.reset_all() self.hide_meshes_show_parts_constraints()