Skip to content

T_Rhino_Geometry_Surface

Will Pearson edited this page Aug 12, 2016 · 2 revisions

Surface Class

Represents a base class that is common to most RhinoCommon surface types. A surface represents an entity that can be all visited by providing two independent parameters, usually called (u, v), or sometimes (s, t).

Inheritance Hierarchy

System.Object
  Rhino.Runtime.CommonObject
    Rhino.Geometry.GeometryBase
      Rhino.Geometry.Surface
         Namespace: Rhino.Geometry
Assembly: RhinoCommon (in RhinoCommon.dll) Version: Rhino 6.0

Syntax

C#

[SerializableAttribute]
public class Surface : GeometryBase

VB

<SerializableAttribute>
Public Class Surface
	Inherits GeometryBase

The Surface type exposes the following members.

Constructors

 

Name Description
Protected method Surface() Protected constructor for internal use.
Protected method Surface(SerializationInfo, StreamingContext) Protected constructor for internal use.
  Back to Top

Properties

 

Name Description
Public property HasBrepForm Returns true if the Brep.TryConvertBrep function will be successful for this object (Inherited from GeometryBase.)
Public property HasUserData Gets true if this class has any custom information attached to it through UserData. (Inherited from CommonObject.)
Public property IsDeformable true if object can be accurately modified with "squishy" transformations like projections, shears, and non-uniform scaling. (Inherited from GeometryBase.)
Public property IsDocumentControlled If true this object may not be modified. Any properties or functions that attempt to modify this object when it is set to "IsReadOnly" will throw a NotSupportedException. (Inherited from GeometryBase.)
Public property IsSolid Gets a values indicating whether a surface is solid.
Public property IsValid Tests an object to see if it is valid. (Inherited from CommonObject.)
Public property ObjectType Useful for switch statements that need to differentiate between basic object types like points, curves, surfaces, and so on. (Inherited from GeometryBase.)
Public property UserData List of custom information that is attached to this class. (Inherited from CommonObject.)
Public property UserDictionary Dictionary of custom information attached to this class. The dictionary is actually user data provided as an easy to use sharable set of information. (Inherited from CommonObject.)
Public property UserStringCount Gets the amount of user strings. (Inherited from GeometryBase.)
  Back to Top

Methods

 

Name Description
Public methodCode example ClosestPoint Input the parameters of the point on the surface that is closest to testPoint.
Public method ClosestSide Gets the side that is closest, in terms of 3D-distance, to a U and V parameter.
Public method ComponentIndex If this piece of geometry is a component in something larger, like a BrepEdge in a Brep, then this function returns the component index. (Inherited from GeometryBase.)
Protected method ConstructConstObject Assigns a parent object and a subobject index to this. (Inherited from CommonObject.)
Public methodStatic member CreateExtrusion Constructs a surface by extruding a curve along a vector.
Public methodStatic member CreateExtrusionToPoint Constructs a surface by extruding a curve to a point.
Public methodStatic member CreatePeriodicSurface(Surface, Int32) Constructs a periodic surface from a base surface and a direction.
Public methodStatic member CreatePeriodicSurface(Surface, Int32, Boolean) Constructs a periodic surface from a base surface and a direction.
Public methodStatic member CreateRollingBallFillet(Surface, Surface, Double, Double) Constructs a rolling ball fillet between two surfaces.
Public methodStatic member CreateRollingBallFillet(Surface, Point2d, Surface, Point2d, Double, Double) Constructs a rolling ball fillet between two surfaces.
Public methodStatic member CreateRollingBallFillet(Surface, Boolean, Surface, Boolean, Double, Double) Constructs a rolling ball fillet between two surfaces.
Public methodStatic member CreateSoftEditSurface Creates a soft edited surface from an exising surface using a smooth field of influence.
Public methodCode example CurvatureAt Computes the curvature at the given UV coordinate.
Public method Degree Returns the maximum algebraic degree of any span (or a good estimate if curve spans are not algebraic).
Public method Dispose() Actively reclaims unmanaged resources that this instance uses. (Inherited from CommonObject.)
Protected method Dispose(Boolean) For derived class implementers. This method is called with argument true when class user calls Dispose(), while with argument false when the Garbage Collector invokes the finalizer, or Finalize() method.

You must reclaim all used unmanaged resources in both cases, and can use this chance to call Dispose on disposable fields if the argument is true.

Also, you must call the base virtual method within your overriding method.

(Inherited from CommonObject.)

Public method Domain Gets the domain in a direction.
Public method Duplicate Constructs a deep (full) copy of this object. (Inherited from GeometryBase.)
Public method DuplicateShallow Constructs a light copy of this object. By "light", it is meant that the same underlying data is used until something is done to attempt to change it. For example, you could have a shallow copy of a very heavy mesh object and the same underlying data will be used when doing things like inspecting the number of faces on the mesh. If you modify the location of one of the mesh vertices, the shallow copy will create a full duplicate of the underlying mesh data and the shallow copy will become a deep copy. (Inherited from GeometryBase.)
Public method EnsurePrivateCopy If you want to keep a copy of this class around by holding onto it in a variable after a command completes, call EnsurePrivateCopy to make sure that this class is not tied to the document. You can call this function as many times as you want. (Inherited from CommonObject.)
Public method Equals Determines whether the specified object is equal to the current object. (Inherited from Object.)
Public method Evaluate Evaluates a surface mathematically.
Public method Extend Extends an untrimmed surface along one edge.
Protected method Finalize() Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.)
Protected method Finalize() Passively reclaims unmanaged resources when the class user did not explicitly call Dispose(). (Inherited from CommonObject.)
Public method Fit Fits a new surface through an existing surface.
Public methodCode example FrameAt Computes the orient plane on a surface given a U and V parameter. This is the simple evaluation call with no error handling.
Public methodCode example GetBoundingBox(Boolean) Boundingbox solver. Gets the world axis aligned boundingbox for the geometry. (Inherited from GeometryBase.)
Public methodCode example GetBoundingBox(Plane) Aligned Boundingbox solver. Gets the plane aligned boundingbox. (Inherited from GeometryBase.)
Public method GetBoundingBox(Transform) Aligned Boundingbox solver. Gets the world axis aligned boundingbox for the transformed geometry. (Inherited from GeometryBase.)
Public method GetBoundingBox(Plane, Box) Aligned Boundingbox solver. Gets the plane aligned boundingbox. (Inherited from GeometryBase.)
Public method GetHashCode Serves as the default hash function. (Inherited from Object.)
Public method GetNextDiscontinuity Searches for a derivative, tangent, or curvature discontinuity.
Public method GetObjectData Populates a System.Runtime.Serialization.SerializationInfo with the data needed to serialize the target object. (Inherited from CommonObject.)
Public method GetSpanVector Gets array of span "knots".
Public methodCode example GetSurfaceSize Gets an estimate of the size of the rectangle that would be created if the 3d surface where flattened into a rectangle.
Public method GetType Gets the Type of the current instance. (Inherited from Object.)
Public method GetUserString Gets user string from this geometry. (Inherited from GeometryBase.)
Public method GetUserStrings Gets a copy of all (user key string, user value string) pairs attached to this geometry. (Inherited from GeometryBase.)
Public method HasNurbsForm Is there a NURBS surface representation of this surface.
Public method InterpolatedCurveOnSurface Constructs an interpolated curve on a surface, using 3D points.
Public method InterpolatedCurveOnSurfaceUV Constructs an interpolated curve on a surface, using 2D surface points.
Public method IsAtSeam Tests if a surface parameter value is at a seam.
Public method IsAtSingularity Tests if a surface parameter value is at a singularity.
Public method IsClosed Gets a value indicating if the surface is closed in a direction.
Public method IsCone() Determines if the surface is a portion of a cone within RhinoMath.ZeroTolerance.
Public method IsCone(Double) Determines if the surface is a portion of a cone within a given tolerance.
Public method IsContinuous Tests continuity at a surface parameter value.
Public method IsCylinder() Determines if the surface is a portion of a cylinder within RhinoMath.ZeroTolerance.
Public method IsCylinder(Double) Determines if the surface is a portion of a cylinder within a given tolerance.
Public method IsIsoparametric(BoundingBox) Determines if a 2d bounding box is iso-parameteric in the parameter space of this surface.
Public method IsIsoparametric(Curve) Determines if a 2d curve is iso-parameteric in the parameter space of this surface.
Public method IsIsoparametric(Curve, Interval) Determines if a 2D curve is iso-parameteric in the parameter space of this surface.
Public methodCode example IsoCurve Gets isoparametric curve.
Public method IsPeriodic Gets a value indicating if thr surface is periodic in a direction (default is false).
Public methodCode example IsPlanar() Tests a surface to see if it is planar to zero tolerance.
Public method IsPlanar(Double) Tests a surface to see if it is planar to a given tolerance.
Public method IsSingular true if surface side is collapsed to a point.
Public method IsSphere() Determines if the surface is a portion of a sphere within RhinoMath.ZeroTolerance.
Public method IsSphere(Double) Determines if the surface is a portion of a sphere within a given tolerance.
Public method IsTorus() Determines if the surface is a portion of a torus within RhinoMath.ZeroTolerance.
Public method IsTorus(Double) Determines if the surface is a portion of a torus within a given tolerance.
Public method IsValidWithLog Determines if an object is valid. Also provides a report on errors if this object happens not to be valid. (Inherited from CommonObject.)
Public method MakeDeformable If possible, converts the object into a form that can be accurately modified with "squishy" transformations like projections, shears, an non-uniform scaling. (Inherited from GeometryBase.)
Protected method MemberwiseClone Creates a shallow copy of the current Object. (Inherited from Object.)
Public method MemoryEstimate Computes an estimate of the number of bytes that this object is using in memory. (Inherited from GeometryBase.)
Protected method NonConstOperation For derived classes implementers. Defines the necessary implementation to free the instance from being const.

(Inherited from CommonObject.)

Public methodCode example NormalAt Computes the surface normal at a point. This is the simple evaluation call - it does not support error handling.
Public method Offset Constructs a new surface which is offset from the current surface.
Protected method OnSwitchToNonConst Is called when a non-const operation occurs. (Inherited from GeometryBase.)
Public method PointAt Evaluates a point at a given parameter.
Public method Pullback(Curve, Double) Pulls a 3d curve back to the surface's parameter space.
Public method Pullback(Curve, Double, Interval) Pulls a 3d curve back to the surface's parameter space.
Public method Pushup(Curve, Double) Computes a 3d curve that is the composite of a 2d curve and the surface map.
Public method Pushup(Curve, Double, Interval) Computes a 3d curve that is the composite of a 2d curve and the surface map.
Public method Rebuild Rebuilds an existing surface to a given degree and point count.
Public method Reverse(Int32) Reverses parameterization Domain changes from [a,b] to [-b,-a]
Public method Reverse(Int32, Boolean) Same as Reverse, but if inPlace is set to true this Surface is modified instead of a new copy being created.
Public method Rotate Rotates the object about the specified axis. A positive rotation angle results in a counter-clockwise rotation about the axis (right hand rule). (Inherited from GeometryBase.)
Public method Scale Scales the object by the specified factor. The scale is centered at the origin. (Inherited from GeometryBase.)
Public method SetDomain Sets the domain in a direction.
Public method SetUserString Attach a user string (key,value combination) to this geometry. (Inherited from GeometryBase.)
Public method ShortPath Constructs a geodesic between 2 points, used by ShortPath command in Rhino.
Public method SpanCount Gets number of smooth nonempty spans in the parameter direction.
Public method Split Splits (divides) the surface into two parts at the specified parameter
Public method ToBrep Converts the surface into a Brep.
Public method ToNurbsSurface() Gets a NURBS surface representation of this surface. Default tolerance of 0.0 is used.
Public method ToNurbsSurface(Double, Int32) Gets a NURBS surface representation of this surface.
Public method ToString Returns a string that represents the current object. (Inherited from Object.)
Public method Transform Transforms the geometry. If the input Transform has a SimilarityType of OrientationReversing, you may want to consider flipping the transformed geometry after calling this function when it makes sense. For example, you may want to call Flip() on a Brep after transforming it. (Inherited from GeometryBase.)
Public method Translate(Vector3d) Translates the object along the specified vector. (Inherited from GeometryBase.)
Public method Translate(Double, Double, Double) Translates the object along the specified vector. (Inherited from GeometryBase.)
Public method Transpose() Transposes surface parameterization (swap U and V)
Public method Transpose(Boolean) Transposes surface parameterization (swap U and V)
Public method Trim Constructs a sub-surface that covers the specified UV trimming domain.
Public method TryGetCone(Cone) Tests a surface to see if it is a portion of a cone within RhinoMath.ZeroTolerance and return the cone.
Public method TryGetCone(Cone, Double) Tests a surface to see if it is a portion of a cone and returns the cone.
Public method TryGetCylinder(Cylinder) Tests a surface to see if it is a portion of a cylinder within RhinoMath.ZeroTolerance and return the cylinder.
Public method TryGetCylinder(Cylinder, Double) Tests a surface to see if it is a portion of a cylinder and return the cylinder.
Public method TryGetPlane(Plane) Tests a surface for planarity and return the plane.
Public methodCode example TryGetPlane(Plane, Double) Tests a surface for planarity and return the plane.
Public method TryGetSphere(Sphere) Test a surface to see if it is a portion of a sphere and return the sphere.
Public method TryGetSphere(Sphere, Double) Test a surface to see if it is a portion of a sphere and return the sphere.
Public method TryGetTorus(Torus) Tests a surface to see if it is a portion of a torus within RhinoMath.ZeroTolerance and returns the torus.
Public method TryGetTorus(Torus, Double) Tests a surface to see if it is a portion of a torus and returns the torus.
  Back to Top

Version Information

Supported in: 6.0.16224.21491, 5D58w

See Also

Reference

Rhino.Geometry Namespace

Inheritance HierarchySystem.Object
  Rhino.Runtime.CommonObject
    Rhino.Geometry.GeometryBase
      Rhino.Geometry.Surface
        Rhino.Geometry.Extrusion
        Rhino.Geometry.NurbsSurface
        Rhino.Geometry.PlaneSurface
        Rhino.Geometry.RevSurface
        Rhino.Geometry.SumSurface
        Rhino.Geometry.SurfaceProxy

Clone this wiki locally