@giro3d/giro3d
Version:
A JS/WebGL framework for 3D geospatial data visualization
47 lines (39 loc) • 1.43 kB
text/typescript
import { Object3D } from 'three';
import type PointMesh from './PointMesh';
import { isPointMesh } from './PointMesh';
import type SimpleGeometryMesh from './SimpleGeometryMesh';
import type { DefaultUserData, SimpleGeometryMeshEventMap } from './SimpleGeometryMesh';
export default class MultiPointMesh<UserData extends DefaultUserData = DefaultUserData>
extends Object3D<SimpleGeometryMeshEventMap>
implements SimpleGeometryMesh<UserData>
{
readonly isSimpleGeometryMesh = true as const;
readonly isMultiPointMesh = true as const;
readonly type = 'MultiPointMesh' as const;
override userData: Partial<UserData> = {};
constructor(points: PointMesh[]) {
super();
this.add(...points);
}
set opacity(opacity: number) {
this.traversePoints(p => (p.opacity = opacity));
}
/**
* Executes the callback on all the {@link PointMesh}es of this mesh.
* @param callback - The callback to execute.
*/
traversePoints(callback: (polygon: PointMesh) => void) {
this.traverse(obj => {
if (isPointMesh(obj)) {
callback(obj);
}
});
}
dispose(): void {
this.traversePoints(p => p.dispose());
this.dispatchEvent({ type: 'dispose' });
}
}
export function isMultiPointMesh(obj: unknown): obj is MultiPointMesh {
return (obj as MultiPointMesh)?.isMultiPointMesh ?? false;
}