SurfaceObject Class

The SurfaceObject class represents a surface object in the model. Currently this class only support dynamic surfaces whose geometries are determined by the parts or pours they associate to. It is not allowed to modify the geometry of a dynamic surface on Open API. The polymesh setter of this class throws .
Inheritance Hierarchy

Namespace:  Tekla.Structures.Model
Assembly:  Tekla.Structures.Model (in Tekla.Structures.Model.dll) Version: 2024.0.0+a110b435391768740483e3032720a566518c9a63
Syntax
[SerializableAttribute]
public class SurfaceObject : ModelObject

The SurfaceObject type exposes the following members.

Constructors
  NameDescription
Public methodSurfaceObject
Initializes a new instance of the SurfaceObject class.
Top
Properties
  NameDescription
Public propertyClass
Gets or sets the class of the surface object.
Public propertyCreateHoles
Gets or sets a value indicating whether CreateHoles parameter of the surface object.
Public propertyFather
Gets or sets the father object of the surface object. The father can be set only before the Insert(), otherwise exception is thrown.
Public propertyIdentifier
The identifier of the object.
(Inherited from Object.)
Public propertyIsUpToDate
Gets if the object does not have a modification which is not shared.
(Inherited from ModelObject.)
Public propertyModificationTime
Gets latest time of the object was modified or created.
(Inherited from ModelObject.)
Public propertyName
Gets or sets the name of the surface object.
Public propertyPolymesh
Gets or sets the surface geometry brep.
Public propertyType
Gets or sets the type of the surface object.
Top
Methods
  NameDescription
Public methodCompareTo
Compares Identifiers of model objects.
(Inherited from ModelObject.)
Public methodDelete
Deletes the model object from the model database.
(Overrides ModelObjectDelete.)
Public methodEquals
Check if Identifiers of model objects are same.
(Inherited from ModelObject.)
Public methodCode exampleGetAllReportProperties
Retrieves all properties for the model object in one hashtable. Type for the returned value must be checked using type casting.
(Inherited from ModelObject.)
Public methodGetAllUserProperties
Retrieves all properties for the model object in one hashtable. Type for the returned value must be checked using type casting.
(Inherited from ModelObject.)
Public methodGetChildren
Returns an enumerator of all the children model objects.
(Inherited from ModelObject.)
Public methodGetCoordinateSystem
Returns the coordinate system for the given model object.
(Inherited from ModelObject.)
Public methodGetDoubleReportProperties
Retrieves multiple double report properties for the model object. It is faster to fetch multiple properties at once.
(Inherited from ModelObject.)
Public methodGetDoubleUserProperties
Retrieves all double properties for the model object.
(Inherited from ModelObject.)
Public methodGetDynamicStringProperty
Gets a dynamic string property from the model object.
(Inherited from ModelObject.)
Public methodGetFatherComponent
Returns the father component of the model object.
(Inherited from ModelObject.)
Public methodGetHierarchicObjects
Returns an enumerator of all the connected hierarchic objects.
(Inherited from ModelObject.)
Public methodGetIntegerReportProperties
Retrieves multiple integer report properties for the model object. It is faster to fetch multiple properties at once.
(Inherited from ModelObject.)
Public methodGetIntegerUserProperties
Retrieves all integer properties for the model object.
(Inherited from ModelObject.)
Public methodGetPhase
Retrieves the phase of the model object (the phase number, the phase name, the phase comment and whether the phase is the current one or not).
(Inherited from ModelObject.)
Public methodGetReportProperty(String, Double)
Retrieves a double property of the report for the model object.
(Inherited from ModelObject.)
Public methodGetReportProperty(String, Int32)
Retrieves an integer property of the report for the model object.
(Inherited from ModelObject.)
Public methodGetReportProperty(String, String)
Retrieves a string property of the report for the model object.
(Inherited from ModelObject.)
Public methodGetStringReportProperties
Retrieves multiple string report properties for the model object. It is faster to fetch multiple properties at once.
(Inherited from ModelObject.)
Public methodGetStringUserProperties
Retrieves all string properties for the model object.
(Inherited from ModelObject.)
Public methodGetUserProperty(String, Double)
Retrieves a double property for the model object.
(Inherited from ModelObject.)
Public methodGetUserProperty(String, Int32)
Retrieves an integer property for the model object.
(Inherited from ModelObject.)
Public methodGetUserProperty(String, String)
Retrieves a string property for the model object.
(Inherited from ModelObject.)
Public methodInsert
Inserts a new model object. The geometry of the object needs to be set by using the public Polymesh function, before calling insert.
(Overrides ModelObjectInsert.)
Public methodModify
Modifies the existing model object in the model database to match the current one.
(Overrides ModelObjectModify.)
Public methodSelect
Selects the model object from the model by the identifier of this instance.
(Overrides ModelObjectSelect.)
Public methodSetDynamicStringProperty
Sets a dynamic string property for the model object.
(Inherited from ModelObject.)
Public methodSetLabel
Sets a label for an object when a new instance is created, this method must be called before Insert. The label is used in plug-ins for identifying the changed object in modification.
(Inherited from ModelObject.)
Public methodSetPhase
Sets the phase of the model object.
(Inherited from ModelObject.)
Public methodSetUserProperties
Sets multiple properties for the model object.
(Inherited from ModelObject.)
Public methodSetUserProperty(String, Double)
Sets a double property for the model object.
(Inherited from ModelObject.)
Public methodSetUserProperty(String, Int32)
Sets an integer property for the model object.
(Inherited from ModelObject.)
Public methodSetUserProperty(String, String)
Sets a string property for the model object.
(Inherited from ModelObject.)
Top
Examples
using Tekla.Structures.Model;
using Tekla.Structures.Geometry3d;
using System;
using System.Collections;
using System.Collections.Generic;

public class Example
{
   public void Example1()
   {
      Point startPointBeam = new Point(0.0, 0.0, 0.0);
      Point endPointBeam = new Point(10000.0, 0.0, 0.0);
      Beam Beam = new Beam(startPointBeam, endPointBeam)
      {
         Profile = { ProfileString = "400*400" },
         Material = { MaterialString = "Concrete_Undefined" }
      };
      Beam.Insert();

      SurfaceObject surfaceObject = new SurfaceObject();
      surfaceObject.Polymesh = CreateSingleFacePolymeshGeometry(
                      new[]
                      {
                          new Vector(    0.0, -200.0, 0.0), // 0
                          new Vector(10000.0, -200.0, 0.0), // 1
                          new Vector(10000.0,  200.0, 0.0), // 2
                          new Vector(    0.0,  200.0, 0.0)  // 3
                      });
      surfaceObject.Father = this.Beam;
      surfaceObject.Insert();
   }

   private static FacetedBrep CreateSingleFacePolymeshGeometry(Vector[] vertices)
   {
       var outerWires = new int[1][];
       outerWires[0] = new int[vertices.Length];
       for (int i = 0; i < vertices.Length; i++)
           outerWires[0][i] = i;

       var innerWires = new Dictionary<int, int[][]> { };

       return new FacetedBrep(vertices, outerWires, innerWires);
   }
}
See Also
Was this helpful?
The feedback you give here is not visible to other users. We use your comments to improve the content.
Previous
Next