Class: PointsManager<T>
PointsManager handles Point type data contained in a TypedArray representation
where all the point data is consecutive from start to end. That is, the
organization is x0,y0,z0,x1,y1,z1,...,xn,yn,zn
. This optimizes the storage
costs for large arrays of data, while still providing access to the point
data as though it were a simple array of objects.
This representation is efficient for storing large numbers of points and for transferring them amongst systems and is planned to have more methods added for generic manipulation of data.
Type Parameters
• T
Constructors
new PointsManager()
new PointsManager<
T
>(configuration
):PointsManager
<T
>
Parameters
• configuration: PolyDataPointConfiguration
= {}
Returns
Defined in
packages/core/src/utilities/PointsManager.ts:37
Properties
_byteSize
_byteSize:
number
=4
Defined in
packages/core/src/utilities/PointsManager.ts:33
_dimensions
_dimensions:
number
=3
Defined in
packages/core/src/utilities/PointsManager.ts:31
_length
_length:
number
=0
Defined in
packages/core/src/utilities/PointsManager.ts:32
array
array:
ArrayBuffer
Defined in
packages/core/src/utilities/PointsManager.ts:35
data
data:
Float32Array
Defined in
packages/core/src/utilities/PointsManager.ts:30
growSize
growSize:
number
=128
Defined in
packages/core/src/utilities/PointsManager.ts:34
kIndex
kIndex:
number
Allow storage for an index value to indicate where this array is contained in terms of the index location.
Defined in
packages/core/src/utilities/PointsManager.ts:22
sources
sources:
IPointsManager
<T
>[]
Sources data for this array. Just used for external access, not updated here.
Defined in
packages/core/src/utilities/PointsManager.ts:28
Accessors
dimensionLength
get
dimensionLength():number
Returns
number
Defined in
packages/core/src/utilities/PointsManager.ts:65
dimensions
get
dimensions():number
Returns
number
Defined in
packages/core/src/utilities/PointsManager.ts:61
length
get
length():number
Returns
number
Defined in
packages/core/src/utilities/PointsManager.ts:57
points
get
points():T
[]
A points object containing Float32Array
instances referring to the underlying
data, contained in a FloatArray32[]
instance.
Note - changes to the data store will directly affect the points value
returned here, even if stored separately.
Returns
T
[]
Defined in
packages/core/src/utilities/PointsManager.ts:187
Methods
forEach()
forEach(
func
):void
Parameters
• func
Returns
void
Defined in
packages/core/src/utilities/PointsManager.ts:51
getPoint()
getPoint(
index
):T
Returns a Float32Array
view of the given point.
Changes to the data in this point will affect the underlying data.
Parameters
• index: number
positive index from start, or negative from end
Returns
T
Float32Array
view onto the point at the given index
Defined in
packages/core/src/utilities/PointsManager.ts:76
getPointArray()
getPointArray(
index
):T
Returns a number[]
version of the given point.
Changes to the array will NOT affect the underlying data.
Parameters
• index: number
positive index from start, or negative from end
Returns
T
A new number[]
instance of the given point.
Defined in
packages/core/src/utilities/PointsManager.ts:97
getTypedArray()
getTypedArray():
Float32Array
Gets the raw underlying data - note this can change. Use for fast calculations on a fully filled array.
Returns
Float32Array
Defined in
packages/core/src/utilities/PointsManager.ts:154
grow()
protected
grow(additionalSize
,growSize
):void
Updates the array size as needed to allow for at least the given additional number of elements.
Parameters
• additionalSize: number
= 1
• growSize: number
= ...
Returns
void
Defined in
packages/core/src/utilities/PointsManager.ts:116
map()
map<
R
>(f
):R
[]
Maps the array onto another type.
Type Parameters
• R
Parameters
• f
Returns
R
[]
Defined in
packages/core/src/utilities/PointsManager.ts:173
push()
push(
point
):void
Push a new point onto this arrays object
Parameters
• point: T
Returns
void
Defined in
packages/core/src/utilities/PointsManager.ts:161
reverse()
reverse():
void
Reverse the points in place.
Returns
void
Defined in
packages/core/src/utilities/PointsManager.ts:136
subselect()
subselect(
count
,offset
):IPointsManager
<T
>
Select the given number of points from the array, evenly spaced at the
given offset (which must be between (-count,count)
)
Parameters
• count: number
= 10
• offset: number
= 0
Returns
Defined in
packages/core/src/utilities/PointsManager.ts:236
toXYZ()
toXYZ():
PointsXYZ
The XYZ representation of a points array is an object with three separate
arrays, one for each of x,y and z, containing the point data, eg
x: {x0, x1, x2, ...., xn }
Will create just x,y for Point2 arrays.
Returns
An XYZ array
Defined in
packages/core/src/utilities/PointsManager.ts:199
create2()
static
create2(initialSize
):PointsManager
<Point2
>
Create a PointsManager<Point2>
instance with available capacity of initialSize
Parameters
• initialSize: number
= 128
Returns
Defined in
packages/core/src/utilities/PointsManager.ts:269
create3()
static
create3(initialSize
,points
?):PointsManager
<Point3
>
Create a PointsManager<Point3>
instance with available capacity of initialSize
Parameters
• initialSize: number
= 128
the starting size of the underlying array, however, it will still be empty of actual data initially.
• points?: Point3
[]
a set of points to add to the points array. Makes it easy to copy
a set of points into a PointsManager
.
Returns
Defined in
packages/core/src/utilities/PointsManager.ts:257
fromXYZ()
static
fromXYZ(__namedParameters
):IPointsManager
<Point3
>
Create an PointsArray3
from the x,y,z individual arrays (see toXYZ)
Will create a Point3
array even if z is missing, with 0 as the value.
Parameters
• __namedParameters: PointsXYZ