xml-multi-solid
The xml-multi-solid geometry builder builds an aggregate geometry made up solely of solid geometries. This builder does not require any data parameters, and will construct the multi solid geometry from existing solid geometries. Thus, before the xml-multi-solid geometry builder is deactivated, other geometry builders should have been activated, passing their constructed solids to the xml-multi-solid geometry builder.
Each of the solids passed to the xml-multi-solid geometry builder should be either simple or composite solids. The accepted solids do not have a restraint on their spatial relationship - they may be disjoint, overlapping, touching, or completely disconnected.
builder type: composite - accepts solid geometries
geometry constructed: multi solids
data parameters:
The following demote-incomplete-geometry and allow-empty-composite data parameters change how the geometry is handled in error conditions. If both of the data parameters are set to false, whenever the geometry builder receives no solids to create a multi solid from, it will raise an error and terminate the translation.
Data Name |
Value | Required/Optional |
keep-as-multi |
Setting this optional parameter to "false" directs the builder to return a single solid rather than a multi-solid geometry when only one solid geometry is received. Range: false | true Default: true |
Optional |
demote-incomplete-geometry |
This data parameter determines if incomplete geometry should be demoted instead of producing an error. If set to true, whenever the geometry builder receives no solids to create a multi solid from, the multi solid will be downgraded to a null geometry. Range: true|false Default: false |
Optional |
allow-empty-composite |
This boolean parameter determines if incomplete geometry should be left incomplete instead of producing an error. If set to true, whenever the geometry builder receives no solids to create a multi solid from, the multi solid will be left empty and returned. Range: true|false Default: false |
Optional |
coordinate-system |
Specifies the coordinate system name. If the expression sequence for the coordinate-system evaluates to the empty string, then the coordinate system for the feature being built will not be set. Range: String |
Optional |
name |
Specifies the geometry’s name. Range: String |
Optional |
Example: Building a multi solid
multisolid.xml
<?xml version="1.0"?> <multisolid> <simplesolid> <compositesurface> <simplesurface> <area> 0.0,0.0,0.0 0.0,1.0,0.0 1.0,0.0,0.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 0.0,0.0,0.0 1.0,0.0,0.0 1.0,1.0,1.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 0.0,0.0,0.0 1.0,1.0,1.0 0.0,1.0,0.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 1.0,0.0,0.0 0.0,1.0,0.0 1.0,1.0,1.0 1.0,0.0,0.0 </area> </simplesurface> </compositesurface> </simplesolid> <simplesolid> <compositesurface> <simplesurface> <area> 0.0,0.0,0.0 0.0,-1.0,0.0 -1.0,0.0,0.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 0.0,0.0,0.0 -1.0,0.0,0.0 -1.0,-1.0,-1.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 0.0,0.0,0.0 -1.0,-1.0,-1.0 0.0,-1.0,0.0 0.0,0.0,0.0 </area> </simplesurface> <simplesurface> <area> 1.0,0.0,0.0 0.0,-1.0,0.0 -1.0,-1.0,-1.0 -1.0,0.0,0.0 </area> </simplesurface> </compositesurface> </simplesolid> </multisolid>
multisolid.xmp
<?xml version="1.0"?> <xfMap> <feature-map> <mapping match="multisolid"> <feature-type> <literal expr="multisolid" /> </feature-type> <geometry activate="xml-multi-solid" /> </mapping> </feature-map> <feature-content-map> <mapping match="simplesolid"> <geometry activate="xml-enclosed-surface" /> </mapping> <mapping match="simplesurface"> <geometry activate="xml-face" /> </mapping> <mapping match="area"> <geometry activate="xml-area"> <data name="data-string"> <extract expr="." /> </data> </geometry> </mapping> </feature-content-map> </xfMap>