Fem: Use own base class for Python objects - fixes #15408
This commit is contained in:
committed by
Chris Hennes
parent
8dbf1e7910
commit
d50506fb4d
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
# /***************************************************************************
|
||||
# ***************************************************************************
|
||||
# * Copyright (c) 2024 Mario Passaglia <mpassaglia[at]cbc.uba.ar> *
|
||||
# * *
|
||||
# * This file is part of FreeCAD. *
|
||||
@@ -19,7 +19,7 @@
|
||||
# * License along with FreeCAD. If not, see *
|
||||
# * <https://www.gnu.org/licenses/>. *
|
||||
# * *
|
||||
# **************************************************************************
|
||||
# ***************************************************************************
|
||||
|
||||
__title__ = "FreeCAD FEM base element object"
|
||||
__author__ = "Mario Passaglia"
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
# /***************************************************************************
|
||||
# ***************************************************************************
|
||||
# * Copyright (c) 2024 Mario Passaglia <mpassaglia[at]cbc.uba.ar> *
|
||||
# * *
|
||||
# * This file is part of FreeCAD. *
|
||||
@@ -19,7 +19,7 @@
|
||||
# * License along with FreeCAD. If not, see *
|
||||
# * <https://www.gnu.org/licenses/>. *
|
||||
# * *
|
||||
# **************************************************************************
|
||||
# ***************************************************************************
|
||||
|
||||
__title__ = "FreeCAD FEM base element object"
|
||||
__author__ = "Mario Passaglia"
|
||||
|
||||
@@ -31,10 +31,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief element fluid 1D object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femelement
|
||||
|
||||
|
||||
class ElementFluid1D(base_fempythonobject.BaseFemPythonObject):
|
||||
class ElementFluid1D(base_femelement.BaseFemElement):
|
||||
"""
|
||||
The element_fluid1D object
|
||||
"""
|
||||
@@ -63,11 +63,6 @@ class ElementFluid1D(base_fempythonobject.BaseFemPythonObject):
|
||||
def __init__(self, obj):
|
||||
super().__init__(obj)
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList", "References", "FluidSection", "List of fluid section shapes"
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyEnumeration", "SectionType", "FluidSection", "select fluid section type"
|
||||
)
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief element geometry 1D object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femelement
|
||||
|
||||
|
||||
class ElementGeometry1D(base_fempythonobject.BaseFemPythonObject):
|
||||
class ElementGeometry1D(base_femelement.BaseFemElement):
|
||||
"""
|
||||
The ElementGeometry1D object
|
||||
"""
|
||||
@@ -88,9 +88,5 @@ class ElementGeometry1D(base_fempythonobject.BaseFemPythonObject):
|
||||
)
|
||||
obj.setPropertyStatus("SectionType", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList", "References", "BeamSection", "List of beam section shapes"
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
obj.SectionType = ElementGeometry1D.known_beam_types
|
||||
obj.SectionType = "Rectangular"
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief element geometry 2D object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femelement
|
||||
|
||||
|
||||
class ElementGeometry2D(base_fempythonobject.BaseFemPythonObject):
|
||||
class ElementGeometry2D(base_femelement.BaseFemElement):
|
||||
"""
|
||||
The ElementGeometry2D object
|
||||
"""
|
||||
@@ -49,11 +49,3 @@ class ElementGeometry2D(base_fempythonobject.BaseFemPythonObject):
|
||||
"set thickness of the shell elements",
|
||||
)
|
||||
obj.setPropertyStatus("Thickness", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList",
|
||||
"References",
|
||||
"ShellThickness",
|
||||
"List of shell thickness shapes",
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief element rotation 1D object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femelement
|
||||
|
||||
|
||||
class ElementRotation1D(base_fempythonobject.BaseFemPythonObject):
|
||||
class ElementRotation1D(base_femelement.BaseFemElement):
|
||||
"""
|
||||
The ElementRotation1D object
|
||||
"""
|
||||
@@ -46,8 +46,3 @@ class ElementRotation1D(base_fempythonobject.BaseFemPythonObject):
|
||||
"App::PropertyAngle", "Rotation", "BeamRotation", "Set the rotation of beam elements"
|
||||
)
|
||||
obj.setPropertyStatus("Rotation", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList", "References", "BeamRotation", "List of beam rotation shapes"
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief mesh boundary layer object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femmeshelement
|
||||
|
||||
|
||||
class MeshBoundaryLayer(base_fempythonobject.BaseFemPythonObject):
|
||||
class MeshBoundaryLayer(base_femmeshelement.BaseFemMeshElement):
|
||||
"""
|
||||
The MeshBoundaryLayer object
|
||||
"""
|
||||
@@ -68,11 +68,3 @@ class MeshBoundaryLayer(base_fempythonobject.BaseFemPythonObject):
|
||||
)
|
||||
obj.setPropertyStatus("GrowthRate", "LockDynamic")
|
||||
obj.GrowthRate = 1.5
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList",
|
||||
"References",
|
||||
"MeshBoundaryLayerShapes",
|
||||
"List of FEM mesh region shapes",
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief mesh group object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femmeshelement
|
||||
|
||||
|
||||
class MeshGroup(base_fempythonobject.BaseFemPythonObject):
|
||||
class MeshGroup(base_femmeshelement.BaseFemMeshElement):
|
||||
"""
|
||||
The MeshGroup object
|
||||
"""
|
||||
@@ -49,11 +49,3 @@ class MeshGroup(base_fempythonobject.BaseFemPythonObject):
|
||||
"The identifier used for export (True: Label, False: Name)",
|
||||
)
|
||||
obj.setPropertyStatus("UseLabel", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList",
|
||||
"References",
|
||||
"MeshGroupShapes",
|
||||
"List of FEM mesh group shapes",
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
@@ -29,10 +29,10 @@ __url__ = "https://www.freecad.org"
|
||||
# \ingroup FEM
|
||||
# \brief mesh region object
|
||||
|
||||
from . import base_fempythonobject
|
||||
from . import base_femmeshelement
|
||||
|
||||
|
||||
class MeshRegion(base_fempythonobject.BaseFemPythonObject):
|
||||
class MeshRegion(base_femmeshelement.BaseFemMeshElement):
|
||||
"""
|
||||
The FemMeshRegion object
|
||||
"""
|
||||
@@ -49,11 +49,3 @@ class MeshRegion(base_fempythonobject.BaseFemPythonObject):
|
||||
"set characteristic length of FEM elements for this refinement",
|
||||
)
|
||||
obj.setPropertyStatus("CharacteristicLength", "LockDynamic")
|
||||
|
||||
obj.addProperty(
|
||||
"App::PropertyLinkSubList",
|
||||
"References",
|
||||
"MeshRegionShapes",
|
||||
"List of FEM mesh refinement shapes",
|
||||
)
|
||||
obj.setPropertyStatus("References", "LockDynamic")
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
# /***************************************************************************
|
||||
# ***************************************************************************
|
||||
# * Copyright (c) 2024 Mario Passaglia <mpassaglia[at]cbc.uba.ar> *
|
||||
# * *
|
||||
# * This file is part of FreeCAD. *
|
||||
@@ -19,7 +19,7 @@
|
||||
# * License along with FreeCAD. If not, see *
|
||||
# * <https://www.gnu.org/licenses/>. *
|
||||
# * *
|
||||
# **************************************************************************
|
||||
# ***************************************************************************
|
||||
|
||||
__title__ = "FreeCAD FEM base element ViewProvider"
|
||||
__author__ = "Mario Passaglia"
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
# /***************************************************************************
|
||||
# ***************************************************************************
|
||||
# * Copyright (c) 2024 Mario Passaglia <mpassaglia[at]cbc.uba.ar> *
|
||||
# * *
|
||||
# * This file is part of FreeCAD. *
|
||||
@@ -19,7 +19,7 @@
|
||||
# * License along with FreeCAD. If not, see *
|
||||
# * <https://www.gnu.org/licenses/>. *
|
||||
# * *
|
||||
# **************************************************************************
|
||||
# ***************************************************************************
|
||||
|
||||
__title__ = "FreeCAD FEM base materlia ViewProvider"
|
||||
__author__ = "Mario Passaglia"
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
# /***************************************************************************
|
||||
# ***************************************************************************
|
||||
# * Copyright (c) 2024 Mario Passaglia <mpassaglia[at]cbc.uba.ar> *
|
||||
# * *
|
||||
# * This file is part of FreeCAD. *
|
||||
@@ -19,7 +19,7 @@
|
||||
# * License along with FreeCAD. If not, see *
|
||||
# * <https://www.gnu.org/licenses/>. *
|
||||
# * *
|
||||
# **************************************************************************
|
||||
# ***************************************************************************
|
||||
|
||||
__title__ = "FreeCAD FEM base mesh element ViewProvider"
|
||||
__author__ = "Mario Passaglia"
|
||||
|
||||
@@ -32,15 +32,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for element fluid 1D object
|
||||
|
||||
from femtaskpanels import task_element_fluid1D
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femelement
|
||||
|
||||
|
||||
class VPElementFluid1D(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPElementFluid1D(view_base_femelement.VPBaseFemElement):
|
||||
"""
|
||||
A View Provider for the ElementFluid1D object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_element_fluid1D._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_element_fluid1D._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for element geometry 1D object
|
||||
|
||||
from femtaskpanels import task_element_geometry1D
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femelement
|
||||
|
||||
|
||||
class VPElementGeometry1D(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPElementGeometry1D(view_base_femelement.VPBaseFemElement):
|
||||
"""
|
||||
A View Provider for the ElementGeometry1D object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_element_geometry1D._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_element_geometry1D._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for element geometry 2D object
|
||||
|
||||
from femtaskpanels import task_element_geometry2D
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femelement
|
||||
|
||||
|
||||
class VPElementGeometry2D(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPElementGeometry2D(view_base_femelement.VPBaseFemElement):
|
||||
"""
|
||||
A View Provider for the ElementGeometry2D object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_element_geometry2D._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_element_geometry2D._TaskPanel)
|
||||
|
||||
@@ -34,10 +34,10 @@ __url__ = "https://www.freecad.org"
|
||||
import FreeCAD
|
||||
|
||||
from femtaskpanels import task_material_common
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femmaterial
|
||||
|
||||
|
||||
class VPMaterialCommon(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPMaterialCommon(view_base_femmaterial.VPBaseFemMaterial):
|
||||
"""
|
||||
A View Provider for the MaterialCommon object
|
||||
"""
|
||||
@@ -55,6 +55,4 @@ class VPMaterialCommon(view_base_femconstraint.VPBaseFemConstraint):
|
||||
return ""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_material_common._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_material_common._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for reinforced material object
|
||||
|
||||
from femtaskpanels import task_material_reinforced
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femmaterial
|
||||
|
||||
|
||||
class VPMaterialReinforced(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPMaterialReinforced(view_base_femmaterial.VPBaseFemMaterial):
|
||||
"""
|
||||
A View Provider for the MaterialReinforced object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_material_reinforced._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_material_reinforced._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for mesh boundary object
|
||||
|
||||
from femtaskpanels import task_mesh_boundarylayer
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femmeshelement
|
||||
|
||||
|
||||
class VPMeshBoundaryLayer(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPMeshBoundaryLayer(view_base_femmeshelement.VPBaseFemMeshElement):
|
||||
"""
|
||||
A View Provider for the MeshBoundaryLayer object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_mesh_boundarylayer._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_mesh_boundarylayer._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for mesh group object
|
||||
|
||||
from femtaskpanels import task_mesh_group
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femmeshelement
|
||||
|
||||
|
||||
class VPMeshGroup(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPMeshGroup(view_base_femmeshelement.VPBaseFemMeshElement):
|
||||
"""
|
||||
A View Provider for the MeshGroup object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_mesh_group._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_mesh_group._TaskPanel)
|
||||
|
||||
@@ -30,15 +30,13 @@ __url__ = "https://www.freecad.org"
|
||||
# \brief view provider for mesh region object
|
||||
|
||||
from femtaskpanels import task_mesh_region
|
||||
from . import view_base_femconstraint
|
||||
from . import view_base_femmeshelement
|
||||
|
||||
|
||||
class VPMeshRegion(view_base_femconstraint.VPBaseFemConstraint):
|
||||
class VPMeshRegion(view_base_femmeshelement.VPBaseFemMeshElement):
|
||||
"""
|
||||
A View Provider for the FemMeshRegion object
|
||||
"""
|
||||
|
||||
def setEdit(self, vobj, mode=0):
|
||||
view_base_femconstraint.VPBaseFemConstraint.setEdit(
|
||||
self, vobj, mode, task_mesh_region._TaskPanel
|
||||
)
|
||||
super().setEdit(vobj, mode, task_mesh_region._TaskPanel)
|
||||
|
||||
Reference in New Issue
Block a user