ArcGIS Pro 3.1 API Reference Guide
ArcGIS.Core.Geometry Namespace / IGeometryEngine Interface / ConstructMultipatchExtrudeToZ Method
The base geometry.
The Z-value of the top.
Example

In This Topic
    ConstructMultipatchExtrudeToZ Method (IGeometryEngine)
    In This Topic
    Creates a multipatch from the input polygon or polyline.
    Syntax
    Multipatch ConstructMultipatchExtrudeToZ( 
       Multipart multipart,
       double toZ
    )
    Function ConstructMultipatchExtrudeToZ( _
       ByVal multipart As Multipart, _
       ByVal toZ As Double _
    ) As Multipatch

    Parameters

    multipart
    The base geometry.
    toZ
    The Z-value of the top.

    Return Value

    Returns the multipatch.
    Exceptions
    ExceptionDescription
    Geometry is null or empty.
    The geometry is not Z-Aware.
    Remarks
    Creates a multipatch from a base geometry by extruding the base geometry along the Z-axis to a given absolute z-plane. The base Z-values of the geometry are preserved and the top z-values are uniformly equal to the input z-value. The resulting extrusion is always parallel to the xy-plane on the top and parallel at the base if and only if the base geometry is parallel to the xy-plane.
    Example
    Construct Multipatch via Extrusion of Polygon or Polyline
    // build a polygon
    string json = "{\"hasZ\":true,\"rings\":[[[0,0,0],[0,1,0],[1,1,0],[1,0,0],[0,0,0]]],\"spatialReference\":{\"wkid\":4326}}";
    Polygon polygon = PolygonBuilderEx.FromJson(json);
    
    // extrude the polygon by an offset to create a multipatch
    Multipatch multipatch = GeometryEngine.Instance.ConstructMultipatchExtrude(polygon, 2);
    
    // a different polygon
    json = "{\"hasZ\":true,\"rings\":[[[0,0,1],[0,1,2],[1,1,3],[1,0,4],[0,0,1]]],\"spatialReference\":{\"wkid\":4326}}";
    polygon = PolygonBuilderEx.FromJson(json);
    
    // extrude between z values to create a multipatch
    multipatch = GeometryEngine.Instance.ConstructMultipatchExtrudeFromToZ(polygon, -10, 20);
    
    // extrude along the axis defined by the coordinate to create a multipatch
    Coordinate3D coord = new Coordinate3D(10, 18, -10);
    multipatch = GeometryEngine.Instance.ConstructMultipatchExtrudeAlongVector3D(polygon, coord);
    
    // build a polyline
    json = "{\"hasZ\":true,\"paths\":[[[400,800,1000],[800,1400,1500],[1200,800,2000],[1800,1800,2500],[2200,800,3000]]],\"spatialReference\":{\"wkid\":3857}}";
    Polyline polyline = PolylineBuilderEx.FromJson(json);
    
    // extrude to a specific z value to create a multipatch
    multipatch = GeometryEngine.Instance.ConstructMultipatchExtrudeToZ(polyline, 500);
    
    Coordinate3D fromCoord = new Coordinate3D(50, 50, -500);
    Coordinate3D toCoord = new Coordinate3D(200, 50, 1000);
    
    // extrude between two coordinates to create a multipatch
    multipatch = GeometryEngine.Instance.ConstructMultipatchExtrudeAlongLine(polyline, fromCoord, toCoord);
    
    Requirements

    Target Platforms: Windows 11, Windows 10

    ArcGIS Pro version: 3.0 or higher.
    See Also