BuildingOperator Class
Generates 3D buildings from building footprint polygons.
NuGet/Assembly: Carmenta.Engine.5.16.2.nupkg (in the CEOperators assembly)
Syntax
public class BuildingOperator : UnaryOperator
Remarks
Each generated building contains four different meshes. One first floor mesh for the first floor, one middle floors mesh for all middle floors, one top floor mesh for the top floor or attic and a couple of roof meshes. Each mesh can have a separate map (e.g. texture). Usually the first floor mesh is textured with a texture with windows and a door. The middle floors mesh is usually textured with a tiled texture with windows and therefore it will look like several floors.
If the building contour is of rectangular type (has four points) a gable ("V-shaped") roof is created; if it has a more complex shape a flat roof is created.
Use a VisualizationOperator with MeshVisualizer to visualize the meshes. There is an integer attribute set on all meshes called "value" that describes which type of mesh it is. Use this attribute to determine which material/texture should be used.
![]() |
One very effective visualization trick if you have high resolution aerial photo is to separate the roof meshes after the BuildingOperator and let the roof meshes via a FunnelOperator pass along with the ground meshes into the GeoTextureMapOperator and thus be textured with the geographic ground texture.
![]() |
![]() |
If the building data does not contain any information about house and floor types and total height of building then use an AttributeOperator to randomize different values.
If the building data is not already ground relative then use an ElevationOperator to lift the building data to the height of the ground.
Inheritance Hierarchy
System.Object (not available in C#)
EngineObject
Operator
UnaryOperator
BuildingOperator
Platforms
Windows, Linux, Android
BuildingOperator Members
The BuildingOperator type has the following members.
Constructors
Name | Description |
---|---|
BuildingOperator | Initializes a new instance of the BuildingOperator class. |
Properties
Name | Description |
---|---|
Description | Gets or sets a short description of the operator. Inherited from Operator |
DisplayName | Gets or sets a display name for the operator. Inherited from Operator |
FirstFloorHeight | Gets or sets the height of the first floor. |
FirstFloorValue | Gets or sets the value of the attribute named "value", set on the first floor mesh. |
Input | Gets or sets the input operator, from which this operator reads features. Inherited from UnaryOperator |
IsDisposed | Gets a value that tells whether the current BuildingOperator has been disposed. Inherited from EngineObject |
IsoMetadataDocument | Gets or sets the path to an ISO 19139 metadata document for the operator. Inherited from Operator |
MiddleFloorsValue | Gets or sets the value of the attribute named "value", set on the middle floor mesh. |
Name | Gets or sets the name of the operator. Inherited from Operator |
NativeHandle | Gets the native Carmenta Engine kernel object the current BuildingOperator represents. Inherited from EngineObject |
RoofHeight | Gets or sets the height of a gable roof. |
RoofOffset | Gets or sets an offset in Z applied to the roof mesh. |
RoofValue | Gets or sets the value of the attribute named "value", set on the roof mesh. |
TopFloorHeight | Gets or sets the height of the top floor. |
TopFloorValue | Gets or sets the value of the attribute named "value", set on the top floor mesh. |
TotalHeight | Gets or sets the total height of the all floors including the roof height. |
IUserProperties.UserProperties | Gets the AttributeSet that contains the user properties. Inherited from IUserProperties |
Methods
Name | Description |
---|---|
Clone | Creates a copy of an object. Inherited from EngineObject |
Dispose | Releases the reference to the native Carmenta Engine kernel instance the EngineObject represents. Inherited from EngineObject |
Equals | Determines whether this instance is equal to another. Inherited from EngineObject |
FindChildObject | Overloaded. Finds the child object with the specified name. Inherited from Operator |
FlushCache | Marks the layer as flushed which will release cached resources during the next update. Inherited from Operator |
GetChildObjects | Overloaded. Gets the child objects of the current object. Inherited from Operator |
GetFeatures | Overloaded. Gets features from the operator chain. Inherited from Operator |
GetLocalizedDescription | Gets a localized version of the operator description in a specific language. Inherited from Operator |
GetLocalizedDisplayName | Gets a localized version of the operator display name in a specific language. Inherited from Operator |
GetLocalizedIsoMetadataDocument | Gets the path to an ISO 19139 metadata document for a specific language. Inherited from Operator |
GetRasterFeature | Overloaded. Gets raster features from the operator chain and merges them into a single raster. Inherited from Operator |
HasLocalizedDescription | Checks if a localized version of the operator description is available in a specific language. Inherited from Operator |
HasLocalizedDisplayName | Checks if a localized version of the operator display name is available in a specific language. Inherited from Operator |
HasLocalizedIsoMetadataDocument | Checks if an ISO 19139 metadata document is available for a specific language. Inherited from Operator |
SetLocalizedDescription | Sets a operator description in a specific language. Inherited from Operator |
SetLocalizedDisplayName | Sets a operator display name in a specific language. Inherited from Operator |
SetLocalizedIsoMetadataDocument | Sets the path to an ISO 19139 metadata document for the operator, for a specific language. Inherited from Operator |