GriddedRaggedRange2dSet<T> Class
A GriddedRaggedRange2dSet is:
- A doubly dimensioned array of Range2dSearchInterface.
- Each entry represents a block in a uniform grid within the master range.
- Member ranges are noted in the grid block containing the range's lower left corner.
- Member ranges larger than twice the grid size are rejected by the insert method.
- Hence a search involving a point in grid block (i,j) must examine ranges in grid blocks left and below, i.e. (i-1,j-1), (i-1,j), (i,j-1)
Implements
Methods
Name | Description | |
---|---|---|
addRange(range: Readonly<WritableLowAndHighXY>, tag: T): void | Add a range to the search set. | |
conditionalInsert(range: Readonly<WritableLowAndHighXY> | Range3d | Range2d, tag: T): boolean | If possible, insert a range into the set. | |
searchRange2d(testRange: Readonly<WritableLowAndHighXY>, handler: (range: Range2d, tag: T) => boolean): boolean | * Search for ranges overlapping testRange | |
searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean | * Search for ranges containing testRange | |
totalRange(result?: Range2d): Range2d | Return the overall range of all members. | |
visitChildren(initialDepth: number, handler: (depth: number, child: Range2dSearchInterface<T>) => void): void | Call the handler on each defined block in the grid. | |
create<T>(range: Range2d, numXEdge: number, numYEdge: number): undefined | GriddedRaggedRange2dSet<T> Static | Create an (empty) set of ranges. |
Defined in
Last Updated: 16 January, 2025
Found something wrong, missing, or unclear on this page?Raise an issue in our repo.