Public Member Functions | |
def | applyShape (self, obj, shape, placement, allowinvalid=False, allownosolid=False) |
def | clone (self, obj) |
def | computeAreas (self, obj) |
def | execute (self, obj) |
def | getExtrusionData (self, obj) |
def | getHosts (self, obj) |
def | getMovableChildren (self, obj) |
def | getParentHeight (self, obj) |
def | getSiblings (self, obj) |
def | hideSubobjects (self, obj, prop) |
def | isIdentity (self, placement) |
def | isStandardCase (self, obj) |
def | onBeforeChange (self, obj, prop) |
def | onChanged (self, obj, prop) |
def | onDocumentRestored (self, obj) |
def | processSubShapes (self, obj, base, placement=None) |
def | rebase (self, shape, hint=None) |
def | setProperties (self, obj) |
def | spread (self, obj, shape, placement=None) |
Public Member Functions inherited from ArchIFC.IfcProduct | |
def | getIfcSchema (self) |
Public Member Functions inherited from ArchIFC.IfcRoot | |
def | addIfcAttribute (self, obj, attribute) |
def | addIfcAttributes (self, ifcTypeSchema, obj) |
def | addIfcAttributeValueExpressions (self, obj, attribute) |
def | getCanonicalisedIfcTypes (self) |
def | getIfcAttributeSchema (self, ifcTypeSchema, name) |
def | getIfcTypeSchema (self, IfcType) |
def | getObjIfcComplexAttribute (self, obj, attributeName) |
def | migrateDeprecatedAttributes (self, obj) |
def | purgeUnusedIfcAttributesFromPropertiesList (self, ifcTypeSchema, obj) |
def | setObjIfcAttributeValue (self, obj, attributeName, value) |
def | setObjIfcComplexAttributeValue (self, obj, attributeName, value) |
def | setupIfcAttributes (self, obj) |
def | setupIfcComplexAttributes (self, obj) |
Public Attributes | |
flatarea | |
oldPlacement | |
Subvolume | |
Type | |
Detailed Description
The Arch Component object. Acts as a base for all other Arch objects, such as Arch walls and Arch structures. Its properties and behaviours are common to all Arch objects. You can learn more about Arch Components, and the purpose of Arch Components here: https://wiki.freecadweb.org/Arch_Component Parameters ---------- obj: <App::FeaturePython> The object to turn into an Arch Component
Member Function Documentation
◆ applyShape()
def ArchComponent.Component.applyShape | ( | self, | |
obj, | |||
shape, | |||
placement, | |||
allowinvalid = False , |
|||
allownosolid = False |
|||
) |
Check the given shape, then assign it to the object. Check if the shape is valid, isn't null, and if it has volume. Remove redundant edges from the shape. Spread the shape to the "Axis" with method .spread(). Set the object's Shape and Placement to the values given, if successful. Finally, run .computeAreas() method, to calculate the horizontal and vertical area of the shape. Parameters ---------- obj: <App::FeaturePython> The component object. shape: <Part.Shape> The shape to check and apply to the object. placement: <Base.Placement> The placement to apply to the object. allowinvalid: bool, optional Whether to allow invalid shapes, or to throw an error. allownosolid: bool, optional Whether to allow non-solid shapes, or to throw an error.
References ArchComponent.Component.computeAreas(), Base::PlacementPy.isIdentity(), Base::RotationPy.isIdentity(), Base::Placement.isIdentity(), Base::Rotation.isIdentity(), ArchComponent.Component.isIdentity(), and ArchComponent.Component.spread().
Referenced by ArchTruss.Truss.execute().
◆ clone()
def ArchComponent.Component.clone | ( | self, | |
obj | |||
) |
If the object is a clone, copy the shape. If the object is a clone according to the "CloneOf" property, copy the object's shape and several properties relating to shape, such as "Length" and "Thickness". Only perform the copy if this object and the object it's a clone of are of the same type, or if the object has the type "Component" or "BuildingPart". Parameters ---------- obj: <App::FeaturePython> The component object. Returns ------- bool True if the copy occurs, False if otherwise.
Referenced by ArchPanel.CommandPanelSheet.Activated(), ArchTruss.Truss.execute(), ArchComponent.Component.execute(), ArchCurtainWall.CurtainWall.execute(), and Mod.PartDesign.WizardShaft.SegmentFunction.SegmentFunction.integrated().
◆ computeAreas()
def ArchComponent.Component.computeAreas | ( | self, | |
obj | |||
) |
Compute the area properties of the object's shape. Compute the vertical area, horizontal area, and perimeter length of the object's shape. The vertical area is the surface area of the faces perpendicular to the ground. The horizontal area is the area of the shape, when projected onto a hyperplane across the XY axes, IE: the area when viewed from a bird's eye view. The perimeter length is the length of the outside edges of this bird's eye view. Assign these values to the object's "VerticalArea", "HorizontalArea", and "PerimeterLength" properties. Parameters ---------- obj: <App::FeaturePython> The component object.
Referenced by ArchComponent.Component.applyShape(), ArchSite.Compass.buildCoordinates(), and ArchRoof.makeRoof().
◆ execute()
def ArchComponent.Component.execute | ( | self, | |
obj | |||
) |
Method run when the object is recomputed. If the object is a clone, just copy the shape it's cloned from. Process subshapes of the object to add additions, and subtract subtractions from the object's shape. Parameters ---------- obj: <App::FeaturePython> The component object.
Reimplemented in ArchCurtainWall.CurtainWall, and ArchTruss.Truss.
References PathTests.TestPathHelix.TestPathHelix.clone, zipios::BasicEntry.clone(), zipios::DirectoryCollection.clone(), zipios::ZipFile.clone(), zipios::ZipLocalEntry.clone(), zipios::CollectionCollection.clone(), zipios::FileCollection.clone(), zipios::ZipCDirEntry.clone(), zipios::FileEntry.clone(), Gui::ViewProviderIndex.clone(), ArchComponent.Component.clone(), ArchComponent.Component.processSubShapes(), ArchComponent.Component.spread(), Gui::ViewProviderDocumentObjectPy.Type, Gui::DocumentPy.Type, Base::BaseClassPy.Type, App::DocumentObjectGroupPy.Type, App::DocumentObjectPy.Type, App::PartPy.Type, App::OriginGroupExtensionPy.Type, Base::BoundBoxPy.Type, App::DocumentPy.Type, App::GroupExtensionPy.Type, App::GeoFeaturePy.Type, App::ExtensionContainerPy.Type, Base::CoordinateSystemPy.Type, App::ExtensionPy.Type, App::GeoFeatureGroupExtensionPy.Type, Base::MatrixPy.Type, Base::PersistencePy.Type, App::DocumentObjectExtensionPy.Type, App::MaterialPy.Type, Base::PlacementPy.Type, Base::QuantityPy.Type, Gui::WorkbenchPy.Type, Gui::ViewProviderPy.Type, App::PropertyContainerPy.Type, Base::RotationPy.Type, Gui::SelectionObjectPy.Type, Gui::PythonWorkbenchPy.Type, Base::UnitPy.Type, Base::VectorPy.Type, Base::AxisPy.Type, Data::ComplexGeoDataPy.Type, Gui::LinkViewPy.Type, Gui::AxisOriginPy.Type, App::LinkBaseExtensionPy.Type, Gui::ViewProviderLinkPy.Type, Base::TypePy.Type, App::PropertyData::PropertySpec.Type, App::Part.Type, App::FeaturePythonPyT< FeaturePyT >.Type, Gui::SelectionChanges.Type, ArchComponent.Component.Type, Base::PyObjectBase.Type, ArchAxis._Axis.Type, ArchBuilding._Building.Type, ArchBuildingPart.BuildingPart.Type, ArchAxis._AxisSystem.Type, and ArchAxis.ArchGrid.Type.
Referenced by draftobjects.facebinder.Facebinder.addSubobjects(), PathScripts.PathDressupDogbone.ObjectDressup.boneStateList(), ArchSite.Compass.buildCoordinates(), PathScripts.PathDressupHoldingTags.ObjectTagDressup.generateTags(), ArchPanel.PanelCut.getWires(), ArchSchedule.CommandArchSchedule.IsActive(), Mod.PartDesign.Scripts.Spring.MySpring.onChanged(), Mod.PartDesign.Scripts.Epitrochoid.Epitrochoid.onChanged(), Mod.PartDesign.Scripts.Parallelepiped.Parallelepiped.onChanged(), Mod.PartDesign.Scripts.DistanceBolt.DistanceBolt.onChanged(), Mod.PartDesign.Scripts.Parallelepiped.BoxCylinder.onChanged(), PathScripts.PathStock.StockFromBase.onChanged(), PathScripts.PathStock.StockCreateBox.onChanged(), PathScripts.PathStock.StockCreateCylinder.onChanged(), FeaturePython.DistanceBolt.onChanged(), draftobjects.draftlink.DraftLink.onDocumentRestored(), and draftobjects.patharray.PathArray.onDocumentRestored().
◆ getExtrusionData()
def ArchComponent.Component.getExtrusionData | ( | self, | |
obj | |||
) |
Get the object's extrusion data. Recursively scrape the Bases of the object, until a Base that is derived from a <Part::Extrusion> is found. From there, copy the extrusion to the (0,0,0) origin. With this copy, get the <Part.Face> the shape was originally extruded from, the <Base.Vector> of the extrusion, and the <Base.Placement> needed to move the copy back to its original location/orientation. Return this data as a tuple. If an object derived from a <Part::Multifuse> is encountered, return this data as a tuple containing lists. The lists will contain the same data as above, from each of the objects within the multifuse. Parameters ---------- obj: <App::FeaturePython> The component object. Returns ------- tuple Tuple containing: 1) The <Part.Face> the object was extruded from. 2) The <Base.Vector> of the extrusion. 3) The <Base.Placement> of the extrusion.
References ArchCommands.getExtrusionData(), Base::PlacementPy.isIdentity(), Base::RotationPy.isIdentity(), Base::Placement.isIdentity(), Base::Rotation.isIdentity(), ArchComponent.Component.isIdentity(), and ArchComponent.Component.rebase().
Referenced by ArchWall.areSameWallTypes(), and ArchStructure.placeAlongEdge().
◆ getHosts()
def ArchComponent.Component.getHosts | ( | self, | |
obj | |||
) |
Return the objects that have this one as host, that is, objects with a "Host" property pointing at this object, or a "Hosts" property containing this one. Returns ------- list of <Arch._Structure> The Arch Structures hosting this component.
◆ getMovableChildren()
def ArchComponent.Component.getMovableChildren | ( | self, | |
obj | |||
) |
Find the component's children set to move with their host. In this case, children refer to Additions, Subtractions, and objects linked to this object that refer to it as a host in the "Host" or "Hosts" properties. Objects are set to move with their host via the MoveWithHost property. Parameters ---------- obj: <App::FeaturePython> The component object. Returns ------- list of <App::FeaturePython> List of child objects set to move with their host.
Referenced by ArchComponent.Component.onChanged().
◆ getParentHeight()
def ArchComponent.Component.getParentHeight | ( | self, | |
obj | |||
) |
Get a height value from hosts. Recursively crawl hosts until a Floor or BuildingPart is found, then return the value of its Height property. Parameters --------- obj: <App::FeaturePython> The component object. Returns ------- <App::PropertyLength> The Height value of the found Floor or BuildingPart.
References ArchComponent.Component.getParentHeight().
Referenced by ArchComponent.Component.getParentHeight().
◆ getSiblings()
def ArchComponent.Component.getSiblings | ( | self, | |
obj | |||
) |
Find objects that have the same Base object, and type. Look to base object, and find other objects that are based off this base object. If these objects are the same type, return them. Parameters ---------- obj: <App::FeaturePython> The component object. Returns ------- list of <App::FeaturePython> List of objects that have the same Base and type as this component.
◆ hideSubobjects()
def ArchComponent.Component.hideSubobjects | ( | self, | |
obj, | |||
prop | |||
) |
Hides Additions and Subtractions of this Component when that list changes. Intended to be used in conjunction with the .onChanged() method, to access the property that has changed. When an object loses or gains an Addition, this method hides all Additions. When it gains or loses a Subtraction, this method hides all Subtractions. Does not effect objects of type Window, or clones of Windows. Parameters ---------- obj: <App::FeaturePython> The component object. prop: string The name of the property that has changed.
◆ isIdentity()
def ArchComponent.Component.isIdentity | ( | self, | |
placement | |||
) |
Check if a placement is *almost* zero. Check if a <Base.Placement>'s displacement from (0,0,0) is almost zero, and if the angle of its rotation about its axis is almost zero. Parameters ---------- placement: <Base.Placement> The placement to examine. Returns ------- bool Returns true if angle and displacement are almost zero, false it otherwise.
Referenced by ArchComponent.Component.applyShape(), ArchComponent.Component.getExtrusionData(), and ArchComponent.Component.processSubShapes().
◆ isStandardCase()
def ArchComponent.Component.isStandardCase | ( | self, | |
obj | |||
) |
Determine if the component is a standard case of its IFC type. Not all IFC types have a standard case. If an object is a standard case or not varies between the different types. Each type has its own rules to define what is a standard case. Rotated objects, or objects with Additions or Subtractions are not standard cases. All objects whose IfcType is suffixed with the string " Sandard Case" are automatically a standard case. Parameters ---------- obj: <App::FeaturePython> The component object. Returns ------- bool Whether the object is a standard case or not.
◆ onBeforeChange()
def ArchComponent.Component.onBeforeChange | ( | self, | |
obj, | |||
prop | |||
) |
Method called before the object has a property changed. Specifically, this method is called before the value changes. If "Placement" has changed, record the old placement, so that .onChanged() can compare between the old and new placement, and move its children accordingly. Parameters ---------- obj: <App::FeaturePython> The component object. prop: string The name of the property that has changed.
◆ onChanged()
def ArchComponent.Component.onChanged | ( | self, | |
obj, | |||
prop | |||
) |
Method called when the object has a property changed. If "Placement" has changed, move any children components that have been set to move with their host, such that they stay in the same location to this component. Also call ArchIFC.IfcProduct.onChanged(). Parameters ---------- obj: <App::FeaturePython> The component object. prop: string The name of the property that has changed.
Reimplemented from ArchIFC.IfcRoot.
Reimplemented in ArchCurtainWall.CurtainWall, and ArchTruss.Truss.
References ArchComponent.Component.getMovableChildren(), ArchComponent.Component.oldPlacement, ArchBuildingPart.BuildingPart.oldPlacement, ArchIFC.IfcRoot.onChanged(), and DraftVecUtils.tup().
Referenced by ArchWall.areSameWallTypes(), draftviewproviders.view_base.ViewProviderDraft.attach(), ArchSite.Compass.buildCoordinates(), ArchEquipment.createMeshView(), draftobjects.wire.Wire.execute(), ArchAxis.CommandArchGrid.IsActive(), ArchTruss.Truss.onChanged(), ArchCurtainWall.CurtainWall.onChanged(), ArchStructure.placeAlongEdge(), ArchWindow.recolorize(), ArchSpace.removeSpaceBoundaries(), draftviewproviders.view_wpproxy.ViewProviderWorkingPlaneProxy.updateData(), draftviewproviders.view_label.ViewProviderLabel.updateData(), DraftLayer.ViewProviderLayer.updateData(), ArchPanel.ViewProviderPanelCut.updateData(), and ArchPanel.ViewProviderPanelSheet.updateData().
◆ onDocumentRestored()
def ArchComponent.Component.onDocumentRestored | ( | self, | |
obj | |||
) |
Method run when the document is restored. Re-add the Arch component properties. Parameters ---------- obj: <App::FeaturePython> The component object.
Reimplemented in ArchCurtainWall.CurtainWall, and ArchTruss.Truss.
Referenced by ArchPanel.CommandPanelSheet.Activated(), ArchWall.areSameWallTypes(), ArchEquipment.createMeshView(), ArchFrame.makeFrame(), ArchPipe.makePipeConnector(), ArchStairs.makeRailing(), ArchRebar.makeRebar(), ArchRoof.makeRoof(), ArchTruss.Truss.onDocumentRestored(), ArchCurtainWall.CurtainWall.onDocumentRestored(), ArchStructure.placeAlongEdge(), ArchWindow.recolorize(), and ArchSpace.removeSpaceBoundaries().
◆ processSubShapes()
def ArchComponent.Component.processSubShapes | ( | self, | |
obj, | |||
base, | |||
placement = None |
|||
) |
Add Additions and Subtractions to a base shape. If Additions exist, fuse them to the base shape. If no base is provided, just fuse other additions to the first addition. If Subtractions exist, cut them from the base shape. Roofs and Windows are treated uniquely, as they define their own Shape to subtract from parent shapes using their .getSubVolume() methods. TODO determine what the purpose of the placement argument is. Parameters ---------- obj: <App::FeaturePython> The component object. base: <Part.Shape>, optional The base shape to add Additions and Subtractions to. placement: <Base.Placement>, optional Prior to adding or subtracting subshapes, the <Base.Placement> of the subshapes are multiplied by the inverse of this parameter. Returns ------- <Part.Shape> The base shape, with the additions and subtractions performed.
References Base::PlacementPy.isIdentity(), Base::RotationPy.isIdentity(), Base::Placement.isIdentity(), Base::Rotation.isIdentity(), ArchComponent.Component.isIdentity(), and ArchWall.mergeShapes().
Referenced by ArchPanel.CommandPanelSheet.Activated(), ArchStructure.StructSelectionObserver.addSelection(), ArchTruss.Truss.execute(), and ArchComponent.Component.execute().
◆ rebase()
def ArchComponent.Component.rebase | ( | self, | |
shape, | |||
hint = None |
|||
) |
Copy a shape to the (0,0,0) origin. Create a copy of a shape, such that its center of mass is in the (0,0,0) origin. TODO Determine the way the shape is rotated by this method. Return the copy of the shape, and the <Base.Placement> needed to move the copy back to its original location/orientation. Parameters ---------- shape: <Part.Shape> The shape to copy. hint: <Base.Vector>, optional If the angle between the normal vector of the shape, and the hint vector is greater than 90 degrees, the normal will be reversed before being rotated.
Referenced by ArchComponent.Component.getExtrusionData(), and exportIFC.getRepresentation().
◆ setProperties()
def ArchComponent.Component.setProperties | ( | self, | |
obj | |||
) |
Give the component its component specific properties, such as material. You can learn more about properties here: https://wiki.freecadweb.org/property
Reimplemented from ArchIFC.IfcRoot.
Reimplemented in ArchCurtainWall.CurtainWall, and ArchTruss.Truss.
References ArchIFC.IfcRoot.setProperties().
Referenced by ArchPanel.CommandPanelSheet.Activated(), ArchSite.Compass.buildCoordinates(), ArchSchedule.CommandArchSchedule.IsActive(), ArchAxis.CommandArchGrid.IsActive(), DraftLayer.Layer.onDocumentRestored(), ArchTruss.Truss.onDocumentRestored(), ArchCurtainWall.CurtainWall.onDocumentRestored(), ArchPanel.PanelView.onDocumentRestored(), ArchPanel.PanelCut.onDocumentRestored(), ArchPanel.ViewProviderPanelCut.onDocumentRestored(), ArchPanel.PanelSheet.onDocumentRestored(), and ArchPanel.ViewProviderPanelSheet.onDocumentRestored().
◆ spread()
def ArchComponent.Component.spread | ( | self, | |
obj, | |||
shape, | |||
placement = None |
|||
) |
Copy the object to its Axis's points. If the object has the "Axis" property assigned, create a copy of the shape for each point on the object assigned as the "Axis". Translate each of these copies equal to the displacement of the points from the (0,0,0) origin. If the object's "Axis" is unassigned, return the original shape unchanged. Parameters ---------- obj: <App::FeaturePython> The component object. shape: <Part.Shape> The shape to copy. placement: Does nothing. Returns ------- <Part.Shape> The shape, either spread to the axis points, or unchanged.
Referenced by ArchComponent.Component.applyShape(), and ArchComponent.Component.execute().
Member Data Documentation
◆ flatarea
ArchComponent.Component.flatarea |
Referenced by ArchSite.Compass.buildCoordinates().
◆ oldPlacement
ArchComponent.Component.oldPlacement |
Referenced by ArchComponent.Component.onChanged().
◆ Subvolume
ArchComponent.Component.Subvolume |
◆ Type
ArchComponent.Component.Type |
Referenced by ArchPanel.CommandPanelSheet.Activated(), ArchStructure.StructSelectionObserver.addSelection(), ArchSite.Compass.buildCoordinates(), ArchComponent.Component.execute(), DraftLayer.LayerContainer.execute(), ArchSchedule.CommandArchSchedule.IsActive(), ArchAxis.CommandArchGrid.IsActive(), draftobjects.draft_annotation.DraftAnnotation.onDocumentRestored(), ArchReference.ArchReference.setProperties(), and DraftLayer.Layer.setProperties().
The documentation for this class was generated from the following file:
- src/Mod/Arch/ArchComponent.py