diff --git a/src/Mod/Fem/TaskPanelFemMaterial.ui b/src/Mod/Fem/TaskPanelFemMaterial.ui index 516c5362c..6db6b83dc 100755 --- a/src/Mod/Fem/TaskPanelFemMaterial.ui +++ b/src/Mod/Fem/TaskPanelFemMaterial.ui @@ -137,24 +137,14 @@ QFormLayout::AllNonFixedFieldsGrow - + - Density + Density - - - - save as name - - - - - - - + @@ -576,6 +566,13 @@ External material resources + + + + save customed material + + + diff --git a/src/Mod/Fem/_TaskPanelFemMaterial.py b/src/Mod/Fem/_TaskPanelFemMaterial.py index 76de8660f..313addb29 100644 --- a/src/Mod/Fem/_TaskPanelFemMaterial.py +++ b/src/Mod/Fem/_TaskPanelFemMaterial.py @@ -30,6 +30,8 @@ __url__ = "http://www.freecadweb.org" import FreeCAD import FreeCADGui from PySide import QtGui +from PySide.QtGui import QFileDialog +from PySide.QtGui import QMessageBox from PySide import QtCore import Units @@ -51,8 +53,8 @@ class _TaskPanelFemMaterial: self.references_shape_type = None self.form = FreeCADGui.PySideUic.loadUi(FreeCAD.getHomePath() + "Mod/Fem/TaskPanelFemMaterial.ui") - QtCore.QObject.connect(self.form.pushButton_MatWeb, QtCore.SIGNAL("clicked()"), self.goMatWeb) - QtCore.QObject.connect(self.form.pushButton_saveas, QtCore.SIGNAL("clicked()"), self.saveas_material) + QtCore.QObject.connect(self.form.pushButton_MatWeb, QtCore.SIGNAL("clicked()"), self.goto_MatWeb) + QtCore.QObject.connect(self.form.pushButton_saveas, QtCore.SIGNAL("clicked()"), self.export_material) QtCore.QObject.connect(self.form.cb_materials, QtCore.SIGNAL("activated(int)"), self.choose_material) QtCore.QObject.connect(self.form.pushButton_Reference, QtCore.SIGNAL("clicked()"), self.add_references) QtCore.QObject.connect(self.form.rb_standard, QtCore.SIGNAL("toggled(bool)"), self.choose_selection_mode_standard) @@ -154,7 +156,7 @@ class _TaskPanelFemMaterial: return False return True - def goMatWeb(self): + def goto_MatWeb(self): import webbrowser webbrowser.open("http://matweb.com") @@ -353,6 +355,7 @@ class _TaskPanelFemMaterial: self.form.cb_materials.addItem(QtGui.QIcon(":/icons/help-browser.svg"), material_name, material_name) self.materials[material_name] = material + ######################## material import and export ################### def import_materials(self): self.materials = {} self.pathList = [] @@ -388,7 +391,7 @@ class _TaskPanelFemMaterial: use_mat_from_config_dir = self.fem_prefs.GetBool("UseMaterialsFromConfigDir", True) if use_mat_from_config_dir: - user_mat_dirname = FreeCAD.getUserAppDataDir() + "Materials" + user_mat_dirname = FreeCAD.getUserAppDataDir() + "FluidMaterial" self.add_mat_dir(user_mat_dirname, ":/icons/preferences-general.svg") use_mat_from_custom_dir = self.fem_prefs.GetBool("UseMaterialsFromCustomDir", True) @@ -413,10 +416,71 @@ class _TaskPanelFemMaterial: for mat in material_name_list: self.form.cb_materials.addItem(QtGui.QIcon(icon), mat[0], mat[1]) - def saveas_material(self): - import Material - mat_file_extension = ".FCMat" - # overwritinig warning, save to customed dir, material name check + def export_FCMat(self, fileName, matDict): + """ + Write a material dictionary to a FCMat file, a version without group support, with Python3 + + """ + try: + import ConfigParser as configparser + except: + import configparser # Python 3 + import string + Config = configparser.ConfigParser() + Config.optionxform = str # disable conversion all uppercase leter in key into lower case + + # ignore creating group, just fill all into group 'FCMat' + grp = 'FCMat' + if not Config.has_section(grp): + Config.add_section(grp) + for x in matDict.keys(): + Config.set(grp,x,matDict[x]) + + Preamble = "# This is a FreeCAD material-card file\n\n" + # Writing our configuration file to 'example.cfg' + with open(fileName, 'wb') as configfile: + configfile.write(Preamble) + Config.write(configfile) + + def export_material(self): + import os + if self.obj.Category == 'Fluid': + MaterialDir = 'FluidMaterial' + else: + MaterialDir = 'Material' + _UseMaterialsFromCustomDir = self.fem_prefs.GetBool("UseMaterialsFromCustomDir", True) + _dir =self.fem_prefs.GetString("CustomMaterialsDir", "") + if _UseMaterialsFromCustomDir and _dir != "" and os.path.isdir(_dir): + TargetDir = self.fem_prefs.GetString("CustomMaterialsDir", "") + elif self.fem_prefs.GetBool("UseMaterialsFromConfigDir", True): + TargetDir = FreeCAD.getUserAppDataDir() + os.path.sep + MaterialDir # $HOME/.FreeCAD + else: + FreeCAD.Console.PrintMessage("Customed material saving directory is not setup in Fem preference") + if not os.path.exists(TargetDir): + os.mkdir(TargetDir) + + saveName, Filter = QFileDialog.getSaveFileName(None, "Save a Material property file", TargetDir, "*.FCMat") + if not saveName == "": + print(saveName) + knownMaterials = [self.form.cb_materials.itemText(i) for i in range(self.form.cb_materials.count())] + material_name = os.path.basename(saveName[:-len('.FCMat')]) + if material_name not in knownMaterials: + self.export_FCMat(saveName, self.obj.Material) + FreeCAD.Console.PrintMessage("Sucessfully save the Material property file: "+ saveName + "\n") + else: + self.export_FCMat(saveName, self.obj.Material) + FreeCAD.Console.PrintMessage("Sucessfully overwritren the Material property file: "+ saveName + "\n") + """ + msgBox = QMessageBox() + msgBox.setText("FcMat file name {} has existed in {} or system folder, overwriting?\n".format(saveName, TargetDir)) + msgBox.addButton(QMessageBox.Yes) + msgBox.addButton(QMessageBox.No) + msgBox.setDefaultButton(QMessageBox.No) + ret = msgBox.exec_() + if ret == QMessageBox.Yes: + self.export_FCMat(saveName, self.obj.Material) + FreeCAD.Console.PrintMessage("Sucessfully overwritren the Material property file: "+ saveName + "\n") + """ ###################geometry reference selection ################# def references_list_right_clicked(self, QPos): diff --git a/src/Mod/Material/FluidMaterial/None.FCMat b/src/Mod/Material/FluidMaterial/None.FCMat index 175136a87..41b44668b 100644 --- a/src/Mod/Material/FluidMaterial/None.FCMat +++ b/src/Mod/Material/FluidMaterial/None.FCMat @@ -5,7 +5,7 @@ Description = None Density = 0 kg/m^3 DynamicViscosity = 0 kg/m/s KinematicViscosity = 0 m^2/s -VolumetricExpansionCoefficient = 0 m/m/K +VolumetricThermalExpansionCoefficient = 0 m/m/K SpecificHeat = 0 J/kg/K ThermalConductivity = 0 W/m/K diff --git a/src/Mod/Material/FluidMaterial/Water.FCMat b/src/Mod/Material/FluidMaterial/Water.FCMat index 141279687..7a80eb8e1 100644 --- a/src/Mod/Material/FluidMaterial/Water.FCMat +++ b/src/Mod/Material/FluidMaterial/Water.FCMat @@ -7,7 +7,7 @@ Density = 998 kg/m^3 DynamicViscosity = 1.003e-3 kg/m/s KinematicViscosity = 1.005 m^2/s -VolumetricExpansionCoefficient = 2.07e-4 m/m/K +VolumetricThermalExpansionCoefficient = 2.07e-4 m/m/K SpecificHeat = 4.182 J/kg/K ThermalConductivity = 0.591 W/m/K