GraphicalEditingScope Class
Represents a period of time within an interactive editing session during which the geometry of elements being displayed in one or more Viewports is being modified. Outside of such a scope, whenever the geometry within a GeometricModel changes new Tiles must be generated to reflect those changes in a viewport. Regenerating entire tiles each time individual elements change can be time-consuming, which may introduce an unacceptable delay between making a modification and seeing its result on the screen.
Within the context of a graphical editing scope, no new tiles are generated. Instead, the geometry for any deleted or modified elements is hidden in the tile graphics, and additional temporary graphics are displayed for any newly-inserted or modified elements. Only when the scope exits are new tiles produced.
The application decides when to enter and exit a graphical editing scope. A single interactive editing session may involve any number of editing scopes. Typically, applications will enter a new editing scope (after first exiting a previous scope, if one exists):
- When switching from a non-graphical workflow to one that involves editing geometry; or
- When changing which geometric model is being edited; or
- After performing an operation that creates or modifies a "large" number (perhaps hundreds?) of elements.
An application should typically exit any graphical editing scope before:
- Pulling changesets; or
- Switching from a graphical editing workflow to some non-graphical workflow.
Graphical editing scopes are only supported for BriefcaseConnections opened in read-write mode that contain version 1.0.11 or newer of the BisCore schema.
@see - enterEditingScope to create a scope for a briefcase.
- editingScope to obtain a briefcase's current scope.
- exit to terminate a scope.
Extends
Implements
- EditingScopeNotifications
Methods
Name | Description | |
---|---|---|
exit(): Promise<void> | Exits this editing scope. | |
getGeometryChanges(): Iterable<ModelGeometryChanges, any, any> | Obtain all geometric changes to models accumulated within this scope. | |
getGeometryChangesForModel(modelId: string): undefined | Iterable<ElementGeometryChange, any, any> | Obtain all geometric changes to elements within the specified model accumulated within this scope. |
Inherited methods
Name | Inherited from | Description |
---|---|---|
registerImpl(): RemoveFunction Inherited | BriefcaseNotificationHandler | |
register(): RemoveFunction Static Inherited | BriefcaseNotificationHandler | Register this class as the handler for notifications on its channel. |
Properties
Name | Type | Description | |
---|---|---|---|
briefcaseChannelName Accessor ReadOnly | "itwinjs-core/editing-scope" | ||
iModel Readonly | BriefcaseConnection | The connection to the iModel being edited. | |
onEnter Static Readonly | BeEvent<(scope: GraphicalEditingScope) => void> | Event raised when a new scope is created for any BriefcaseConnection. | |
onExited Readonly | BeEvent<(scope: GraphicalEditingScope) => void> | Event raised when this scope has exited. | |
onExiting Readonly | BeEvent<(scope: GraphicalEditingScope) => void> | Event raised when this scope is about to exit. | |
onGeometryChanges Readonly | BeEvent<(changes: Iterable<ModelGeometryChanges, any, any>, scope: GraphicalEditingScope) => void> | Event raised after geometric changes are written to the iModel. |
Inherited properties
Name | Type | Inherited from | Description |
---|---|---|---|
channelName Accessor Inherited ReadOnly | string | BriefcaseNotificationHandler | All subclasses must implement this method to specify their response channel name. |
Defined in
Last Updated: 18 January, 2025