fmeobjects.FMECompositeSurface¶

FMECompositeSurface.appendPart |
appendPart(surface), |
FMECompositeSurface.boundingBox () |
This method returns the bounding box of the geometry. |
FMECompositeSurface.boundingCube () |
This method returns the bounding cube of the geometry. |
FMECompositeSurface.bounds () |
Returns the bounds of the geometry. |
FMECompositeSurface.clearMeasures () |
Remove all measures from the geometry. |
FMECompositeSurface.copyAttributesFromFeature (…) |
Copies all the attributes from the given feature to traits on this geometry, if they match the (optional) regular expression. |
FMECompositeSurface.copyNameFromGeometry (…) |
Copies the name of the ‘sourceGeometry’ onto this geometry. |
FMECompositeSurface.copyTraitsFromGeometry (…) |
Copies all the traits from the given geometry that match the (optional) regular expression. |
FMECompositeSurface.copyTraitsToFeature (…) |
Copies all the traits from this geometry to attributes on the given feature, if they match the (optional) regular expression. |
FMECompositeSurface.deleteName () |
Deletes the geometry’s name. |
FMECompositeSurface.deleteSide (front) |
This method deletes the side specified by ‘front’ and indicates whether or not it existed before being deleted. |
FMECompositeSurface.force2D () |
Reduces the geometry to 2D. |
FMECompositeSurface.force3D (newZ) |
This sets the geometry’s dimension to 3D. |
FMECompositeSurface.getAppearanceReference (front) |
This method returns the appearance reference within the Library associated with this surface. |
FMECompositeSurface.getArea () |
Area calculation. |
FMECompositeSurface.getAsWireFrame () |
Returns the wireframe of the surface as a FMEMultiCurve . |
FMECompositeSurface.getMeasureNames () |
Retrieve the names of the measures on this geometry. |
FMECompositeSurface.getName () |
This routine retrieves the ‘name’ of this geometry as a six.text_type . |
FMECompositeSurface.getPartAt |
getPartAt(index), |
FMECompositeSurface.getTrait (traitName) |
Retrieves the geometry trait value of the specified trait name. |
FMECompositeSurface.getTraitNames () |
Retrieve the names of the traits on this geometry. |
FMECompositeSurface.getTraitNullMissingAndType (…) |
This method returns a tuple of a boolean, indicating if the trait is null, a boolean, indicating if the trait is missing, and an integer representing the type of the trait. |
FMECompositeSurface.getTraitType (traitName) |
Returns the type of given trait. |
FMECompositeSurface.hasMeasures () |
Check if this geometry or any sub part of this geometry has measures. |
FMECompositeSurface.hasName () |
Returns whether or not the geometry has a name. |
FMECompositeSurface.is3D () |
Returns whether or not the geometry is 3D. |
FMECompositeSurface.isCollection () |
Check if the geometry is an aggregate or multi-part collection. |
FMECompositeSurface.isInPlane (tolerance, …) |
Works similarly to isPlanar() , but checks planarity with respect to given normal or given plane (if plane equation D is specified - see below). |
FMECompositeSurface.isOriented () |
A face with a donut area will not be oriented if the normal of any inner boundary has the same direction as the normal of the outer boundary. |
FMECompositeSurface.isPlanar (tolerance) |
Returns True if this is planar within the given tolerance, and False otherwise. |
FMECompositeSurface.measureExists (measureName) |
Returns True if the specified measure exists and False otherwise. |
FMECompositeSurface.numParts () |
This returns the number of surfaces that make up this composite surface. |
FMECompositeSurface.offset (offsetPoint) |
Offsets the surface by the coords specified by ‘offsetPoint’. |
FMECompositeSurface.orient () |
Flips the front and the back of parts of the surface as required to create a surface that is oriented. |
FMECompositeSurface.removeEndPart () |
This removes and returns the last surface of the composite surface. |
FMECompositeSurface.removeMeasure (measureName) |
Removes the measure with name ‘measureName’ if supplied, or the default measure, if there is one. |
FMECompositeSurface.removeTraits (regexp) |
This method has 4 modes: |
FMECompositeSurface.renameMeasure (…) |
Renames the measure specified by ‘oldMeasureName’ to the new name, specified by ‘newMeasureName’. |
FMECompositeSurface.reorient () |
Flips the surface such that the front and back of the surface are switched. |
FMECompositeSurface.resolvePartDefaults () |
Recursively resolves surface parts with default appearances by replacing these defaults with the inherited appearance references stored by the parent surface, if such a value exists. |
FMECompositeSurface.reverse () |
This reverses the order of the surface’s points. |
FMECompositeSurface.rotate2D (center, angle) |
Rotates this surface about the z-axis by the specified angle, in degrees. |
FMECompositeSurface.scale (xScale, yScale, zScale) |
Scale the feature by the given amounts. |
FMECompositeSurface.setAppearanceReference (…) |
This method associates an appearance within the Library with this surface. |
FMECompositeSurface.setName (name) |
Sets the geometry’s name with a six.text_type . |
FMECompositeSurface.setTrait (traitName, …) |
Sets a geometry trait with the specified value. |
FMECompositeSurface.setTraitNullWithType (…) |
This method supplies a null trait value with a type to the geometry. |
FMECompositeSurface.sideExists (front) |
This method checks whether the side specified by ‘front’ exists. |
FMECompositeSurface.simpleSurfaceIter () |
This creates a simple surface iterator. |
-
class
FMECompositeSurface
¶ Bases:
fmeobjects.FMESurface
FME Composite Surface Class
Create an instance of a Composite Surface geometry object.
init()
Default
FMECompositeSurface
constructor.Return type: FMECompositeSurface Returns: An instance of a Composite Surface geometry object. init(compositeSurface)
Create a copy of the passed in Composite Surface geometry object.
Parameters: compositeSurface (FMECompositeSurface) – The Composite Surface geometry object to create a copy of. Return type: FMECompositeSurface Returns: An instance of a Composite Surface geometry object. -
__init__
¶ Initialize self. See help(type(self)) for accurate signature.
-
appendPart
()¶ appendPart(surface),
This appends the surface to the composite surface. If
None
is passed in, nothing will be appended. All areas in the composite surface will be forced to have the same dimension. If any 3D areas exist, all 2D areas will be converted to 3D with a default Z value of 0.0.Parameters: surface (FMESurface) – The surface to be appended. Return type: None Raises: FMEException – An exception is raised if an error occurred.
-
boundingBox
()¶ This method returns the bounding box of the geometry.
Return type: tuple[tuple[float]] Returns: The bounding box of the Geometry, in the form ((minx, miny), (maxx, maxy)).
-
boundingCube
()¶ This method returns the bounding cube of the geometry.
Return type: tuple[tuple[float]] Returns: The bounding box of the Geometry, in the form ((minx, miny, minz), (maxx, maxy, maxz)).
-
bounds
()¶ Returns the bounds of the geometry.
Return type: tuple[FMEPoint] Returns: The min point and max point of the bounds. None
is returned if the geometry contains no points.
-
copyAttributesFromFeature
(sourceFeature, overwriteExisting, regexp, prefix)¶ Copies all the attributes from the given feature to traits on this geometry, if they match the (optional) regular expression.
Parameters: - sourceFeature (FMEFeature) – The feature to copy attributes from.
- overwriteExisting (bool) – Existing traits will be overwritten only if overwriteExisting is
True
. - regexp (str) – (Optional) The regular expression to match the attributes against. If regexp is not specified, then all attributes will be copied.
- prefix (str) – (Optional) The prefix is put on all the trait names as they are copied. If it is not specified, a prefix will not be added to the trait names.
Return type:
-
copyNameFromGeometry
(sourceGeometry)¶ Copies the name of the ‘sourceGeometry’ onto this geometry. If ‘sourceGeometry’s name is blank or
None
, this geometry’s name will becomeNone
.Parameters: sourceGeometry (FMEGeometry) – The geometry to copy the name from. Return type: None
-
copyTraitsFromGeometry
(sourceGeometry, overwriteExisting, regexp, prefix)¶ Copies all the traits from the given geometry that match the (optional) regular expression.
Parameters: - sourceGeometry (FMEGeometry) – The geometry to copy traits from.
- overwriteExisting (bool) – Existing traits will be overwritten only if overwriteExisting is
True
. - regexp (str) – (Optional) The regular expression to match the traits against. If regexp is not specified, then all traits will be copied.
- prefix (str) – (Optional) The prefix is put on all the trait names as they are copied. If it is not specified, a prefix will not be added to the trait names.
Return type:
-
copyTraitsToFeature
(destFeature, overwriteExisting, regexp, prefix)¶ Copies all the traits from this geometry to attributes on the given feature, if they match the (optional) regular expression.
Parameters: - destFeature (FMEFeature) – The feature to copy traits to.
- overwriteExisting (bool) – Existing attributes will be overwritten only if overwriteExisting is
True
. - regexp (str) – (Optional) The regular expression to match the traits against. If regexp is not specified, then all traits will be copied.
- prefix (str) – (Optional) The prefix is put on all the attribute names as they are copied. If it is not specified, a prefix will not be added to the attribute names.
Return type:
-
deleteName
()¶ Deletes the geometry’s name. If a name existed prior to this call then
True
is returned; otherwiseFalse
is returned.Return type: bool Returns: Returns a boolean indicating whether or not the name existed before deletion.
-
deleteSide
(front)¶ This method deletes the side specified by ‘front’ and indicates whether or not it existed before being deleted.
Parameters: front (bool) – If True
then the front side will be deleted, otherwise the back side will be deleted.Return type: bool Returns: Returns True
if the side existed before being deleted and returnsFalse
if it didn’t exist.
-
force3D
(newZ)¶ This sets the geometry’s dimension to 3D. All Z values are set to the value passed in, even if the geometry is already 3D.
Parameters: newZ (float) – The new Z value. Return type: None
-
getAppearanceReference
(front)¶ This method returns the appearance reference within the Library associated with this surface. The ‘front’ parameter controls whether this query should return the front or the back appearance reference. Both can be fetched independently. If this surface is a regular surface with no geometry instance, a
FMEException
will be thrown.Parameters: front (bool) – Boolean indicating whether the appearance reference should be retrieved for the front or back of the surface. Return type: int Returns: The unique appearance reference for this appearance. Raises: FMEException – An exception is raised if an error occurred or this surface is a regular surface with no geometry instance.
-
getAsWireFrame
()¶ Returns the wireframe of the surface as a
FMEMultiCurve
.None
is returned if a wireframe cannot be generated.Return type: FMEMultiCurve or None Returns: The wireframe of the surface as a FMEMultiCurve
.
-
getMeasureNames
()¶ Retrieve the names of the measures on this geometry.
Return type: tuple[string] Returns: Return a tuple storing the names of the measures on this geometry. This will return an empty tuple if there are no measures. For FMEAggregate
,FMEMultiSurface
, andFMECompositeSurface
, this will return the union of all measure names of all of its parts.
-
getName
()¶ This routine retrieves the ‘name’ of this geometry as a
six.text_type
. This will returnNone
if it did not have a name associated with it.Return type: six.text_type or None Returns: The geometry’s name.
-
getPartAt
()¶ getPartAt(index),
This method returns the surface at the given index.
None
is returned if the index is out of range.Parameters: index (int) – The index of the surface part to return. Return type: FMESurface or None Returns: The surface at the given index. Note: This method returns a terminal area type of the FMESurface
; i.e. one of the leaf classes in theFMESurface
inheritance graph. For example, aFMEMesh
is returned if the area truly is a Mesh.Raises: FMEException – An exception is raised if an error occurred.
-
getTrait
(traitName)¶ Retrieves the geometry trait value of the specified trait name. For Python 2.7, strings are returned as one of two possible types - system encoded strings or unicode strings, if the source trait was encoded. Null trait values will be returned as an empty string. Binary blob traits are returned as a bytearray.
None
is returned when the trait is not found on the geometry.Parameters: traitName (str) – The name of the geometry trait. Return type: bool, int, long, float, six.string_types, bytearray, bytes or None Returns: The trait value. Raises: FMEException – An exception is raised if there was a problem in retrieving the trait value.
-
getTraitNames
()¶ Retrieve the names of the traits on this geometry.
Return type: tuple[str] Returns: Return a tuple storing the names of the traits on this geometry. This will return an empty tuple if there are no traits. For all collections and containers, this will only return the names of traits on the outermost object only.
-
getTraitNullMissingAndType
(traitName)¶ This method returns a tuple of a boolean, indicating if the trait is null, a boolean, indicating if the trait is missing, and an integer representing the type of the trait. The first boolean is
True
if ‘traitName’ maps to a null trait value on the geometry. Otherwise it isFalse
. The second boolean isTrue
if ‘traitName’ maps to a no value on the geometry. Otherwise it isFalse
. If the trait is absent,FME_ATTR_UNDEFINED
is returned for the type.The possible trait types are
FME_ATTR_UNDEFINED
,FME_ATTR_BOOLEAN
,FME_ATTR_INT8
,FME_ATTR_UINT8
,FME_ATTR_INT16
,FME_ATTR_UINT16
,FME_ATTR_INT32
,FME_ATTR_UINT32
,FME_ATTR_REAL32
,FME_ATTR_REAL64
,FME_ATTR_REAL80
,FME_ATTR_STRING
,FME_ATTR_ENCODED_STRING
,FME_ATTR_INT64
,FME_ATTR_UINT64
.Parameters: traitName (str) – The trait’s name. Return type: tuple[bool, bool, int] Returns: A tuple of 2 boolean values the first indicating whether or not the value of the trait is null, the second indicating whether or not the trait is missing, and an integer representing the trait type.
-
getTraitType
(traitName)¶ Returns the type of given trait. If the trait cannot be found,
FME_ATTR_UNDEFINED
will be returned.Returns one of
FME_ATTR_UNDEFINED
,FME_ATTR_BOOLEAN
,FME_ATTR_INT8
,FME_ATTR_UINT8
,FME_ATTR_INT16
,FME_ATTR_UINT16
,FME_ATTR_INT32
,FME_ATTR_UINT32
,FME_ATTR_REAL32
,FME_ATTR_REAL64
,FME_ATTR_REAL80
,FME_ATTR_STRING
,FME_ATTR_ENCODED_STRING
,FME_ATTR_INT64
,FME_ATTR_UINT64
.Parameters: traitName (str) – The trait’s name. Return type: int Returns: The trait type.
-
hasMeasures
()¶ Check if this geometry or any sub part of this geometry has measures.
Return type: bool Returns: True
if this geometry or any sub part of this geometry has measures,False
otherwise.
-
hasName
()¶ Returns whether or not the geometry has a name.
Return type: bool Returns: Returns True
if the geometry has a name andFalse
otherwise.
-
is3D
()¶ Returns whether or not the geometry is 3D.
Return type: bool Returns: Returns True
if the geometry is 3D andFalse
otherwise. ForFMENull
, this method will always returnTrue
. ForFMEAggregate
,FMEMultiPoint
,FMEMultiArea
,FMEMultiText
andFMEMultiCurve
, this method will returnTrue
if any one of the sub-parts is 3D. If the collection is empty or all of its members are 2D, this method will returnFalse
.
-
isCollection
()¶ Check if the geometry is an aggregate or multi-part collection.
Return type: bool Returns: True
if the geometry is an aggregate or multi-part collection.
-
isInPlane
(tolerance, normalVector, valD, recalculateD)¶ Works similarly to
isPlanar()
, but checks planarity with respect to given normal or given plane (if plane equation D is specified - see below).If given normal is the zero vector, the normal used to check the planarity is computed using Newell’s method as in
isPlanar()
. valD is a reference to a value of D in the plane equation AX + BY + CZ = D. It can be used to make sure that multiple pieces lie in the same plane. If ‘recalculateD’ is set toFalse
, the passed in value of D will be used in the calculation. If ‘recalcualteD’ is set toTrue
, the passed in value is ignored and is instead automatically calculated (and returned in the second position of the returned tuple). A useful calling pattern for ensuring co-planarity is to get valD computed on the first call to the function setting ‘recalculateD’ toTrue
, and then use this value for future calls with ‘recalculateD’ toFalse
.Parameters: Return type: Returns: A tuple containing a boolean, tuple, and float representing: 1) Whether or not the surface is in plane; 2) The normal vector returned; and 3) The value ‘D’. Note: If recalculateD is
False
, the tuple returned will only contain the boolean and vector tuple (i.e. ‘valD’ is not returned).
-
isOriented
()¶ A face with a donut area will not be oriented if the normal of any inner boundary has the same direction as the normal of the outer boundary. Meshes and composite surfaces will return
False
if they have two parts that share an edge and those two parts are not consistently oriented with respect to each other. If the surface is improperly noded, the behaviour of this function is undefined.Return type: bool Returns: Returns True
if the surface is oriented,False
otherwise.
-
isPlanar
(tolerance)¶ Returns
True
if this is planar within the given tolerance, andFalse
otherwise.The planarity condition is computed by the following algorithm. The normal vector <A, B, C> is determined by the vertices of this surface using Newell’s method. For the first point (x’, y’, z’) of this surface, we compute D’ = Ax’ + By’ + Cz’. Then, this surface is planar if and only if every subsequent point (x, y, z) of this surface gives a D = Ax + By + Cz, that is within the tolerance amount of D’. That is, | D - D’ | <= tolerance.
If the specified tolerance is negative, then this method always returns
True
.Parameters: tolerance (float) – The tolerance to check against. Return type: bool Returns: Whether the surface is planar within the tolerance supplied.
-
measureExists
(measureName)¶ Returns
True
if the specified measure exists andFalse
otherwise. If the ‘measureName’ parameter is not specified then the default measure is checked.Parameters: measureName (str) – (Optional) The measure’s name. Return type: bool Returns: Boolean indicating whether or not the measure exists.
-
numParts
()¶ This returns the number of surfaces that make up this composite surface.
Return type: int Returns: The number of surfaces in composite surface.
-
offset
(offsetPoint)¶ Offsets the surface by the coords specified by ‘offsetPoint’.
Parameters: offsetPoint (FMEPoint) – The FMEPoint
to offset the surface by.Return type: None Raises: FMEException – An exception is raised if an error occurred.
-
orient
()¶ Flips the front and the back of parts of the surface as required to create a surface that is oriented. Refer to
isOriented()
for the specification of what it means to be an oriented surface. If the surface is improperly noded or non-orientable, the behaviour of this function is undefined. All measures are changed as needed, including the vertex normal measures. Note: The vertex normals are not flipped (scaled by -1).Return type: None
-
removeEndPart
()¶ This removes and returns the last surface of the composite surface. If there are no surfaces in the composite surface, it will return
None
.Return type: FMESurface or None Returns: The last surface of the composite surface. Note: This method returns a terminal surface type of the FMESurface
; i.e. one of the leaf classes in theFMESurface
inheritance graph. For example, aFMEMesh
is returned if the area truly is a mesh.Raises: FMEException – An exception is raised if an error occurred.
-
removeMeasure
(measureName)¶ Removes the measure with name ‘measureName’ if supplied, or the default measure, if there is one.
Parameters: measureName (str) – (Optional) The name of the measure to remove. Return type: None
-
removeTraits
(regexp)¶ This method has 4 modes:
- Remove all traits at the top level: regex == NULL
- Remove some traits at the top level: regex == <string>
- Remove all traits at all levels: regex ==
kFME_RecurseAll
- Remove some traits at all levels: regex ==
kFME_RecurseSome
<string>
For example, specifying regex == NULL for a multi-surface will remove all traits at the root level of the multi-surface, whereas specifying regex ==
kFME_RecurseSome
<string> will remove all traits from all levels of the multi surface that match <string>. If <string> is an illegal regular expression, no traits will be removed.Return type: None
-
renameMeasure
(oldMeasureName, newMeasureName)¶ Renames the measure specified by ‘oldMeasureName’ to the new name, specified by ‘newMeasureName’.
Parameters: Return type:
-
reorient
()¶ Flips the surface such that the front and back of the surface are switched. All measures are changed as needed, including the vertex normal measures. Note: The vertex normals are not flipped (scaled by -1). Refer to
reverse()
if the vertex normals need to be flipped. Note:FMETriangleStrip
have a method calledisFlipped()
that is to be used in conjunction with the geometry to determine which side is the front. WhenisFlipped()
returnsTrue
, the front is actually the opposite side of what the coordinates of the first triangle in the strip indicate.Return type: None
-
resolvePartDefaults
()¶ Recursively resolves surface parts with default appearances by replacing these defaults with the inherited appearance references stored by the parent surface, if such a value exists. The nearest non-default ancestor value will be used to set the default appearances on the part.
Return type: None
-
rotate2D
(center, angle)¶ Rotates this surface about the z-axis by the specified angle, in degrees. The rotation is performed relative to the center specified. A positive angle corresponds to a counter-clockwise rotation, when looking down onto the XY-plane.
Parameters: Return type: Raises: FMEException – An exception is raised if an error occurred.
-
scale
(xScale, yScale, zScale)¶ Scale the feature by the given amounts.
Parameters: Return type: Raises: FMEException – An exception is raised if an error occurred.
-
setAppearanceReference
(appearanceRef, front)¶ This method associates an appearance within the Library with this surface. This is done by passing in the unique appearance reference for this appearance. Subsequent calls to this method on the same side, will override the previous appearance used with the new appearance passed in.
An appearance reference of ‘0’ represents the default appearance. Interpretation of the default appearance is left to the consumer of this geometry. When set at this
FMESurface
level, the appearance represents the default appearance to apply when the contained surfaces use the default appearance instead of a specific appearance. Contained surfaces may be found within nested surfaces, geometry instances that reference geometries containing surfaces, or as surfaces or multi-surfaces.The second parameter controls whether this action should take place on the front of the contained surfaces or the back. Both can be set independently. The appearanceRef should be a valid reference to a definition stored in the
FMELibrary
. If the reference was not found in the library, it will still attach the reference to the instance, but will throw aFMEException
. This is an unhealthy situation as it represents a ‘dangling reference’.Parameters: Raises: FMEException – An exception is raised if an error occurred or the reference was not found in the library and a dangling reference was attached.
-
setName
(name)¶ Sets the geometry’s name with a
six.text_type
. By supplying a blank name as input, this method will act asdeleteName()
.Parameters: name (six.text_type) – The geometry’s new name. Return type: None
-
setTrait
(traitName, traitValue)¶ Sets a geometry trait with the specified value. If the geometry trait already exists, its value and type will be changed. The following type numeric mappings are used:
PyInt ==> FME_Int32
PyFloat ==> FME_Real64
PyLong ==> FME_Int64
For Python 2.7, strings can be input as one of two possible types: system encoded strings or unicode strings. Binary values are to be specified as bytearray values or bytes values for Python 3 and as bytearray values for Python 2.7.
Parameters: Return type:
-
setTraitNullWithType
(traitName, traitType)¶ This method supplies a null trait value with a type to the geometry. If a trait with the same name already exists, it is overwritten.
Trait type must be one of
FME_ATTR_UNDEFINED
,FME_ATTR_BOOLEAN
,FME_ATTR_INT8
,FME_ATTR_UINT8
,FME_ATTR_INT16
,FME_ATTR_UINT16
,FME_ATTR_INT32
,FME_ATTR_UINT32
,FME_ATTR_REAL32
,FME_ATTR_REAL64
,FME_ATTR_REAL80
,FME_ATTR_STRING
,FME_ATTR_ENCODED_STRING
,FME_ATTR_INT64
,FME_ATTR_UINT64
.Parameters: Return type:
-
sideExists
(front)¶ This method checks whether the side specified by ‘front’ exists.
Parameters: front (bool) – If ‘front’ is true then the front side will be checked otherwise the back side will be checked. Return type: bool Returns: Returns true if the side exists and false otherwise.
-
simpleSurfaceIter
()¶ This creates a simple surface iterator.
Return type: FMESimpleSurfaceIterator Returns: Returns a simple surface iterator.
-