ViewState3d Class

Defines the state of a view of 3d models.

@see ViewState Parameters

Extends

Extended by

Methods

Name Description
constructor(props: ViewDefinition3dProps, iModel: IModelConnection, categories: CategorySelectorState, displayStyle: DisplayStyle3dState): ViewState3d    
alignToGlobe(target: Point3d, transition?: boolean): ViewStatus For a geoLocated project, align the view with the global ellipsoid by rotating  
allow3dManipulations(): boolean Returns true if ViewTools are allowed to operate in three dimensions on this view.  
applyPose(val: ViewPose): this See applyPose.  
attachToViewport(args: Viewport): void See attachToViewport.  
calcLensAngle(): Angle Calculate the lens angle formed by the current delta and focus distance  
cartographicToRoot(cartographic: Cartographic, result?: Point3d): undefined | Point3d Convert a cartographic coordinate to a point in spatial coordinates.  
cartographicToRootFromGcs(cartographic: Cartographic, result?: Point3d): Promise<undefined | Point3d> Convert a cartographic coordinate to a point in spatial coordinates using the GCS reprojection.  
cartographicToRootUsingGcs(cartographic: Cartographic[]): Promise<undefined | Point3d[]> Convert cartographic coordinates to spatial coordinates using the GCS reprojection.  
centerEyePoint(backDistance?: number): void Place the eyepoint of the camera so it is aligned with the center of the view.  
centerFocusDistance(): void Center the focus distance of the camera halfway between the front plane and the back plane, keeping the eyepoint,  
detachFromViewport(): void See detachFromViewport.  
getBackDistance(): number Get the distance from the eyePoint to the back plane for this view.  
getCartographicHeight(point: Readonly<WritableXYAndZ>): undefined | number    
getDisplayStyle3d(): DisplayStyle3dState The style that controls how the contents of the view are displayed.  
getEarthFocalPoint(): undefined | Point3d If the background map is displayed, return the point on the globe in directly front of the eye (or in center of view if camera off)  
getExtents(): Vector3d Get the extents of this view in CoordSystem.World coordinates.  
getEyeCartographicHeight(): undefined | number    
getEyeOrOrthographicViewPoint(): Point3d Obtain an "eye" point for this view.  
getEyePoint(): Point3d Get the current location of the eyePoint for camera in this view.  
getFocusDistance(): number Get the distance from the eyePoint to the focus plane for this view.  
getFrontDistance(): number Get the distance from the eyePoint to the front plane for this view.  
getGroundElevation(): number Returns the ground elevation taken from the environment added with the global z position of this imodel.  
getGroundExtents(vp?: Viewport): Range3d Return the ground extents, which will originate either from the viewport frustum or the extents of the imodel.  
getLensAngle(): Angle Get the lens angle for this view.  
getOrigin(): Point3d Get the origin of this view in CoordSystem.World coordinates.  
getRotation(): Matrix3d Get the 3x3 ortho-normal Matrix3d for this view.  
getTargetPoint(result?: Point3d): Point3d Get the target point of the view.  
globalViewTransition(): number A value representing the degree to which a view is viewing the globe as opposed to a specific location  
is3d(): this is ViewState3d See is3d.  
isEyePointAbove(elevation: number): boolean    
isEyePointGlobalView(eyePoint: Readonly<WritableXYAndZ>): boolean    
lookAt(args: LookAtPerspectiveArgs | LookAtOrthoArgs | LookAtUsingLensAngle): ViewStatus Setup view state for either perspective or orthographic view.  
lookAtGlobalLocation(eyeHeight: number, pitchAngleRadians: number0, location?: GlobalLocation, eyePoint?: Point3d): number Look at a global location, placing the camera's eye at the specified eye height above a viewed location.  
lookAtGlobalLocationFromGcs(eyeHeight: number, pitchAngleRadians: number0, location?: GlobalLocation, eyePoint?: Point3d): Promise<number> Look at a global location, placing the camera's eye at the specified eye height above a viewed location using the GCS.  
minimumFrontDistance(): number    
moveCameraGlobal(fromPoint: Point3d, toPoint: Point3d): ViewStatus Move camera about the global ellipsoid.  
moveCameraLocal(distance: Vector3d): ViewStatus Move the camera relative to its current location by a distance in camera coordinates.  
moveCameraWorld(distance: Vector3d): ViewStatus Move the camera relative to its current location by a distance in world coordinates.  
rootToCartographic(root: Readonly<WritableXYAndZ>, result?: Cartographic): undefined | Cartographic Convert a point in spatial coordinates to a cartographic coordinate.  
rootToCartographicFromGcs(root: Readonly<WritableXYAndZ>, result?: Cartographic): Promise<undefined | Cartographic> Convert a point in spatial coordinates to a cartographic coordinate using the GCS reprojection.  
rootToCartographicUsingGcs(root: Readonly<WritableXYAndZ>[]): Promise<undefined | Cartographic[]> Convert spatial coordinates to cartographic coordinates using the GCS reprojection.  
rotateCameraLocal(angle: Angle, axis: Vector3d, aboutPt?: Point3d): ViewStatus Rotate the camera from its current location about an axis relative to its current orientation.  
rotateCameraWorld(angle: Angle, axis: Vector3d, aboutPt?: Point3d): ViewStatus Rotate the camera from its current location about an axis in world coordinates.  
savePose(): ViewPose3d Capture a copy of the viewed volume and camera parameters.  
setAllow3dManipulations(allow: boolean): void Set whether ViewTools are allowed to operate in 3 dimensions on this view.  
setExtents(extents: Readonly<WritableXYAndZ>): void Set the extents of this view in CoordSystem.World coordinates.  
setEyePoint(pt: Readonly<WritableXYAndZ>): void Change the location of the eyePoint for the camera in this view.  
setFocusDistance(dist: number): void Set the focus distance for this view.  
setLensAngle(angle: Angle): void Set the lens angle for this view.  
setOrigin(origin: Readonly<WritableXYAndZ>): void Set the origin of this view in CoordSystem.World coordinates.  
setRotation(rot: Matrix3d): void Change the rotation of the view.  
setupFromFrustum(frustum: Frustum, opts?: OnViewExtentsError): ViewStatus Initialize the origin, extents, and rotation from an existing Frustum  
supportsCamera(): boolean    
toJSON(): ViewDefinition3dProps Convert to JSON representation.  
turnCameraOff(): void Turn the camera off for this view.  
verifyFocusPlane(): void Ensure the focus plane lies between the front and back planes.  
calculateMaxDepth(delta: Vector3d, zVec: Vector3d): number Protected Static    

Inherited methods

Name Inherited from Description
_updateMaxGlobalScopeFactor(): void Protected Inherited ViewState  
adjustAspectRatio(aspect: number): void Inherited ViewState Adjust the aspect ratio of this ViewState so it matches the supplied value.
calculateFocusCorners(): Point3d[] Inherited ViewState  
calculateFrustum(result?: Frustum): undefined | Frustum Inherited ViewState Calculate the world coordinate Frustum from the parameters of this ViewState.
clone(iModel?: IModelConnection): this Inherited ViewState Make an independent copy of this EntityState
computeDisplayTransform(args: ComputeDisplayTransformArgs): undefined | Transform Inherited ViewState Compute the transform applied to a model or element at display time, if any.
computeFitRange(): Range3d Abstract Inherited ViewState Compute a range in CoordSystem.World coordinates that tightly encloses the contents of this view.
equals(other: this): boolean Inherited ViewState Determine whether this ViewState exactly matches another.
forEachModel(func: (model: GeometricModelState) => void): void Abstract Inherited ViewState Execute a function on each viewed model
forEachTileTreeRef(func: (treeRef: TileTreeReference) => void): void Inherited ViewState Execute a function against each TileTreeReference associated with this view.
getAspectRatio(): number Inherited ViewState Get the aspect ratio (width/height) of this view
getAspectRatioSkew(): number Inherited ViewState Get the aspect ratio skew (x/y, usually 1.0) that is used to exaggerate the y axis of the view.
getAuxiliaryCoordinateSystemId(): string Inherited ViewState Get the Id of the auxiliary coordinate system for this ViewState
getCenter(result?: Point3d): Point3d Inherited ViewState Get the point at the geometric center of the view.
getGlobeRotation(): undefined | Matrix3d Inherited ViewState If the view is not of the project as determined by getIsViewingProject then return
getGridOrientation(): GridOrientationType Inherited ViewState Get the grid settings for this view
getGridSettings(vp: Viewport, origin: Point3d, rMatrix: Matrix3d, orientation: GridOrientationType): void Inherited ViewState Populate the given origin and rotation with information from the grid settings from the grid orientation.
getGridSpacing(): Readonly<WritableXAndY> Inherited ViewState  
getGridsPerRef(): number Inherited ViewState  
getIsViewingProject(): boolean Inherited ViewState Return true if the view is looking at the current iModel project extents or
getModelAppearanceOverride(id: string): undefined | FeatureAppearance Inherited ViewState Query the symbology overrides applied to a model when rendered using this ViewState.
getSubCategoryOverride(id: string): undefined | SubCategoryOverride Inherited ViewState Query the symbology overrides applied to geometry belonging to a specific subcategory when rendered using this ViewState.
getUpVector(point: Point3d): Vector3d Inherited ViewState Compute the vector in the "up" direction of a specific point in world space.
getViewClip(): undefined | ClipVector Inherited ViewState Get the clipping volume for this view, if defined
getViewedExtents(): Range3d Abstract Inherited ViewState Get the extents of this view in CoordSystem.World coordinates.
getXVector(result?: Vector3d): Vector3d Inherited ViewState Get the unit vector that points in the view X (left-to-right) direction.
getYVector(result?: Vector3d): Vector3d Inherited ViewState Get the unit vector that points in the view Y (bottom-to-top) direction.
getZVector(result?: Vector3d): Vector3d Inherited ViewState Get the unit vector that points in the view Z (front-to-back) direction.
hasSameCoordinates(other: ViewState): boolean Inherited ViewState Determine whether this ViewState has the same coordinate system as another one.
is2d(): this is ViewState2d Inherited ViewState Returns true if this ViewState is-a ViewState2d
isSheetView(): this is SheetViewState Inherited ViewState Returns true if this ViewState is-a SheetViewState
isSpatialView(): this is SpatialViewState Abstract Inherited ViewState Returns true if this ViewState is-a SpatialViewState
load(): Promise<void> Inherited ViewState Asynchronously load any required data for this ViewState from the backend.
lookAtViewAlignedVolume(volume: Range3d, aspect?: number, options?: MarginOptions & OnViewExtentsError): void Inherited ViewState Look at a volume of space defined by a range in view local coordinates, keeping its current rotation.
lookAtVolume(volume: Readonly<WritableLowAndHighXYZ> | Readonly<WritableLowAndHighXY>, aspect?: number, options?: MarginOptions & OnViewExtentsError): void Inherited ViewState Change the volume that this view displays, keeping its current rotation.
postload(hydrateResponse: HydrateViewStateResponseProps): Promise<void> Protected Inherited ViewState  
preload(hydrateRequest: HydrateViewStateRequestProps): void Protected Inherited ViewState Populates the hydrateRequest object stored on the ViewState with:
resetExtentLimits(): void Inherited ViewState Resets the largest and smallest values allowed for the extents of this ViewState to their default values.
setAspectRatioSkew(val: number): void Inherited ViewState Set the aspect ratio skew (x/y) for this view.
setAuxiliaryCoordinateSystem(acs?: AuxCoordSystemState): void Inherited ViewState Set or clear the AuxiliaryCoordinateSystem for this view.
setCategorySelector(categories: CategorySelectorState): void Inherited ViewState Set the CategorySelector for this view.
setCenter(center: Point3d): void Inherited ViewState set the center of this view to a new position.
setDisplayStyle(style: DisplayStyleState): void Inherited ViewState  
setGridSettings(orientation: GridOrientationType, spacing: Point2d, gridsPerRef: number): void Inherited ViewState Set the grid settings for this view
setRotationAboutPoint(rotation: Matrix3d, point?: Point3d): void Inherited ViewState Set the rotation of this ViewState to the supplied rotation, by rotating it about a point.
setStandardGlobalRotation(id: StandardViewId): void Inherited ViewState Orient this view to one of the StandardView rotations, if the the view is not viewing the project then the
setStandardRotation(id: StandardViewId): void Inherited ViewState Orient this view to one of the StandardView rotations.
setViewClip(clip?: ClipVector): void Inherited ViewState Set or clear the clipping volume for this view.
toProps(): ViewStateProps Inherited ViewState Serialize this ViewState as a set of properties that can be used to recreate it via createFromProps.
viewsCategory(id: string): boolean Inherited ViewState Determine whether the specified Category is displayed in this view
viewsModel(modelId: string): boolean Abstract Inherited ViewState Returns true if this view displays the contents of a Model specified by Id.
createFromProps(_props: ViewStateProps, _iModel: IModelConnection): undefined | ViewState Static Inherited ViewState Create a new ViewState object from a set of properties.

Properties

Name Type Description
_cameraOn Protected boolean True if the camera is valid.  
camera Readonly Camera The camera used for this view.  
className Accessor Static ReadOnly string The name of the BIS class associated with this class.  
details Accessor ReadOnly ViewDetails3d Provides access to optional detail settings for this view.  
displayStyle Accessor DisplayStyle3dState The style that controls how the contents of the view are displayed.  
extents Readonly Vector3d The extent of the view frustum.  
forceMinFrontDist number Minimum distance for front plane  
globalScopeFactor Accessor ReadOnly number A value that represents the global scope of the view -- a value greater than one indicates that the scope of this view is global.  
isCameraOn Accessor ReadOnly boolean    
isCameraValid Accessor ReadOnly boolean Determine whether the camera is valid for this view  
isGlobalView Accessor ReadOnly boolean    
origin Readonly Point3d The lower left back corner of the view frustum.  
rotation Readonly Matrix3d Rotation of the view frustum.  

Inherited properties

Name Type Inherited from Description
analysisStyle Accessor Inherited ReadOnly undefined | AnalysisStyle ViewState See DisplayStyleSettings.analysisStyle.
areAllTileTreesLoaded Accessor Inherited ReadOnly boolean ViewState Returns true if all TileTrees required by this view have been loaded.
Note that the map tile trees associated to the viewport rather than the view, to check the
map tiles as well call areAreAllTileTreesLoaded.
auxiliaryCoordinateSystem Accessor Inherited ReadOnly AuxCoordSystemState ViewState get the auxiliary coordinate system state object for this ViewState.
backgroundColor Accessor Inherited ReadOnly ColorDef ViewState Get this view's background color.
categorySelector Accessor Inherited CategorySelectorState ViewState Selects the categories that are display by this ViewState.
classFullName Accessor Static Inherited ReadOnly string ViewState Get full BIS class name of this Entity in the form "SchemaName:ClassName".
classFullName Readonly Inherited string ViewState The full class name in the form "schema:class".
className Accessor Inherited ReadOnly string ViewState The name of the BIS class associated with this class.
code Readonly Inherited Code ViewState The Code for this element
defaultExtentLimits Accessor Abstract Inherited ReadOnly ExtentLimits ViewState Returns the default extent limits for this ViewState. These limits are used if the extentLimits have not been explicitly overridden.
description Inherited string | undefined ViewState  
extentLimits Accessor Inherited ExtentLimits ViewState Get or set the largest and smallest values allowed for the extents for this ViewState
The default limits vary based on the type of view:
- Spatial and drawing view extents cannot exceed the diameter of the earth.
- Sheet view extents cannot exceed ten times the paper size of the sheet.
Explicitly setting the extent limits overrides the default limits.
federationGuid Readonly Inherited string | undefined ViewState A FederationGuid assigned to this element by some other federated database
id Readonly Inherited string ViewState The Id of this Entity.
iModel Readonly Inherited IModelConnection ViewState The iModel from which this Entity was loaded
isAttachedToViewport Accessor Inherited ReadOnly boolean ViewState Returns whether this view is currently being displayed by a Viewport.
isPrivate Inherited boolean | undefined ViewState  
jsonProperties Readonly Inherited [key: string]: any ViewState Optional json properties of this Entity.
model Readonly Inherited string ViewState The ModelId of the Model containing this element
modelDisplayTransformProvider Accessor Inherited undefined | ModelDisplayTransformProvider ViewState An object that can provide per-model transforms to be applied at display time.
name Accessor Inherited ReadOnly string ViewState Get the name of the ViewDefinition from which this ViewState originated.
onDisplayStyleChanged Readonly Inherited BeEvent<(newStyle: DisplayStyleState) => void> ViewState An event raised just before assignment to the displayStyle property, only if the view is attached to a Viewport.
onModelDisplayTransformProviderChanged Readonly Inherited BeEvent<(newProvider: ModelDisplayTransformProvider) => void> ViewState Event raised just before assignment to the modelDisplayTransformProvider property, only if the view is attached to a Viewport.
onViewedCategoriesChanged Readonly Inherited BeEvent<() => void> ViewState An event raised when the set of categories viewed by this view changes, only if the view is attached to a Viewport.
parent Readonly Inherited RelatedElement | undefined ViewState The parent Element of this, or undefined if no parent.
scheduleScript Accessor Inherited ReadOnly undefined | RenderSchedule.Script ViewState The RenderSchedule.Script that animates the contents of the view, if any.
schemaName Accessor Static Inherited ReadOnly string ViewState The name of the BIS schema for this class.
userLabel Readonly Inherited string | undefined ViewState A user-assigned label for this element.
viewFlags Accessor Inherited ViewFlags ViewState Flags controlling various aspects of this view's DisplayStyleState.

Defined in

Last Updated: 18 January, 2025