From ed4fcb3ffec8b6aee1acbc7ab4d4b1ea2f7858b6 Mon Sep 17 00:00:00 2001 From: Florent Poujol Date: Wed, 5 Oct 2016 12:30:50 +0200 Subject: [PATCH] Update definitions to r80, for Superpowers v3. Bump version to v0.4.1 --- package.json | 2 +- public/bundles/typescriptAPI.js | 2 +- typescriptAPI/main.d.ts | 3884 +++++++++++++++++++------------ 3 files changed, 2361 insertions(+), 1527 deletions(-) diff --git a/package.json b/package.json index 420ed0d..9e695d4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "superpowers-game-threejs-plugin", - "version": "0.4.0", + "version": "0.4.1", "description": "Expose Three.js to the Typescript API of the Superpowers Game system for Superpowers, the extensible HTML5 2D+3D game engine.", "repository": { "type": "git", diff --git a/public/bundles/typescriptAPI.js b/public/bundles/typescriptAPI.js index 4d2a06e..43f1883 100644 --- a/public/bundles/typescriptAPI.js +++ b/public/bundles/typescriptAPI.js @@ -3,7 +3,7 @@ SupCore.system.registerPlugin("typescriptAPI", "THREE.js", { code: "declare var THREE; declare var SupWebGLRenderer; declare var SupThreeScene;", - defs: "// THREE.js plugin\n// https://github.com/florentpoujol/superpowers-game-threejs-plugin\n// Expose Three.js to the Typescript API\n\ndeclare var SupWebGLRenderer: THREE.WebGLRenderer;\ndeclare var SupThreeScene: THREE.Scene;\n\n// below is the content of https://github.com/elisee/DefinitelyTyped/blob/a5264ccb8a0521f704baf8ea91ad46d3f450ff56/threejs/three.d.ts\n\n// Type definitions for three.js r73\n// Project: http://mrdoob.github.com/three.js/\n// Definitions by: Kon , Satoru Kimura \n// Definitions: https://github.com/borisyankov/DefinitelyTyped\n\ndeclare module THREE {\n export var REVISION: string;\n\n // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent.button\n export enum MOUSE { LEFT, MIDDLE, RIGHT }\n\n // GL STATE CONSTANTS\n export enum CullFace { }\n export var CullFaceNone: CullFace;\n export var CullFaceBack: CullFace;\n export var CullFaceFront: CullFace;\n export var CullFaceFrontBack: CullFace;\n\n export enum FrontFaceDirection { }\n export var FrontFaceDirectionCW: FrontFaceDirection;\n export var FrontFaceDirectionCCW: FrontFaceDirection;\n\n // Shadowing Type\n export enum ShadowMapType { }\n export var BasicShadowMap: ShadowMapType;\n export var PCFShadowMap: ShadowMapType;\n export var PCFSoftShadowMap: ShadowMapType;\n\n // MATERIAL CONSTANTS\n\n // side\n export enum Side { }\n export var FrontSide: Side;\n export var BackSide: Side;\n export var DoubleSide: Side;\n\n // shading\n export enum Shading { }\n export var NoShading: Shading;\n export var FlatShading: Shading;\n export var SmoothShading: Shading;\n\n // colors\n export enum Colors { }\n export var NoColors: Colors;\n export var FaceColors: Colors;\n export var VertexColors: Colors;\n\n // blending modes\n export enum Blending { }\n export var NoBlending: Blending;\n export var NormalBlending: Blending;\n export var AdditiveBlending: Blending;\n export var SubtractiveBlending: Blending;\n export var MultiplyBlending: Blending;\n export var CustomBlending: Blending;\n\n // custom blending equations\n // (numbers start from 100 not to clash with other\n // mappings to OpenGL constants defined in Texture.js)\n export enum BlendingEquation { }\n export var AddEquation: BlendingEquation;\n export var SubtractEquation: BlendingEquation;\n export var ReverseSubtractEquation: BlendingEquation;\n export var MinEquation: BlendingEquation;\n export var MaxEquation: BlendingEquation;\n\n // custom blending destination factors\n export enum BlendingDstFactor { }\n export var ZeroFactor: BlendingDstFactor;\n export var OneFactor: BlendingDstFactor;\n export var SrcColorFactor: BlendingDstFactor;\n export var OneMinusSrcColorFactor: BlendingDstFactor;\n export var SrcAlphaFactor: BlendingDstFactor;\n export var OneMinusSrcAlphaFactor: BlendingDstFactor;\n export var DstAlphaFactor: BlendingDstFactor;\n export var OneMinusDstAlphaFactor: BlendingDstFactor;\n\n // custom blending src factors\n export enum BlendingSrcFactor { }\n export var DstColorFactor: BlendingSrcFactor;\n export var OneMinusDstColorFactor: BlendingSrcFactor;\n export var SrcAlphaSaturateFactor: BlendingSrcFactor;\n\n // TEXTURE CONSTANTS\n // Operations\n export enum Combine { }\n export var MultiplyOperation: Combine;\n export var MixOperation: Combine;\n export var AddOperation: Combine;\n\n // Mapping modes\n export enum Mapping { }\n export var UVMapping: Mapping;\n export var CubeReflectionMapping: Mapping;\n export var CubeRefractionMapping: Mapping;\n export var EquirectangularReflectionMapping: Mapping;\n export var EquirectangularRefractionMapping: Mapping;\n export var SphericalReflectionMapping: Mapping;\n\n // Wrapping modes\n export enum Wrapping { }\n export var RepeatWrapping: Wrapping;\n export var ClampToEdgeWrapping: Wrapping;\n export var MirroredRepeatWrapping: Wrapping;\n\n // Filters\n export enum TextureFilter { }\n export var NearestFilter: TextureFilter;\n export var NearestMipMapNearestFilter: TextureFilter;\n export var NearestMipMapLinearFilter: TextureFilter;\n export var LinearFilter: TextureFilter;\n export var LinearMipMapNearestFilter: TextureFilter;\n export var LinearMipMapLinearFilter: TextureFilter;\n\n // Data types\n export enum TextureDataType { }\n export var UnsignedByteType: TextureDataType;\n export var ByteType: TextureDataType;\n export var ShortType: TextureDataType;\n export var UnsignedShortType: TextureDataType;\n export var IntType: TextureDataType;\n export var UnsignedIntType: TextureDataType;\n export var FloatType: TextureDataType;\n export var HalfFloatType: TextureDataType;\n\n // Pixel types\n export enum PixelType { }\n export var UnsignedShort4444Type: PixelType;\n export var UnsignedShort5551Type: PixelType;\n export var UnsignedShort565Type: PixelType;\n\n // Pixel formats\n export enum PixelFormat { }\n export var AlphaFormat: PixelFormat;\n export var RGBFormat: PixelFormat;\n export var RGBAFormat: PixelFormat;\n export var LuminanceFormat: PixelFormat;\n export var LuminanceAlphaFormat: PixelFormat;\n export var RGBEFormat: PixelFormat;\n\n // Compressed texture formats\n // DDS / ST3C Compressed texture formats\n export enum CompressedPixelFormat { }\n export var RGB_S3TC_DXT1_Format: CompressedPixelFormat;\n export var RGBA_S3TC_DXT1_Format: CompressedPixelFormat;\n export var RGBA_S3TC_DXT3_Format: CompressedPixelFormat;\n export var RGBA_S3TC_DXT5_Format: CompressedPixelFormat;\n\n // PVRTC compressed texture formats\n export var RGB_PVRTC_4BPPV1_Format: CompressedPixelFormat;\n export var RGB_PVRTC_2BPPV1_Format: CompressedPixelFormat;\n export var RGBA_PVRTC_4BPPV1_Format: CompressedPixelFormat;\n export var RGBA_PVRTC_2BPPV1_Format: CompressedPixelFormat;\n\n // log handlers\n export function warn(message?: any, ...optionalParams: any[]): void;\n export function error(message?: any, ...optionalParams: any[]): void;\n export function log(message?: any, ...optionalParams: any[]): void;\n\n\n // Cameras ////////////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Abstract base class for cameras. This class should always be inherited when you build a new camera.\n */\n export class Camera extends Object3D {\n /**\n * This constructor sets following properties to the correct type: matrixWorldInverse, projectionMatrix and projectionMatrixInverse.\n */\n constructor();\n\n /**\n * This is the inverse of matrixWorld. MatrixWorld contains the Matrix which has the world transform of the Camera.\n */\n matrixWorldInverse: Matrix4;\n\n /**\n * This is the matrix which contains the projection.\n */\n projectionMatrix: Matrix4;\n\n getWorldDirection(optionalTarget?: Vector3): Vector3;\n\n /**\n * This make the camera look at the vector position in local space.\n * @param vector point to look at\n */\n lookAt(vector: Vector3): void;\n\n clone(camera?: Camera): Camera;\n }\n\n export class CubeCamera extends Object3D {\n constructor( near?: number, far?: number, cubeResolution?: number);\n\n renderTarget: WebGLRenderTargetCube;\n\n updateCubeMap( renderer: Renderer, scene: Scene ): void;\n\n }\n\n /**\n * Camera with orthographic projection\n *\n * @example\n * var camera = new THREE.OrthographicCamera( width / - 2, width / 2, height / 2, height / - 2, 1, 1000 );\n * scene.add( camera );\n *\n * @see src/cameras/OrthographicCamera.js\n */\n export class OrthographicCamera extends Camera {\n /**\n * @param left Camera frustum left plane.\n * @param right Camera frustum right plane.\n * @param top Camera frustum top plane.\n * @param bottom Camera frustum bottom plane.\n * @param near Camera frustum near plane.\n * @param far Camera frustum far plane.\n */\n constructor(left: number, right: number, top: number, bottom: number, near?: number, far?: number);\n\n zoom: number;\n\n /**\n * Camera frustum left plane.\n */\n left: number;\n\n /**\n * Camera frustum right plane.\n */\n right: number;\n\n /**\n * Camera frustum top plane.\n */\n top: number;\n\n /**\n * Camera frustum bottom plane.\n */\n bottom: number;\n\n /**\n * Camera frustum near plane.\n */\n near: number;\n\n /**\n * Camera frustum far plane.\n */\n far: number;\n\n /**\n * Updates the camera projection matrix. Must be called after change of parameters.\n */\n updateProjectionMatrix(): void;\n\n clone(): OrthographicCamera;\n }\n\n /**\n * Camera with perspective projection.\n *\n * # example\n * var camera = new THREE.PerspectiveCamera( 45, width / height, 1, 1000 );\n * scene.add( camera );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/cameras/PerspectiveCamera.js\n */\n export class PerspectiveCamera extends Camera {\n /**\n * @param fov Camera frustum vertical field of view. Default value is 50.\n * @param aspect Camera frustum aspect ratio. Default value is 1.\n * @param near Camera frustum near plane. Default value is 0.1.\n * @param far Camera frustum far plane. Default value is 2000.\n */\n constructor(fov?: number, aspect?: number, near?: number, far?: number);\n\n zoom: number;\n\n /**\n * Camera frustum vertical field of view, from bottom to top of view, in degrees.\n */\n fov: number;\n\n /**\n * Camera frustum aspect ratio, window width divided by window height.\n */\n aspect: number;\n\n /**\n * Camera frustum near plane.\n */\n near: number;\n\n /**\n * Camera frustum far plane.\n */\n far: number;\n\n /**\n * Uses focal length (in mm) to estimate and set FOV 35mm (fullframe) camera is used if frame size is not specified.\n * Formula based on http://www.bobatkins.com/photography/technical/field_of_view.html\n * @param focalLength focal length\n * @param frameHeight frame size. Default value is 24.\n */\n setLens(focalLength: number, frameHeight?: number): void;\n\n /**\n * Sets an offset in a larger frustum. This is useful for multi-window or multi-monitor/multi-machine setups.\n * For example, if you have 3x2 monitors and each monitor is 1920x1080 and the monitors are in grid like this:\n *\n * +---+---+---+\n * | A | B | C |\n * +---+---+---+\n * | D | E | F |\n * +---+---+---+\n *\n * then for each monitor you would call it like this:\n *\n * var w = 1920;\n * var h = 1080;\n * var fullWidth = w * 3;\n * var fullHeight = h * 2;\n *\n * // A\n * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );\n * // B\n * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );\n * // C\n * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );\n * // D\n * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );\n * // E\n * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );\n * // F\n * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 1, w, h ); Note there is no reason monitors have to be the same size or in a grid.\n *\n * @param fullWidth full width of multiview setup\n * @param fullHeight full height of multiview setup\n * @param x horizontal offset of subcamera\n * @param y vertical offset of subcamera\n * @param width width of subcamera\n * @param height height of subcamera\n */\n setViewOffset(fullWidth: number, fullHeight: number, x: number, y: number, width: number, height: number): void;\n\n /**\n * Updates the camera projection matrix. Must be called after change of parameters.\n */\n updateProjectionMatrix(): void;\n clone(): PerspectiveCamera;\n }\n\n // Core ///////////////////////////////////////////////////////////////////////////////////////////////\n\n /**\n * @see src/core/InterleavedBuffer.js\n */\n export class InterleavedBuffer {\n constructor(array: ArrayLike, stride: number);\n array: ArrayLike;\n stride: number;\n dynamic: boolean;\n updateRange: {offset:number, count:number};\n version: number;\n length: number;\n count: number;\n needsUpdate: boolean;\n\n setDynamic(dynamic: boolean): InterleavedBuffer;\n copy(source: InterleavedBuffer): void;\n copyAt(index1: number, attribute: InterleavedBufferAttribute, index2: number): InterleavedBuffer;\n set(value: ArrayLike, index: number): InterleavedBuffer;\n clone(): InterleavedBuffer;\n }\n\n /**\n * @see src/core/InstancedInterleavedBuffer.js\n */\n export class InstancedInterleavedBuffer extends InterleavedBuffer {\n constructor(array: ArrayLike, stride: number, meshPerAttribute?: number);\n meshPerAttribute: number;\n copy(source: InstancedInterleavedBuffer): InstancedInterleavedBuffer;\n }\n\n /**\n * @see src/core/BufferAttribute.js\n */\n export class BufferAttribute {\n constructor(array: ArrayLike, itemSize: number); // array parameter should be TypedArray.\n\n array: ArrayLike;\n itemSize: number;\n dynamic: boolean;\n updateRange: {offset:number, count:number};\n needsUpdate: boolean;\n /** Deprecated, use count instead */\n length: number;\n count: number;\n\n setDynamic(dynamic: boolean): BufferAttribute;\n copy(source: BufferAttribute): BufferAttribute;\n copyAt(index1: number, attribute: BufferAttribute, index2: number): BufferAttribute;\n copyArray(array: ArrayLike): BufferAttribute;\n copyColorArray(colors: {r:number, g:number, b:number}[]): BufferAttribute;\n copyIndicesArray(indices: {a:number, b:number, c:number}[]): BufferAttribute;\n copyVector2sArray(vectors: {x:number, y:number}[]): BufferAttribute;\n copyVector3sArray(vectors: {x:number, y:number, z:number}[]): BufferAttribute;\n copyVector4sArray(vectors: {x:number, y:number, z:number, w:number}[]): BufferAttribute;\n set(value: ArrayLike, offset?: number): BufferAttribute;\n getX(index: number): number;\n setX(index: number, x: number): BufferAttribute;\n getY(index: number): number;\n setY(index: number, y: number): BufferAttribute;\n getZ(index: number): number;\n setZ(index: number, z: number): BufferAttribute;\n getW(index: number): number;\n setW(index: number, z: number): BufferAttribute;\n setXY(index: number, x: number, y: number): BufferAttribute;\n setXYZ(index: number, x: number, y: number, z: number): BufferAttribute;\n setXYZW(index: number, x: number, y: number, z: number, w: number): BufferAttribute;\n clone(): BufferAttribute;\n }\n\n // deprecated (are these actually deprecated?)\n export class Int8Attribute extends BufferAttribute{\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Uint8Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Uint8ClampedAttribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Int16Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Uint16Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Int32Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Uint32Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Float32Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n // deprecated\n export class Float64Attribute extends BufferAttribute {\n constructor(data: any, itemSize: number);\n }\n\n /**\n * @see src/core/InstancedBufferAttribute.js\n */\n export class InstancedBufferAttribute extends BufferAttribute {\n constructor(data: ArrayLike, itemSize: number, meshPerAttribute?: number);\n meshPerAttribute: number;\n copy(source: InstancedBufferAttribute): InstancedBufferAttribute;\n }\n\n /**\n * @see src/core/InterleavedBufferAttribute.js\n */\n export class InterleavedBufferAttribute {\n constructor(interleavedBuffer: InterleavedBuffer, itemSize: number, offset: number);\n\n uuid: string;\n data: InterleavedBuffer;\n itemSize: number;\n offset: number;\n /** Deprecated, use count instead */\n length: number;\n count: number;\n\n getX(index: number): number;\n setX(index: number, x: number): InterleavedBufferAttribute;\n getY(index: number): number;\n setY(index: number, y: number): InterleavedBufferAttribute;\n getZ(index: number): number;\n setZ(index: number, z: number): InterleavedBufferAttribute;\n getW(index: number): number;\n setW(index: number, z: number): InterleavedBufferAttribute;\n setXY(index: number, x: number, y: number): InterleavedBufferAttribute;\n setXYZ(index: number, x: number, y: number, z: number): InterleavedBufferAttribute;\n setXYZW(index: number, x: number, y: number, z: number, w: number): InterleavedBufferAttribute;\n }\n\n /**\n * This is a superefficent class for geometries because it saves all data in buffers.\n * It reduces memory costs and cpu cycles. But it is not as easy to work with because of all the nessecary buffer calculations.\n * It is mainly interesting when working with static objects.\n *\n * @see src/core/BufferGeometry.js\n */\n export class BufferGeometry {\n /**\n * This creates a new BufferGeometry. It also sets several properties to an default value.\n */\n constructor();\n\n static MaxIndex: number;\n\n /**\n * Unique number of this buffergeometry instance\n */\n id: number;\n uuid: string;\n name: string;\n type: string;\n attributes: BufferAttribute|InterleavedBufferAttribute[];\n /** Deprecated. Use groups instead. */\n drawcalls: { start: number; count: number; index: number; }[];\n /** Deprecated. Use groups instead. */\n offsets: { start: number; count: number; index: number; }[];\n groups: { start: number, count: number, materialIndex?: number }[];\n boundingBox: Box3;\n boundingSphere: BoundingSphere;\n\n addIndex(index: BufferAttribute): void;\n setIndex(index: BufferAttribute): void;\n\n /** Deprecated. This overloaded method is deprecated. */\n addAttribute(name: string, array: any, itemSize: number): any;\n addAttribute(name: string, attribute: BufferAttribute|InterleavedBufferAttribute): void;\n getAttribute(name: string): BufferAttribute|InterleavedBufferAttribute;\n removeAttribute(name: string): void;\n\n setIndex(index: BufferAttribute): void;\n getIndex(): BufferAttribute;\n\n /** Deprecated. Use addGroup */\n addDrawCall(start: number, count: number, index: number): void;\n addGroup(start: number, count: number, materialIndex?: number): void;\n clearGroups(): void;\n\n setDrawRange(start: number, count: number): void;\n\n /**\n * Bakes matrix transform directly into vertex coordinates.\n */\n applyMatrix(matrix: Matrix4): void;\n\n rotateX(angle: number): BufferGeometry;\n rotateY(angle: number): BufferGeometry;\n rotateZ(angle: number): BufferGeometry;\n translate(x: number, y: number, z: number): BufferGeometry;\n scale(x: number, y: number, z: number): BufferGeometry;\n lookAt(v: Vector3): void;\n\n center(): Vector3;\n\n setFromObject(object: Object3D) : void;\n updateFromObject(object: Object3D) : void;\n\n fromGeometry(geometry: Geometry, settings?: any): BufferGeometry;\n\n /**\n * Computes bounding box of the geometry, updating Geometry.boundingBox attribute.\n * Bounding boxes aren't computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingBox(): void;\n\n /**\n * Computes bounding sphere of the geometry, updating Geometry.boundingSphere attribute.\n * Bounding spheres aren't' computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingSphere(): void;\n\n // deprecated\n computeFaceNormals(): void;\n\n /**\n * Computes vertex normals by averaging face normals.\n */\n computeVertexNormals(): void;\n\n computeOffsets(size: number): void;\n merge(geometry: BufferGeometry, offset: number): BufferGeometry;\n normalizeNormals(): void;\n toJSON(): any;\n clone(): BufferGeometry;\n copy(source: BufferGeometry): BufferGeometry;\n\n /**\n * Disposes the object from memory.\n * You need to call this when you want the bufferGeometry removed while the application is running.\n */\n dispose(): void;\n\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n /**\n * @see src/core/InstancedBufferGeometry.js\n */\n export class InstancedBufferGeometry extends BufferGeometry {\n constructor();\n groups: {start:number, count:number, instances:number}[];\n addGroup(start: number, count: number, instances: number): void;\n copy(source: InstancedBufferGeometry): InstancedBufferGeometry;\n }\n\n /**\n * @see src/core/DirectGeometry.js\n */\n export class DirectGeometry {\n constructor();\n id: number;\n uuid: string;\n name: string;\n type: string;\n indices: number[];\n vertices: Vector3[];\n normals: Vector3[];\n colors: Color[];\n uvs: Vector2[];\n uvs2: Vector2[];\n groups: {start: number, materialIndex: number}[];\n morphTargets: MorphTarget[];\n skinWeights: number[];\n skinIndices: number[];\n boundingBox: Box3;\n boundingSphere: BoundingSphere;\n verticesNeedUpdate: boolean;\n normalsNeedUpdate: boolean;\n colorsNeedUpdate: boolean;\n uvsNeedUpdate: boolean;\n groupsNeedUpdate: boolean;\n computeBoundingBox(): void;\n computeBoundingSphere(): void;\n computeGroups(geometry: Geometry): void;\n fromGeometry(geometry: Geometry): DirectGeometry;\n dispose(): void;\n }\n\n /**\n * Object for keeping track of time.\n *\n * @see src/core/Clock.js\n */\n export class Clock {\n /**\n * @param autoStart Automatically start the clock.\n */\n constructor(autoStart?: boolean);\n\n /**\n * If set, starts the clock automatically when the first update is called.\n */\n autoStart: boolean;\n\n /**\n * When the clock is running, It holds the starttime of the clock.\n * This counted from the number of milliseconds elapsed since 1 January 1970 00:00:00 UTC.\n */\n startTime: number;\n\n /**\n * When the clock is running, It holds the previous time from a update.\n * This counted from the number of milliseconds elapsed since 1 January 1970 00:00:00 UTC.\n */\n oldTime: number;\n\n /**\n * When the clock is running, It holds the time elapsed between the start of the clock to the previous update.\n * This parameter is in seconds of three decimal places.\n */\n elapsedTime: number;\n\n /**\n * This property keeps track whether the clock is running or not.\n */\n running: boolean;\n\n /**\n * Starts clock.\n */\n start(): void;\n\n /**\n * Stops clock.\n */\n stop(): void;\n\n /**\n * Get the seconds passed since the clock started.\n */\n getElapsedTime(): number;\n\n /**\n * Get the seconds passed since the last call to this method.\n */\n getDelta(): number;\n }\n\n /**\n * Deprecated. Use new THREE.BufferAttribute().setDynamic(true) instead.\n */\n export class DynamicBufferAttribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n\n updateRange: {\n offset: number;\n count: number;\n }\n\n clone(): DynamicBufferAttribute;\n }\n\n /**\n * JavaScript events for custom objects\n *\n * # Example\n * var Car = function () {\n *\n * EventDispatcher.call( this );\n * this.start = function () {\n *\n * this.dispatchEvent( { type: 'start', message: 'vroom vroom!' } );\n *\n * };\n *\n * };\n *\n * var car = new Car();\n * car.addEventListener( 'start', function ( event ) {\n *\n * alert( event.message );\n *\n * } );\n * car.start();\n *\n * @source src/core/EventDispatcher.js\n */\n export class EventDispatcher {\n /**\n * Creates eventDispatcher object. It needs to be call with '.call' to add the functionality to an object.\n */\n constructor();\n\n /**\n * Adds a listener to an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n addEventListener(type: string, listener: (event: any) => void ): void;\n\n /**\n * Adds a listener to an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n hasEventListener(type: string, listener: (event: any) => void): void;\n\n /**\n * Removes a listener from an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n removeEventListener(type: string, listener: (event: any) => void): void;\n\n /**\n * Fire an event type.\n * @param type The type of event that gets fired.\n */\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n /**\n * Triangle face.\n *\n * # Example\n * var normal = new THREE.Vector3( 0, 1, 0 );\n * var color = new THREE.Color( 0xffaa00 );\n * var face = new THREE.Face3( 0, 1, 2, normal, color, 0 );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/core/Face3.js\n */\n export class Face3 {\n /**\n * @param a Vertex A index.\n * @param b Vertex B index.\n * @param c Vertex C index.\n * @param normal Face normal or array of vertex normals.\n * @param color Face color or array of vertex colors.\n * @param materialIndex Material index.\n */\n constructor(a: number, b: number, c: number, normal?: Vector3, color?: Color, materialIndex?: number);\n constructor(a: number, b: number, c: number, normal?: Vector3, vertexColors?: Color[], materialIndex?: number);\n constructor(a: number, b: number, c: number, vertexNormals?: Vector3[], color?: Color, materialIndex?: number);\n constructor(a: number, b: number, c: number, vertexNormals?: Vector3[], vertexColors?: Color[], materialIndex?: number);\n\n /**\n * Vertex A index.\n */\n a: number;\n\n /**\n * Vertex B index.\n */\n b: number;\n\n /**\n * Vertex C index.\n */\n c: number;\n\n /**\n * Face normal.\n */\n normal: Vector3;\n\n /**\n * Array of 4 vertex normals.\n */\n vertexNormals: Vector3[];\n\n /**\n * Face color.\n */\n color: Color;\n\n /**\n * Array of 4 vertex normals.\n */\n vertexColors: Color[];\n\n /**\n * Array of 4 vertex tangets.\n */\n vertexTangents: number[];\n\n /**\n * Material index (points to {@link Geometry.materials}).\n */\n materialIndex: number;\n\n clone(): Face3;\n }\n\n export interface MorphTarget {\n name: string;\n vertices: Vector3[];\n }\n\n export interface MorphColor {\n name: string;\n colors: Color[];\n }\n\n export interface MorphNormals {\n name: string;\n normals: Vector3[];\n }\n\n export interface BoundingSphere {\n radius: number;\n }\n\n\n /**\n * Base class for geometries\n *\n * # Example\n * var geometry = new THREE.Geometry();\n * geometry.vertices.push( new THREE.Vector3( -10, 10, 0 ) );\n * geometry.vertices.push( new THREE.Vector3( -10, -10, 0 ) );\n * geometry.vertices.push( new THREE.Vector3( 10, -10, 0 ) );\n * geometry.faces.push( new THREE.Face3( 0, 1, 2 ) );\n * geometry.computeBoundingSphere();\n *\n * @see https://github.com/mrdoob/three.js/blob/master/src/core/Geometry.js\n */\n export class Geometry {\n constructor();\n\n /**\n * Unique number of this geometry instance\n */\n id: number;\n\n uuid: string;\n\n /**\n * Name for this geometry. Default is an empty string.\n */\n name: string;\n\n type: string;\n\n /**\n * The array of vertices hold every position of points of the model.\n * To signal an update in this array, Geometry.verticesNeedUpdate needs to be set to true.\n */\n vertices: Vector3[];\n\n /**\n * Array of vertex colors, matching number and order of vertices.\n * Used in ParticleSystem, Line and Ribbon.\n * Meshes use per-face-use-of-vertex colors embedded directly in faces.\n * To signal an update in this array, Geometry.colorsNeedUpdate needs to be set to true.\n */\n colors: Color[];\n\n /**\n * Array of triangles or/and quads.\n * The array of faces describe how each vertex in the model is connected with each other.\n * To signal an update in this array, Geometry.elementsNeedUpdate needs to be set to true.\n */\n faces: Face3[];\n\n /**\n * Array of face UV layers.\n * Each UV layer is an array of UV matching order and number of vertices in faces.\n * To signal an update in this array, Geometry.uvsNeedUpdate needs to be set to true.\n */\n faceVertexUvs: Vector2[][][];\n\n /**\n * Array of morph targets. Each morph target is a Javascript object:\n *\n * { name: \"targetName\", vertices: [ new THREE.Vector3(), ... ] }\n *\n * Morph vertices match number and order of primary vertices.\n */\n morphTargets: MorphTarget[];\n\n /**\n * Array of morph normals. Morph normals have similar structure as morph targets, each normal set is a Javascript object:\n *\n * morphNormal = { name: \"NormalName\", normals: [ new THREE.Vector3(), ... ] }\n */\n morphNormals: MorphNormals[];\n\n /**\n * Array of skinning weights, matching number and order of vertices.\n */\n skinWeights: number[];\n\n /**\n * Array of skinning indices, matching number and order of vertices.\n */\n skinIndices: number[];\n\n /**\n *\n */\n lineDistances: number[];\n\n /**\n * Bounding box.\n */\n boundingBox: Box3;\n\n /**\n * Bounding sphere.\n */\n boundingSphere: BoundingSphere;\n\n /**\n * Set to true if attribute buffers will need to change in runtime (using \"dirty\" flags).\n * Unless set to true internal typed arrays corresponding to buffers will be deleted once sent to GPU.\n * Defaults to true.\n */\n dynamic: boolean;\n\n /**\n * Set to true if the vertices array has been updated.\n */\n verticesNeedUpdate: boolean;\n\n /**\n * Set to true if the faces array has been updated.\n */\n elementsNeedUpdate: boolean;\n\n /**\n * Set to true if the uvs array has been updated.\n */\n uvsNeedUpdate: boolean;\n\n /**\n * Set to true if the normals array has been updated.\n */\n normalsNeedUpdate: boolean;\n\n /**\n * Set to true if the tangents in the faces has been updated.\n */\n tangentsNeedUpdate: boolean;\n\n /**\n * Set to true if the colors array has been updated.\n */\n colorsNeedUpdate: boolean;\n\n /**\n * Set to true if the linedistances array has been updated.\n */\n lineDistancesNeedUpdate: boolean;\n\n /**\n *\n */\n groupsNeedUpdate: boolean;\n\n /**\n * Bakes matrix transform directly into vertex coordinates.\n */\n applyMatrix(matrix: Matrix4): void;\n\n fromBufferGeometry(geometry: BufferGeometry): Geometry;\n\n /**\n *\n */\n center(): Vector3;\n\n /**\n * Computes face normals.\n */\n computeFaceNormals(): void;\n\n /**\n * Computes vertex normals by averaging face normals.\n * Face normals must be existing / computed beforehand.\n */\n computeVertexNormals(areaWeighted?: boolean): void;\n\n /**\n * Computes morph normals.\n */\n computeMorphNormals(): void;\n\n computeLineDistances(): void;\n\n /**\n * Computes bounding box of the geometry, updating {@link Geometry.boundingBox} attribute.\n */\n computeBoundingBox(): void;\n\n /**\n * Computes bounding sphere of the geometry, updating Geometry.boundingSphere attribute.\n * Neither bounding boxes or bounding spheres are computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingSphere(): void;\n\n merge( geometry: Geometry, matrix: Matrix, materialIndexOffset: number): void;\n\n mergeMesh( mesh: Mesh ): void;\n\n /**\n * Checks for duplicate vertices using hashmap.\n * Duplicated vertices are removed and faces' vertices are updated.\n */\n mergeVertices(): number;\n\n sortFacesByMaterialIndex(): void;\n\n toJSON(): any;\n\n /**\n * Creates a new clone of the Geometry.\n */\n clone(): Geometry;\n\n /**\n * Removes The object from memory.\n * Don't forget to call this method when you remove an geometry because it can cuase meomory leaks.\n */\n dispose(): void;\n\n\n //These properties do not exist in a normal Geometry class, but if you use the instance that was passed by JSONLoader, it will be added.\n bones: Bone[];\n animation: AnimationData;\n animations: AnimationData[];\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n /**\n * Base class for scene graph objects\n */\n export class Object3D {\n constructor();\n\n /**\n * Unique number of this object instance.\n */\n id: number;\n\n /**\n *\n */\n uuid: string;\n\n /**\n * Optional name of the object (doesn't need to be unique).\n */\n name: string;\n\n type: string;\n\n /**\n * Object's parent in the scene graph.\n */\n parent: Object3D;\n\n /**\n * Array with object's children.\n */\n children: Object3D[];\n\n /**\n * Up direction.\n */\n up: Vector3;\n\n /**\n * Object's local position.\n */\n position: Vector3;\n\n /**\n * Object's local rotation (Euler angles), in radians.\n */\n rotation: Euler;\n\n /**\n * Global rotation.\n */\n quaternion: Quaternion;\n\n /**\n * Object's local scale.\n */\n scale: Vector3;\n\n /**\n * When this is set, then the rotationMatrix gets calculated every frame.\n */\n rotationAutoUpdate: boolean;\n\n /**\n * Local transform.\n */\n matrix: Matrix4;\n\n /**\n * The global transform of the object. If the Object3d has no parent, then it's identical to the local transform.\n */\n matrixWorld: Matrix4;\n\n /**\n * When this is set, it calculates the matrix of position, (rotation or quaternion) and scale every frame and also recalculates the matrixWorld property.\n */\n matrixAutoUpdate: boolean;\n\n /**\n * When this is set, it calculates the matrixWorld in that frame and resets this property to false.\n */\n matrixWorldNeedsUpdate: boolean;\n\n /**\n * Object gets rendered if true.\n */\n visible: boolean;\n\n /**\n * Gets rendered into shadow map.\n */\n castShadow: boolean;\n\n /**\n * Material gets baked in shadow receiving.\n */\n receiveShadow: boolean;\n\n /**\n * When this is set, it checks every frame if the object is in the frustum of the camera. Otherwise the object gets drawn every frame even if it isn't visible.\n */\n frustumCulled: boolean;\n\n renderOrder: number;\n\n /**\n * An object that can be used to store custom data about the Object3d. It should not hold references to functions as these will not be cloned.\n */\n userData: any;\n\n /**\n *\n */\n static DefaultUp: Vector3;\n static DefaultMatrixAutoUpdate: boolean;\n\n /**\n * Order of axis for Euler angles.\n */\n // deprecated\n eulerOrder: string;\n\n\n /**\n * This updates the position, rotation and scale with the matrix.\n */\n applyMatrix(matrix: Matrix4): void;\n\n /**\n *\n */\n setRotationFromAxisAngle(axis: Vector3, angle: number): void;\n\n /**\n *\n */\n setRotationFromEuler(euler: Euler ): void;\n\n /**\n *\n */\n setRotationFromMatrix(m: Matrix4): void;\n\n /**\n *\n */\n setRotationFromQuaternion( q: Quaternion ): void;\n\n /**\n * Rotate an object along an axis in object space. The axis is assumed to be normalized.\n * @param axis A normalized vector in object space.\n * @param angle The angle in radians.\n */\n rotateOnAxis(axis: Vector3, angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateX(angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateY(angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateZ(angle: number): Object3D;\n\n /**\n * @param axis A normalized vector in object space.\n * @param distance The distance to translate.\n */\n translateOnAxis(axis: Vector3, distance: number): Object3D;\n\n /**\n *\n * @param distance\n * @param axis\n */\n translate( distance: number, axis: Vector3 ): Object3D;\n\n /**\n * Translates object along x axis by distance.\n * @param distance Distance.\n */\n translateX(distance: number): Object3D;\n\n /**\n * Translates object along y axis by distance.\n * @param distance Distance.\n */\n translateY(distance: number): Object3D;\n\n /**\n * Translates object along z axis by distance.\n * @param distance Distance.\n */\n translateZ(distance: number): Object3D;\n\n /**\n * Updates the vector from local space to world space.\n * @param vector A local vector.\n */\n localToWorld(vector: Vector3): Vector3;\n\n /**\n * Updates the vector from world space to local space.\n * @param vector A world vector.\n */\n worldToLocal(vector: Vector3): Vector3;\n\n /**\n * Rotates object to face point in space.\n * @param vector A world vector to look at.\n */\n lookAt(vector: Vector3): void;\n\n /**\n * Adds object as child of this object.\n */\n add(object: Object3D): void;\n\n /**\n * Removes object as child of this object.\n */\n remove(object: Object3D): void;\n\n /* deprecated */\n getChildByName( name: string ): Object3D;\n\n /**\n * Searches through the object's children and returns the first with a matching id, optionally recursive.\n * @param id Unique number of the object instance\n */\n getObjectById(id: number): Object3D;\n\n /**\n * Searches through the object's children and returns the first with a matching name, optionally recursive.\n * @param name String to match to the children's Object3d.name property.\n */\n getObjectByName(name: string): Object3D;\n\n getObjectByProperty( name: string, value: string ): Object3D;\n\n getWorldPosition(optionalTarget?: Vector3): Vector3;\n getWorldQuaternion(optionalTarget?: Quaternion): Quaternion;\n getWorldRotation(optionalTarget?: Euler): Euler;\n getWorldScale(optionalTarget?: Vector3): Vector3;\n getWorldDirection(optionalTarget?: Vector3): Vector3;\n\n /**\n * Translates object along arbitrary axis by distance.\n * @param distance Distance.\n * @param axis Translation direction.\n */\n traverse(callback: (object: Object3D) => any): void;\n\n traverseVisible(callback: (object: Object3D) => any): void;\n\n traverseAncestors(callback: (object: Object3D) => any): void;\n\n /**\n * Updates local transform.\n */\n updateMatrix(): void;\n\n /**\n * Updates global transform of the object and its children.\n */\n updateMatrixWorld(force: boolean): void;\n\n toJSON(): any;\n\n /**\n *\n * @param object\n * @param recursive\n */\n clone(object?: Object3D, recursive?: boolean): Object3D;\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n\n }\n\n export interface Intersection {\n distance: number;\n point: Vector3;\n face: Face3;\n object: Object3D;\n }\n\n export interface RaycasterParameters {\n Sprite?: any;\n Mesh?: any;\n Points?: any;\n /** Deprecated, use Points */\n PointCloud?: any;\n LOD?: any;\n Line?: any;\n }\n\n export class Raycaster {\n constructor(origin?: Vector3, direction?: Vector3, near?: number, far?: number);\n\n ray: Ray;\n near: number;\n far: number;\n params: RaycasterParameters;\n precision: number;\n linePrecision: number;\n set(origin: Vector3, direction: Vector3): void;\n setFromCamera(coords: { x: number; y: number;}, camera: Camera ): void;\n intersectObject(object: Object3D, recursive?: boolean): Intersection[];\n intersectObjects(objects: Object3D[], recursive?: boolean): Intersection[];\n }\n\n // Lights //////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Abstract base class for lights.\n */\n export class Light extends Object3D {\n constructor(hex?: number);\n\n color: Color;\n\n shadow: LightShadow;\n\n /** Deprecated, use shadow */\n shadowCameraFov: number;\n shadowCameraNear: number;\n shadowCameraFar: number;\n shadowCameraLeft: number;\n shadowCameraRight: number;\n shadowCameraTop: number;\n shadowCameraBottom: number;\n shadowBias: number;\n shadowDarkness: number;\n shadowMapWidth: number;\n shadowMapHeight: number;\n shadowMap: RenderTarget;\n shadowMapSize: number;\n shadowCamera: Camera;\n shadowMatrix: Matrix4;\n\n clone(light?: Light): Light;\n }\n \n export class LightShadow {\n constructor(camera: Camera);\n\n camera: THREE.Camera;\n\n bias: number;\n darkness: number;\n\n mapSize: THREE.Vector2;\n\n map: any;\n matrix: THREE.Matrix4;\n \n clone(): LightShadow;\n }\n\n /**\n * This light's color gets applied to all the objects in the scene globally.\n *\n * # example\n * var light = new THREE.AmbientLight( 0x404040 ); // soft white light\n * scene.add( light );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/lights/AmbientLight.js\n */\n export class AmbientLight extends Light {\n /**\n * This creates a Ambientlight with a color.\n * @param hex Numeric value of the RGB component of the color.\n */\n constructor(hex?: number);\n\n clone(): AmbientLight;\n }\n\n /**\n * Affects objects using MeshLambertMaterial or MeshPhongMaterial.\n *\n * @example\n * // White directional light at half intensity shining from the top.\n * var directionalLight = new THREE.DirectionalLight( 0xffffff, 0.5 );\n * directionalLight.position.set( 0, 1, 0 );\n * scene.add( directionalLight );\n *\n * @see src/lights/DirectionalLight.js\n */\n export class DirectionalLight extends Light {\n\n constructor(hex?: number, intensity?: number);\n\n /**\n * Target used for shadow camera orientation.\n */\n target: Object3D;\n\n /**\n * Light's intensity.\n * Default — 1.0.\n */\n intensity: number;\n\n clone(): DirectionalLight;\n }\n\n export class HemisphereLight extends Light {\n constructor(skyColorHex?: number, groundColorHex?: number, intensity?: number);\n\n groundColor: Color;\n intensity: number;\n\n clone(): HemisphereLight;\n }\n\n /**\n * Affects objects using {@link MeshLambertMaterial} or {@link MeshPhongMaterial}.\n *\n * @example\n * var light = new THREE.PointLight( 0xff0000, 1, 100 );\n * light.position.set( 50, 50, 50 );\n * scene.add( light );\n */\n export class PointLight extends Light {\n constructor(hex?: number, intensity?: number, distance?: number, decay?: number);\n\n /*\n * Light's intensity.\n * Default - 1.0.\n */\n intensity: number;\n\n /**\n * If non-zero, light will attenuate linearly from maximum intensity at light position down to zero at distance.\n * Default — 0.0.\n */\n distance: number;\n\n decay: number;\n\n clone(): PointLight;\n }\n\n /**\n * A point light that can cast shadow in one direction.\n */\n export class SpotLight extends Light {\n constructor(hex?: number, intensity?: number, distance?: number, angle?: number, exponent?: number, decay?: number);\n\n /**\n * Spotlight focus points at target.position.\n * Default position — (0,0,0).\n */\n target: Object3D;\n\n /**\n * Light's intensity.\n * Default — 1.0.\n */\n intensity: number;\n\n /**\n * If non-zero, light will attenuate linearly from maximum intensity at light position down to zero at distance.\n * Default — 0.0.\n */\n distance: number;\n\n /*\n * Maximum extent of the spotlight, in radians, from its direction.\n * Default — Math.PI/2.\n */\n angle: number;\n\n /**\n * Rapidity of the falloff of light from its target direction.\n * Default — 10.0.\n */\n exponent: number;\n\n decay: number;\n\n clone(): SpotLight;\n }\n\n // Loaders //////////////////////////////////////////////////////////////////////////////////\n\n export interface Progress {\n total: number;\n loaded: number;\n }\n\n /**\n * Base class for implementing loaders.\n *\n * Events:\n * load\n * Dispatched when the image has completed loading\n * content — loaded image\n *\n * error\n *\n * Dispatched when the image can't be loaded\n * message — error message\n */\n export class Loader {\n constructor();\n\n imageLoader: ImageLoader;\n\n /**\n * Will be called when load starts.\n * The default is a function with empty body.\n */\n onLoadStart: () => void;\n\n /**\n * Will be called while load progresses.\n * The default is a function with empty body.\n */\n onLoadProgress: () => void;\n\n /**\n * Will be called when load completes.\n * The default is a function with empty body.\n */\n onLoadComplete: () => void;\n\n /**\n * default — null.\n * If set, assigns the crossOrigin attribute of the image to the value of crossOrigin, prior to starting the load.\n */\n crossOrigin: string;\n\n extractUrlBase(url: string): string;\n initMaterials(materials: Material[], texturePath: string): Material[];\n needsTangents(materials: Material[]): boolean;\n createMaterial(m: Material, texturePath: string): boolean;\n\n static Handlers: LoaderHandler;\n }\n\n export interface LoaderHandler {\n handlers: any[];\n add(regex: string, loader: Loader): void;\n get(file: string): Loader;\n }\n\n export class BinaryTextureLoader {\n constructor();\n\n load(url: string, onLoad: (dataTexture: DataTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n }\n\n export class BufferGeometryLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n setCrossOrigin(crossOrigin: string): void;\n parse(json: any): BufferGeometry;\n }\n\n export interface Cache {\n enabled: boolean;\n files: any[];\n\n add(key: string, file: any): void;\n get(key: string): any;\n remove(key: string): void;\n clear(): void;\n }\n export var Cache: Cache;\n\n export class CompressedTextureLoader {\n constructor();\n\n load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onError?: (event: any) => void): void;\n }\n\n export class DataTextureLoader extends BinaryTextureLoader {\n // alias for BinaryTextureLoader.\n }\n\n /*\n * GeometryLoader class is experimental, and it is not yet included in the compiled source code.\n *\n export class GeometryLoader {\n\n }\n */\n\n /**\n * A loader for loading an image.\n * Unlike other loaders, this one emits events instead of using predefined callbacks. So if you're interested in getting notified when things happen, you need to add listeners to the object.\n */\n export class ImageLoader {\n constructor(manager?: LoadingManager);\n\n cache: Cache;\n manager: LoadingManager;\n crossOrigin: string;\n\n /**\n * Begin loading from url\n * @param url\n */\n load(url: string, onLoad?: (image: HTMLImageElement) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): HTMLImageElement;\n\n setCrossOrigin(crossOrigin: string): void;\n }\n\n /**\n * A loader for loading objects in JSON format.\n */\n export class JSONLoader extends Loader {\n constructor();\n\n withCredentials: boolean;\n\n /**\n * @param url\n * @param callback. This function will be called with the loaded model as an instance of geometry when the load is completed.\n * @param texturePath If not specified, textures will be assumed to be in the same folder as the Javascript model file.\n */\n load(url: string, callback: (geometry: Geometry, materials: Material[]) => void , texturePath?: string): void;\n\n loadAjaxJSON(context: JSONLoader, url: string, callback: (geometry: Geometry, materials: Material[]) => void , texturePath?: string, callbackProgress?: (progress: Progress) => void ): void;\n\n parse(json: any, texturePath?: string): { geometry: Geometry; materials?: Material[] };\n }\n\n /**\n * Handles and keeps track of loaded and pending data.\n */\n export class LoadingManager {\n constructor(onLoad?: () => void, onProgress?: (url: string, loaded: number, total: number) => void, onError?: () => void);\n\n onStart: () => void;\n\n /**\n * Will be called when load starts.\n * The default is a function with empty body.\n */\n onLoad: () => void;\n\n /**\n * Will be called while load progresses.\n * The default is a function with empty body.\n */\n onProgress: (item: any, loaded: number, total: number) => void;\n\n /**\n * Will be called when each element in the scene completes loading.\n * The default is a function with empty body.\n */\n onError: () => void;\n\n itemStart(url: string): void;\n itemEnd(url: string): void;\n\n }\n\n export class MaterialLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n\n load(url: string, onLoad: (material: Material) => void): void;\n setCrossOrigin(crossOrigin: string): void;\n parse(json: any): Material;\n }\n\n export class ObjectLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n texturePass: string;\n\n load(url: string, onLoad?: (object: Object3D) => void): void;\n setTexturePath( value: string ): void;\n setCrossOrigin(crossOrigin: string): void;\n parse(json: any, onLoad?: (object: Object3D) => void): T;\n parseGeometries(json: any): any[]; // Array of BufferGeometry or Geometry or Geometry2.\n parseMaterials(json: any, textures: Texture[]): Material[]; // Array of Classes that inherits from Matrial.\n parseImages( json: any, onLoad: () => void ): any[];\n parseTextures( json: any, images: any ): Texture[];\n parseObject(data: any, geometries: any[], materials: Material[]): T;\n\n }\n\n /**\n * Class for loading a texture.\n * Unlike other loaders, this one emits events instead of using predefined callbacks. So if you're interested in getting notified when things happen, you need to add listeners to the object.\n */\n export class TextureLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n crossOrigin: string;\n\n /**\n * Begin loading from url\n *\n * @param url\n */\n load(url: string, onLoad: (texture: Texture) => void): void;\n setCrossOrigin(crossOrigin: string): void;\n }\n\n export class XHRLoader {\n constructor(manager?: LoadingManager);\n\n cache: Cache;\n manager: LoadingManager;\n responseType: string;\n crossOrigin: string;\n\n load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n setResponseType(responseType: string): void;\n setCrossOrigin(crossOrigin: string): void;\n }\n\n // Materials //////////////////////////////////////////////////////////////////////////////////\n export interface MaterialParameters {\n name?: string;\n side?: Side;\n opacity?: number;\n transparent?: boolean;\n blending?: Blending;\n blendSrc?: BlendingDstFactor;\n blendDst?: BlendingSrcFactor;\n blendEquation?: BlendingEquation;\n depthTest?: boolean;\n depthWrite?: boolean;\n polygonOffset?: boolean;\n polygonOffsetFactor?: number;\n polygonOffsetUnits?: number;\n alphaTest?: number;\n overdraw?: number;\n visible?: boolean;\n needsUpdate?: boolean;\n }\n\n /**\n * Materials describe the appearance of objects. They are defined in a (mostly) renderer-independent way, so you don't have to rewrite materials if you decide to use a different renderer.\n */\n export class Material {\n constructor();\n\n /**\n * Unique number of this material instance.\n */\n id: number;\n\n uuid: string;\n\n /**\n * Material name. Default is an empty string.\n */\n name: string;\n\n type: string;\n\n /**\n * Defines which of the face sides will be rendered - front, back or both.\n * Default is THREE.FrontSide. Other options are THREE.BackSide and THREE.DoubleSide.\n */\n side: Side;\n\n /**\n * Opacity. Default is 1.\n */\n opacity: number;\n\n /**\n * Defines whether this material is transparent. This has an effect on rendering, as transparent objects need an special treatment, and are rendered after the opaque (i.e. non transparent) objects. For a working example of this behaviour, check the {@link WebGLRenderer} code.\n * Default is false.\n */\n transparent: boolean;\n\n /**\n * Which blending to use when displaying objects with this material. Default is {@link NormalBlending}.\n */\n blending: Blending;\n\n /**\n * Blending source. It's one of the blending mode constants defined in Three.js. Default is {@link SrcAlphaFactor}.\n */\n blendSrc: BlendingDstFactor;\n\n /**\n * Blending destination. It's one of the blending mode constants defined in Three.js. Default is {@link OneMinusSrcAlphaFactor}.\n */\n blendDst: BlendingSrcFactor;\n\n /**\n * Blending equation to use when applying blending. It's one of the constants defined in Three.js. Default is AddEquation.\n */\n blendEquation: BlendingEquation;\n\n blendSrcAlpha: number;\n blendDstAlpha: number;\n blendEquationAlpha: number;\n\n depthFunc: Function;\n\n /**\n * Whether to have depth test enabled when rendering this material. Default is true.\n */\n depthTest: boolean;\n\n /**\n * Whether rendering this material has any effect on the depth buffer. Default is true.\n * When drawing 2D overlays it can be useful to disable the depth writing in order to layer several things together without creating z-index artifacts.\n */\n depthWrite: boolean;\n\n colorWrite: boolean;\n\n /**\n * Whether to use polygon offset. Default is false. This corresponds to the POLYGON_OFFSET_FILL WebGL feature.\n */\n polygonOffset: boolean;\n\n /**\n * Sets the polygon offset factor. Default is 0.\n */\n polygonOffsetFactor: number;\n\n /**\n * Sets the polygon offset units. Default is 0.\n */\n polygonOffsetUnits: number;\n\n /**\n * Sets the alpha value to be used when running an alpha test. Default is 0.\n */\n alphaTest: number;\n\n /**\n * Enables/disables overdraw. If greater than zero, polygons are drawn slightly bigger in order to fix antialiasing gaps when using the CanvasRenderer. Default is 0.\n */\n overdraw: number;\n\n /**\n * Defines whether this material is visible. Default is true.\n */\n visible: boolean;\n\n /**\n * Specifies that the material needs to be updated, WebGL wise. Set it to true if you made changes that need to be reflected in WebGL.\n * This property is automatically set to true when instancing a new material.\n */\n needsUpdate: boolean;\n\n setValues(values: Object): void;\n toJSON(): any;\n clone(material?:Material): Material;\n update(): void;\n dispose(): void;\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n export interface LineBasicMaterialParameters extends MaterialParameters {\n color?: number;\n linewidth?: number;\n linecap?: string;\n linejoin?: string;\n vertexColors?: Colors;\n fog?: boolean;\n }\n\n export class LineBasicMaterial extends Material {\n constructor(parameters?: LineBasicMaterialParameters);\n\n color: Color;\n linewidth: number;\n linecap: string;\n linejoin: string;\n vertexColors: Colors;\n fog: boolean;\n\n clone(): LineBasicMaterial;\n }\n\n export interface LineDashedMaterialParameters extends MaterialParameters {\n color?: number;\n linewidth?: number;\n scale?: number;\n dashSize?: number;\n gapSize?: number;\n vertexColors?: Colors;\n fog?: boolean;\n }\n\n export class LineDashedMaterial extends Material {\n constructor(parameters?: LineDashedMaterialParameters);\n\n color: Color;\n linewidth: number;\n scale: number;\n dashSize: number;\n gapSize: number;\n vertexColors: Colors;\n fog: boolean;\n\n clone(): LineDashedMaterial;\n }\n\n /**\n * parameters is an object with one or more properties defining the material's appearance.\n */\n export interface MeshBasicMaterialParameters extends MaterialParameters{\n color?: number;\n map?: Texture;\n aoMap?: Texture;\n aoMapIntensity?: number;\n specularMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n fog?: boolean;\n shading?: Shading;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n wireframeLinecap?: string;\n wireframeLinejoin?: string;\n vertexColors?: Colors;\n skinning?: boolean;\n morphTargets?: boolean;\n }\n\n export class MeshBasicMaterial extends Material {\n constructor(parameters?: MeshBasicMaterialParameters);\n\n color: Color;\n map: Texture;\n aoMap: Texture;\n aoMapIntensity: number;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n fog: boolean;\n shading: Shading;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n vertexColors: Colors;\n skinning: boolean;\n morphTargets: boolean;\n\n clone(): MeshBasicMaterial;\n }\n\n export interface MeshDepthMaterialParameters extends MaterialParameters{\n wireframe?: boolean;\n wireframeLinewidth?: number;\n }\n\n export class MeshDepthMaterial extends Material {\n constructor(parameters?: MeshDepthMaterialParameters);\n\n wireframe: boolean;\n wireframeLinewidth: number;\n\n clone(): MeshDepthMaterial;\n }\n\n // MeshFaceMaterial does not inherit the Material class in the original code. However, it should treat as Material class.\n // See tests/canvas/canvas_materials.ts.\n export class MeshFaceMaterial extends Material {\n constructor(materials?: Material[]);\n materials: Material[];\n\n toJSON(): any;\n clone(): MeshFaceMaterial;\n }\n\n export interface MeshLambertMaterialParameters extends MaterialParameters{\n color?: number;\n emissive?: number;\n map?: Texture;\n specularMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n fog?: boolean;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n wireframeLinecap?: string;\n wireframeLinejoin?: string;\n vertexColors?: Colors;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class MeshLambertMaterial extends Material {\n constructor(parameters?: MeshLambertMaterialParameters);\n color: Color;\n emissive: Color;\n map: Texture;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n fog: boolean;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n vertexColors: Colors;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n\n clone(): MeshLambertMaterial;\n }\n\n export interface MeshNormalMaterialParameters extends MaterialParameters{\n /** Line color in hexadecimal. Default is 0xffffff. */\n color?: number;\n /** Sets the texture map. Default is null */\n map?: Texture;\n /** Set light map. Default is null. */\n lightMap?: Texture;\n /** Set specular map. Default is null. */\n specularMap?: Texture;\n /** Set alpha map. Default is null. */\n alphaMap?: Texture;\n /** Set env map. Default is null. */\n envMap?: Texture;\n /** Define whether the material color is affected by global fog settings. Default is false. */\n fog?: boolean;\n /** How the triangles of a curved surface are rendered. Default is THREE.SmoothShading. */\n shading?: Shading;\n /** Render geometry as wireframe. Default is false (i.e. render as smooth shaded). */\n wireframe?: boolean;\n /** Controls wireframe thickness. Default is 1. */\n wireframeLinewidth?: number;\n /** Define appearance of line ends. Default is 'round'. */\n wireframeLinecap?: string;\n /** Define appearance of line joints. Default is 'round'. */\n wireframeLinejoin?: string;\n /** Define how the vertices gets colored. Default is THREE.NoColors. */\n vertexColors?: Colors;\n /** Define whether the material uses skinning. Default is false. */\n skinning?: boolean;\n /** Define whether the material uses morphTargets. Default is false. */\n morphTargets?: boolean;\n }\n\n export class MeshNormalMaterial extends Material {\n constructor(parameters?: MeshNormalMaterialParameters);\n\n wireframe: boolean;\n wireframeLinewidth: number;\n morphTargets: boolean;\n\n clone(): MeshNormalMaterial;\n }\n\n export interface MeshPhongMaterialParameters extends MaterialParameters {\n /** geometry color in hexadecimal. Default is 0xffffff. */\n color?: number;\n /** Sets the texture map. Default is null */\n map?: Texture;\n /** Set light map. Default is null */\n lightMap?: Texture;\n lightMapIntensity?: number;\n\n aoMap?: Texture;\n aoMapIntensity?: number;\n emissiveMap?: Texture;\n\n /** Set specular map. Default is null */\n specularMap?: Texture;\n /** Set alpha map. Default is null */\n alphaMap?: Texture;\n /** Set env map. Default is null */\n envMap?: Texture;\n /** Define whether the material color is affected by global fog settings. Default is true */\n fog?: boolean;\n /** Define shading type. Default is THREE.SmoothShading */\n shading?: Shading;\n /** render geometry as wireframe. Default is false */\n wireframe?: string;\n /** Line thickness. Default is 1. */\n wireframeLinewidth?: number;\n /** Define appearance of line ends. Default is 'round' */\n wireframeLinecap?: string;\n /** Define appearance of line joints. Default is 'round'. */\n wireframeLinejoin?: string;\n /** Define how the vertices gets colored. Default is THREE.NoColors. */\n vertexColors?: Colors;\n /** Define whether the material uses skinning. Default is false. */\n skinning?: boolean;\n\n /** Define whether the material uses morphTargets. Default is false. */\n morphTargets?: boolean;\n\n emissive?: number;\n specular?: number;\n shininess?: number;\n metal?: boolean;\n bumpMap?: Texture;\n bumpScale?: number;\n normalMap?: Texture;\n normalScale?: Vector2;\n displacementMap?: Texture;\n displacementScale?: number;\n displacementBias?: number;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n morphNormals?: boolean;\n }\n\n export class MeshPhongMaterial extends Material {\n constructor(parameters?: MeshPhongMaterialParameters);\n\n color: Color; // diffuse\n emissive: Color;\n specular: Color;\n shininess: number;\n metal: boolean;\n map: Texture;\n lightMap: Texture;\n lightMapIntensity: number;\n aoMap: Texture;\n aoMapIntensity: number;\n emissiveMap: Texture;\n bumpMap: Texture;\n bumpScale: number;\n normalMap: Texture;\n normalScale: Vector2;\n displacementMap: Texture;\n displacementScale: number;\n displacementBias: number;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n fog: boolean;\n shading: Shading;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n vertexColors: Colors;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n\n clone(): MeshPhongMaterial;\n }\n\n export interface PointCloudMaterialParameters extends MaterialParameters{\n color?: number;\n map?: Texture;\n size?: number;\n sizeAttenuation?: boolean;\n vertexColors?: Colors;\n fog?: boolean;\n }\n\n export class PointCloudMaterial extends Material {\n constructor(parameters?: PointCloudMaterialParameters);\n\n color: Color;\n map: Texture;\n size: number;\n sizeAttenuation: boolean;\n vertexColors: boolean;\n fog: boolean;\n\n clone(): PointCloudMaterial;\n }\n\n // deprecated\n export class ParticleBasicMaterial extends PointCloudMaterial{\n\n }\n\n // deprecated\n export class ParticleSystemMaterial extends PointCloudMaterial{\n\n }\n\n export class RawShaderMaterial extends ShaderMaterial {\n constructor(parameters?: ShaderMaterialParameters);\n\n }\n\n export interface ShaderMaterialParameters extends MaterialParameters {\n defines?: any;\n uniforms?: any;\n vertexShader?: string;\n fragmentShader?: string;\n shading?: Shading;\n linewidth?: number;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n fog?: boolean;\n lights?: boolean;\n vertexColors?: Colors;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class ShaderMaterial extends Material {\n constructor(parameters?: ShaderMaterialParameters);\n\n defines: any;\n uniforms: any;\n vertexShader: string;\n fragmentShader: string;\n shading: Shading;\n linewidth: number;\n wireframe: boolean;\n wireframeLinewidth: number;\n fog: boolean;\n lights: boolean;\n vertexColors: Colors;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n\n clone(): ShaderMaterial;\n }\n\n export interface SpriteMaterialParameters extends MaterialParameters {\n color?: number;\n map?: Texture;\n rotation?: number;\n fog?: boolean;\n }\n\n export class SpriteMaterial extends Material {\n constructor(parameters?: SpriteMaterialParameters);\n\n color: Color;\n map: Texture;\n rotation: number;\n fog: boolean;\n\n clone(): SpriteMaterial;\n }\n\n // Math //////////////////////////////////////////////////////////////////////////////////\n\n export class Box2 {\n constructor(min?: Vector2, max?: Vector2);\n\n max: Vector2;\n min: Vector2;\n\n set(min: Vector2, max: Vector2): Box2;\n setFromPoints(points: Vector2[]): Box2;\n setFromCenterAndSize(center: Vector2, size: Vector2): Box2;\n copy(box: Box2): Box2;\n makeEmpty(): Box2;\n empty(): boolean;\n center(optionalTarget?: Vector2): Vector2;\n size(optionalTarget?: Vector2): Vector2;\n expandByPoint(point: Vector2): Box2;\n expandByVector(vector: Vector2): Box2;\n expandByScalar(scalar: number): Box2;\n containsPoint(point: Vector2): boolean;\n containsBox(box: Box2): boolean;\n getParameter(point: Vector2): Vector2;\n isIntersectionBox(box: Box2): boolean;\n clampPoint(point: Vector2, optionalTarget?: Vector2): Vector2;\n distanceToPoint(point: Vector2): number;\n intersect(box: Box2): Box2;\n union(box: Box2): Box2;\n translate(offset: Vector2): Box2;\n equals(box: Box2): boolean;\n clone(): Box2;\n }\n\n export class Box3 {\n constructor(min?: Vector3, max?: Vector3);\n\n max: Vector3;\n min: Vector3;\n\n set(min: Vector3, max: Vector3): Box3;\n setFromPoints(points: Vector3[]): Box3;\n setFromCenterAndSize(center: Vector3, size: Vector3): Box3;\n setFromObject(object: Object3D): Box3;\n copy(box: Box3): Box3;\n makeEmpty(): Box3;\n empty(): boolean;\n center(optionalTarget?: Vector3): Vector3;\n size(optionalTarget?: Vector3): Vector3;\n expandByPoint(point: Vector3): Box3;\n expandByVector(vector: Vector3): Box3;\n expandByScalar(scalar: number): Box3;\n containsPoint(point: Vector3): boolean;\n containsBox(box: Box3): boolean;\n getParameter(point: Vector3): Vector3;\n isIntersectionBox(box: Box3): boolean;\n clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n distanceToPoint(point: Vector3): number;\n getBoundingSphere(optionalTarget?: Sphere): Sphere;\n intersect(box: Box3): Box3;\n union(box: Box3): Box3;\n applyMatrix4(matrix: Matrix4): Box3;\n translate(offset: Vector3): Box3;\n equals(box: Box3): boolean;\n clone(): Box3;\n }\n\n export interface HSL {\n h: number;\n s: number;\n l: number;\n }\n\n /**\n * Represents a color. See also {@link ColorUtils}.\n *\n * @example\n * var color = new THREE.Color( 0xff0000 );\n *\n * @see src/math/Color.js\n */\n export class Color {\n constructor(color?: Color);\n constructor(color?: string);\n constructor(color?: number);\n constructor(r: number, g: number, b: number);\n\n /**\n * Red channel value between 0 and 1. Default is 1.\n */\n r: number;\n\n /**\n * Green channel value between 0 and 1. Default is 1.\n */\n g: number;\n\n /**\n * Blue channel value between 0 and 1. Default is 1.\n */\n b: number;\n\n set(color: Color): Color;\n set(color: number): Color;\n set(color: string): Color;\n setHex(hex: number): Color;\n\n /**\n * Sets this color from RGB values.\n * @param r Red channel value between 0 and 1.\n * @param g Green channel value between 0 and 1.\n * @param b Blue channel value between 0 and 1.\n */\n setRGB(r: number, g: number, b: number): Color;\n\n /**\n * Sets this color from HSL values.\n * Based on MochiKit implementation by Bob Ippolito.\n *\n * @param h Hue channel value between 0 and 1.\n * @param s Saturation value channel between 0 and 1.\n * @param l Value channel value between 0 and 1.\n */\n setHSL(h: number, s: number, l: number): Color;\n\n /**\n * Sets this color from a CSS context style string.\n * @param contextStyle Color in CSS context style format.\n */\n setStyle(style: string): Color;\n\n /**\n * Copies given color.\n * @param color Color to copy.\n */\n copy(color: Color): Color;\n\n /**\n * Copies given color making conversion from gamma to linear space.\n * @param color Color to copy.\n */\n copyGammaToLinear(color: Color, gammaFactor?: number): Color;\n\n /**\n * Copies given color making conversion from linear to gamma space.\n * @param color Color to copy.\n */\n copyLinearToGamma(color: Color, gammaFactor?: number): Color;\n\n /**\n * Converts this color from gamma to linear space.\n */\n convertGammaToLinear(): Color;\n\n /**\n * Converts this color from linear to gamma space.\n */\n convertLinearToGamma(): Color;\n\n /**\n * Returns the hexadecimal value of this color.\n */\n getHex(): number;\n\n /**\n * Returns the string formated hexadecimal value of this color.\n */\n getHexString(): string;\n\n getHSL(): HSL;\n\n /**\n * Returns the value of this color in CSS context style.\n * Example: rgb(r, g, b)\n */\n getStyle(): string;\n\n offsetHSL(h: number, s: number, l: number): Color;\n\n add(color: Color): Color;\n addColors(color1: Color, color2: Color): Color;\n addScalar(s: number): Color;\n multiply(color: Color): Color;\n multiplyScalar(s: number): Color;\n lerp(color: Color, alpha: number): Color;\n equals(color: Color): boolean;\n fromArray(rgb: number[]): Color;\n toArray(array?: number[], offset?: number): number[];\n\n /**\n * Clones this color.\n */\n clone(): Color;\n }\n\n export class ColorKeywords {\n static aliceblue: number;\n static antiquewhite: number;\n static aqua: number;\n static aquamarine: number;\n static azure: number;\n static beige: number;\n static bisque: number;\n static black: number;\n static blanchedalmond: number;\n static blue: number;\n static blueviolet: number;\n static brown: number;\n static burlywood: number;\n static cadetblue: number;\n static chartreuse: number;\n static chocolate: number;\n static coral: number;\n static cornflowerblue: number;\n static cornsilk: number;\n static crimson: number;\n static cyan: number;\n static darkblue: number;\n static darkcyan: number;\n static darkgoldenrod: number;\n static darkgray: number;\n static darkgreen: number;\n static darkgrey: number;\n static darkkhaki: number;\n static darkmagenta: number;\n static darkolivegreen: number;\n static darkorange: number;\n static darkorchid: number;\n static darkred: number;\n static darksalmon: number;\n static darkseagreen: number;\n static darkslateblue: number;\n static darkslategray: number;\n static darkslategrey: number;\n static darkturquoise: number;\n static darkviolet: number;\n static deeppink: number;\n static deepskyblue: number;\n static dimgray: number;\n static dimgrey: number;\n static dodgerblue: number;\n static firebrick: number;\n static floralwhite: number;\n static forestgreen: number;\n static fuchsia: number;\n static gainsboro: number;\n static ghostwhite: number;\n static gold: number;\n static goldenrod: number;\n static gray: number;\n static green: number;\n static greenyellow: number;\n static grey: number;\n static honeydew: number;\n static hotpink: number;\n static indianred: number;\n static indigo: number;\n static ivory: number;\n static khaki: number;\n static lavender: number;\n static lavenderblush: number;\n static lawngreen: number;\n static lemonchiffon: number;\n static lightblue: number;\n static lightcoral: number;\n static lightcyan: number;\n static lightgoldenrodyellow: number;\n static lightgray: number;\n static lightgreen: number;\n static lightgrey: number;\n static lightpink: number;\n static lightsalmon: number;\n static lightseagreen: number;\n static lightskyblue: number;\n static lightslategray: number;\n static lightslategrey: number;\n static lightsteelblue: number;\n static lightyellow: number;\n static lime: number;\n static limegreen: number;\n static linen: number;\n static magenta: number;\n static maroon: number;\n static mediumaquamarine: number;\n static mediumblue: number;\n static mediumorchid: number;\n static mediumpurple: number;\n static mediumseagreen: number;\n static mediumslateblue: number;\n static mediumspringgreen: number;\n static mediumturquoise: number;\n static mediumvioletred: number;\n static midnightblue: number;\n static mintcream: number;\n static mistyrose: number;\n static moccasin: number;\n static navajowhite: number;\n static navy: number;\n static oldlace: number;\n static olive: number;\n static olivedrab: number;\n static orange: number;\n static orangered: number;\n static orchid: number;\n static palegoldenrod: number;\n static palegreen: number;\n static paleturquoise: number;\n static palevioletred: number;\n static papayawhip: number;\n static peachpuff: number;\n static peru: number;\n static pink: number;\n static plum: number;\n static powderblue: number;\n static purple: number;\n static red: number;\n static rosybrown: number;\n static royalblue: number;\n static saddlebrown: number;\n static salmon: number;\n static sandybrown: number;\n static seagreen: number;\n static seashell: number;\n static sienna: number;\n static silver: number;\n static skyblue: number;\n static slateblue: number;\n static slategray: number;\n static slategrey: number;\n static snow: number;\n static springgreen: number;\n static steelblue: number;\n static tan: number;\n static teal: number;\n static thistle: number;\n static tomato: number;\n static turquoise: number;\n static violet: number;\n static wheat: number;\n static white: number;\n static whitesmoke: number;\n static yellow: number;\n static yellowgreen: number;\n }\n\n export class Euler {\n constructor(x?: number, y?: number, z?: number, order?: string);\n\n x: number;\n y: number;\n z: number;\n order: string;\n\n set(x: number, y: number, z: number, order?: string): Euler;\n copy(euler: Euler): Euler;\n setFromRotationMatrix(m: Matrix4, order?: string, update?: boolean): Euler;\n setFromQuaternion(q:Quaternion, order?: string, update?: boolean): Euler;\n setFromVector3( v: Vector3, order?: string ): Euler;\n reorder(newOrder: string): Euler;\n equals(euler: Euler): boolean;\n fromArray(xyzo: any[]): Euler;\n toArray(array?: number[], offset?: number): number[];\n toVector3(optionalResult?: Vector3): Vector3;\n onChange: () => void;\n\n clone(): Euler;\n }\n\n /**\n * Frustums are used to determine what is inside the camera's field of view. They help speed up the rendering process.\n */\n export class Frustum {\n constructor(p0?: Plane, p1?: Plane, p2?: Plane, p3?: Plane, p4?: Plane, p5?: Plane);\n\n /**\n * Array of 6 vectors.\n */\n planes: Plane[];\n\n set(p0?: number, p1?: number, p2?: number, p3?: number, p4?: number, p5?: number): Frustum;\n copy(frustum: Frustum): Frustum;\n setFromMatrix(m: Matrix4): Frustum;\n intersectsObject(object: Object3D): boolean;\n intersectsSphere(sphere: Sphere): boolean;\n intersectsBox(box: Box3): boolean;\n containsPoint(point: Vector3): boolean;\n clone(): Frustum;\n\n }\n\n export class Line3 {\n constructor(start?: Vector3, end?: Vector3);\n start: Vector3;\n end: Vector3;\n\n set(start?: Vector3, end?: Vector3): Line3;\n copy(line: Line3): Line3;\n center(optionalTarget?: Vector3): Vector3;\n delta(optionalTarget?: Vector3): Vector3;\n distanceSq(): number;\n distance(): number;\n at(t: number, optionalTarget?: Vector3): Vector3;\n closestPointToPointParameter(point: Vector3, clampToLine?: boolean): number;\n closestPointToPoint(point: Vector3, clampToLine?: boolean, optionalTarget?: Vector3): Vector3;\n applyMatrix4(matrix: Matrix4): Line3;\n equals(line: Line3): boolean;\n clone(): Line3;\n }\n\n interface Math {\n generateUUID(): string;\n\n /**\n * Clamps the x to be between a and b.\n *\n * @param x Value to be clamped.\n * @param a Minimum value\n * @param b Maximum value.\n */\n clamp(x: number, a: number, b: number): number;\n\n\n /**\n * Linear mapping of x from range [a1, a2] to range [b1, b2].\n *\n * @param x Value to be mapped.\n * @param a1 Minimum value for range A.\n * @param a2 Maximum value for range A.\n * @param b1 Minimum value for range B.\n * @param b2 Maximum value for range B.\n */\n mapLinear(x: number, a1: number, a2: number, b1: number, b2: number): number;\n\n smoothstep(x: number, min: number, max: number): number;\n\n smootherstep(x: number, min: number, max: number): number;\n\n /**\n * Random float from 0 to 1 with 16 bits of randomness.\n * Standard Math.random() creates repetitive patterns when applied over larger space.\n */\n random16(): number;\n\n /**\n * Random integer from low to high interval.\n */\n randInt(low: number, high: number): number;\n\n /**\n * Random float from low to high interval.\n */\n randFloat(low: number, high: number): number;\n\n /**\n * Random float from - range / 2 to range / 2 interval.\n */\n randFloatSpread(range: number): number;\n\n degToRad(degrees: number): number;\n\n radToDeg(radians: number): number;\n\n isPowerOfTwo(value: number): boolean;\n\n nextPowerOfTwo(value: number): number;\n }\n\n /**\n *\n * @see src/math/Math.js\n */\n export var Math: Math;\n\n /**\n * ( interface Matrix<T> )\n */\n export interface Matrix {\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n /**\n * identity():T;\n */\n identity(): Matrix;\n\n /**\n * copy(m:T):T;\n */\n copy(m: Matrix): Matrix;\n\n /**\n * multiplyScalar(s:number):T;\n */\n multiplyScalar(s: number): Matrix;\n\n determinant(): number;\n\n /**\n * getInverse(matrix:T, throwOnInvertible?:boolean):T;\n */\n getInverse(matrix: Matrix, throwOnInvertible?: boolean): Matrix;\n\n /**\n * transpose():T;\n */\n transpose(): Matrix;\n\n /**\n * clone():T;\n */\n clone(): Matrix;\n }\n\n /**\n * ( class Matrix3 implements Matrix<Matrix3> )\n */\n export class Matrix3 implements Matrix {\n /**\n * Creates an identity matrix.\n */\n constructor();\n\n /**\n * Initialises the matrix with the supplied n11..n33 values.\n */\n constructor(n11: number, n12: number, n13: number, n21: number, n22: number, n23: number, n31: number, n32: number, n33: number);\n\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n set(n11: number, n12: number, n13: number, n21: number, n22: number, n23: number, n31: number, n32: number, n33: number): Matrix3;\n identity(): Matrix3;\n copy(m: Matrix3): Matrix3;\n applyToVector3Array(array: number[], offset?: number, length?: number): number[];\n multiplyScalar(s: number): Matrix3;\n determinant(): number;\n getInverse(matrix: Matrix3, throwOnInvertible?: boolean): Matrix3;\n getInverse(matrix: Matrix4, throwOnInvertible?: boolean): Matrix3;\n\n /**\n * Transposes this matrix in place.\n */\n transpose(): Matrix3;\n flattenToArrayOffset(array: number[], offset: number): number[];\n getNormalMatrix(m: Matrix4): Matrix3;\n\n /**\n * Transposes this matrix into the supplied array r, and returns itself.\n */\n transposeIntoArray(r: number[]): number[];\n fromArray(array: number[]): Matrix3;\n toArray(): number[];\n clone(): Matrix3;\n }\n\n /**\n * A 4x4 Matrix.\n *\n * @example\n * // Simple rig for rotating around 3 axes\n * var m = new THREE.Matrix4();\n * var m1 = new THREE.Matrix4();\n * var m2 = new THREE.Matrix4();\n * var m3 = new THREE.Matrix4();\n * var alpha = 0;\n * var beta = Math.PI;\n * var gamma = Math.PI/2;\n * m1.makeRotationX( alpha );\n * m2.makeRotationY( beta );\n * m3.makeRotationZ( gamma );\n * m.multiplyMatrices( m1, m2 );\n * m.multiply( m3 );\n */\n export class Matrix4 implements Matrix {\n /**\n * Initialises the matrix with the supplied n11..n44 values.\n */\n constructor(n11?: number, n12?: number, n13?: number, n14?: number, n21?: number, n22?: number, n23?: number, n24?: number, n31?: number, n32?: number, n33?: number, n34?: number, n41?: number, n42?: number, n43?: number, n44?: number);\n\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n /**\n * Sets all fields of this matrix.\n */\n set(n11: number, n12: number, n13: number, n14: number, n21: number, n22: number, n23: number, n24: number, n31: number, n32: number, n33: number, n34: number, n41: number, n42: number, n43: number, n44: number): Matrix4;\n\n /**\n * Resets this matrix to identity.\n */\n identity(): Matrix4;\n\n /**\n * Copies a matrix m into this matrix.\n */\n copy(m: Matrix4): Matrix4;\n copyPosition(m: Matrix4): Matrix4;\n\n extractBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4;\n makeBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4;\n\n /**\n * Copies the rotation component of the supplied matrix m into this matrix rotation component.\n */\n extractRotation(m: Matrix4): Matrix4;\n makeRotationFromEuler(euler: Euler): Matrix4;\n makeRotationFromQuaternion(q: Quaternion): Matrix4;\n /**\n * Constructs a rotation matrix, looking from eye towards center with defined up vector.\n */\n lookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix4;\n\n /**\n * Multiplies this matrix by m.\n */\n multiply(m: Matrix4): Matrix4;\n\n /**\n * Sets this matrix to a x b.\n */\n multiplyMatrices(a: Matrix4, b: Matrix4): Matrix4;\n\n /**\n * Sets this matrix to a x b and stores the result into the flat array r.\n * r can be either a regular Array or a TypedArray.\n */\n multiplyToArray(a: Matrix4, b: Matrix4, r: number[]): Matrix4;\n\n /**\n * Multiplies this matrix by s.\n */\n multiplyScalar(s: number): Matrix4;\n applyToVector3Array(array: number[], offset?: number, length?: number): number[];\n\n /**\n * Computes determinant of this matrix.\n * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm\n */\n determinant(): number;\n\n /**\n * Transposes this matrix.\n */\n transpose(): Matrix4;\n\n /**\n * Flattens this matrix into supplied flat array starting from offset position in the array.\n */\n flattenToArrayOffset(array: number[], offset: number): number[];\n\n /**\n * Sets the position component for this matrix from vector v.\n */\n setPosition(v: Vector3): Vector3;\n\n /**\n * Sets this matrix to the inverse of matrix m.\n * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm.\n */\n getInverse(m: Matrix4, throwOnInvertible?: boolean): Matrix4;\n\n /**\n * Multiplies the columns of this matrix by vector v.\n */\n scale(v: Vector3): Matrix4;\n\n getMaxScaleOnAxis(): number;\n /**\n * Sets this matrix as translation transform.\n */\n makeTranslation(x: number, y: number, z: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around x axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationX(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around y axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationY(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around z axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationZ(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around axis by angle radians.\n * Based on http://www.gamedev.net/reference/articles/article1199.asp.\n *\n * @param axis Rotation axis.\n * @param theta Rotation angle in radians.\n */\n makeRotationAxis(axis: Vector3, angle: number): Matrix4;\n\n /**\n * Sets this matrix as scale transform.\n */\n makeScale(x: number, y: number, z: number): Matrix4;\n\n /**\n * Sets this matrix to the transformation composed of translation, rotation and scale.\n */\n compose(translation: Vector3, rotation: Quaternion, scale: Vector3): Matrix4;\n\n /**\n * Decomposes this matrix into the translation, rotation and scale components.\n * If parameters are not passed, new instances will be created.\n */\n decompose(translation?: Vector3, rotation?: Quaternion, scale?: Vector3): Object[]; // [Vector3, Quaternion, Vector3]\n\n /**\n * Creates a frustum matrix.\n */\n makeFrustum(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix4;\n\n /**\n * Creates a perspective projection matrix.\n */\n makePerspective(fov: number, aspect: number, near: number, far: number): Matrix4;\n\n /**\n * Creates an orthographic projection matrix.\n */\n makeOrthographic(left: number, right: number, top: number, bottom: number, near: number, far: number): Matrix4;\n fromArray(array: number[]): Matrix4;\n toArray(): number[];\n /**\n * Clones this matrix.\n */\n clone(): Matrix4;\n }\n\n export class Plane {\n constructor(normal?: Vector3, constant?: number);\n\n normal: Vector3;\n constant: number;\n\n set(normal: Vector3, constant: number): Plane;\n setComponents(x: number, y: number, z: number, w: number): Plane;\n setFromNormalAndCoplanarPoint(normal: Vector3, point: Vector3): Plane;\n setFromCoplanarPoints(a: Vector3, b: Vector3, c: Vector3): Plane;\n copy(plane: Plane): Plane;\n normalize(): Plane;\n negate(): Plane;\n distanceToPoint(point: Vector3): number;\n distanceToSphere(sphere: Sphere): number;\n projectPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n orthoPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n isIntersectionLine(line: Line3): boolean;\n intersectLine(line: Line3, optionalTarget?: Vector3): Vector3;\n coplanarPoint(optionalTarget?: boolean): Vector3;\n applyMatrix4(matrix: Matrix4, optionalNormalMatrix?: Matrix3): Plane;\n translate(offset: Vector3): Plane;\n equals(plane: Plane): boolean;\n clone(): Plane;\n }\n\n /**\n * Implementation of a quaternion. This is used for rotating things without incurring in the dreaded gimbal lock issue, amongst other advantages.\n *\n * @example\n * var quaternion = new THREE.Quaternion();\n * quaternion.setFromAxisAngle( new THREE.Vector3( 0, 1, 0 ), Math.PI / 2 );\n * var vector = new THREE.Vector3( 1, 0, 0 );\n * vector.applyQuaternion( quaternion );\n */\n export class Quaternion {\n /**\n * @param x x coordinate\n * @param y y coordinate\n * @param z z coordinate\n * @param w w coordinate\n */\n constructor(x?: number, y?: number, z?: number, w?: number);\n\n x: number;\n y: number;\n z: number;\n w: number;\n\n /**\n * Sets values of this quaternion.\n */\n set(x: number, y: number, z: number, w: number): Quaternion;\n\n /**\n * Copies values of q to this quaternion.\n */\n copy(q: Quaternion): Quaternion;\n\n /**\n * Sets this quaternion from rotation specified by Euler angles.\n */\n setFromEuler(euler: Euler, update?: boolean): Quaternion;\n\n /**\n * Sets this quaternion from rotation specified by axis and angle.\n * Adapted from http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm.\n * Axis have to be normalized, angle is in radians.\n */\n setFromAxisAngle(axis: Vector3, angle: number): Quaternion;\n\n /**\n * Sets this quaternion from rotation component of m. Adapted from http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm.\n */\n setFromRotationMatrix(m: Matrix4): Quaternion;\n setFromUnitVectors(vFrom: Vector3, vTo: Vector3): Quaternion;\n /**\n * Inverts this quaternion.\n */\n inverse(): Quaternion;\n\n conjugate(): Quaternion;\n dot(v: Vector3): number;\n lengthSq(): number;\n\n /**\n * Computes length of this quaternion.\n */\n length(): number;\n\n /**\n * Normalizes this quaternion.\n */\n normalize(): Quaternion;\n\n /**\n * Multiplies this quaternion by b.\n */\n multiply(q: Quaternion): Quaternion;\n\n /**\n * Sets this quaternion to a x b\n * Adapted from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm.\n */\n multiplyQuaternions(a: Quaternion, b: Quaternion): Quaternion;\n\n /**\n * Deprecated. Use Vector3.applyQuaternion instead\n */\n multiplyVector3(vector: Vector3): Vector3;\n slerp(qb: Quaternion, t: number): Quaternion;\n equals(v: Quaternion): boolean;\n fromArray(n: number[]): Quaternion;\n toArray(): number[];\n\n fromArray(xyzw: number[], offset?: number): Quaternion;\n toArray(xyzw?: number[], offset?: number): number[];\n\n onChange: () => void;\n\n /**\n * Clones this quaternion.\n */\n clone(): Quaternion;\n\n /**\n * Adapted from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/.\n */\n static slerp(qa: Quaternion, qb: Quaternion, qm: Quaternion, t: number): Quaternion;\n }\n\n export class Ray {\n constructor(origin?: Vector3, direction?: Vector3);\n\n origin: Vector3;\n direction: Vector3;\n\n set(origin: Vector3, direction: Vector3): Ray;\n copy(ray: Ray): Ray;\n at(t: number, optionalTarget?: Vector3): Vector3;\n recast(t: number): Ray;\n closestPointToPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n distanceToPoint(point: Vector3): number;\n distanceSqToPoint(point: Vector3): number;\n distanceSqToSegment(v0: Vector3, v1: Vector3, optionalPointOnRay?: Vector3, optionalPointOnSegment?: Vector3): number;\n isIntersectionSphere(sphere: Sphere): boolean;\n intersectSphere(sphere: Sphere, optionalTarget?: Vector3): Vector3;\n isIntersectionPlane(plane: Plane): boolean;\n distanceToPlane(plane: Plane): number;\n intersectPlane(plane: Plane, optionalTarget?: Vector3): Vector3;\n isIntersectionBox(box: Box3): boolean;\n intersectBox(box: Box3, optionalTarget?: Vector3): Vector3;\n intersectTriangle(a: Vector3, b: Vector3, c: Vector3, backfaceCulling: boolean, optionalTarget?: Vector3): Vector3;\n applyMatrix4(matrix4: Matrix4): Ray;\n equals(ray: Ray): boolean;\n clone(): Ray;\n }\n\n export class Sphere {\n constructor(center?: Vector3, radius?: number);\n\n center: Vector3;\n radius: number;\n\n set(center: Vector3, radius: number): Sphere;\n setFromPoints(points: Vector3[], optionalCenter?: Vector3): Sphere;\n copy(sphere: Sphere): Sphere;\n empty(): boolean;\n containsPoint(point: Vector3): boolean;\n distanceToPoint(point: Vector3): number;\n intersectsSphere(sphere: Sphere): boolean;\n clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n getBoundingBox(optionalTarget?: Box3): Box3;\n applyMatrix4(matrix: Matrix4): Sphere;\n translate(offset: Vector3): Sphere;\n equals(sphere: Sphere): boolean;\n\n clone(): Sphere;\n }\n\n export interface SplineControlPoint {\n x: number;\n y: number;\n z: number;\n }\n\n /**\n * Represents a spline.\n *\n * @see src/math/Spline.js\n */\n export class Spline {\n /**\n * Initialises the spline with points, which are the places through which the spline will go.\n */\n constructor(points: SplineControlPoint[]);\n\n points: SplineControlPoint[];\n\n /**\n * Initialises using the data in the array as a series of points. Each value in a must be another array with three values, where a[n] is v, the value for the nth point, and v[0], v[1] and v[2] are the x, y and z coordinates of that point n, respectively.\n *\n * @param a array of triplets containing x, y, z coordinates\n */\n initFromArray(a: number[][]): void;\n\n /**\n * Return the interpolated point at k.\n *\n * @param k point index\n */\n getPoint(k: number): SplineControlPoint;\n\n /**\n * Returns an array with triplets of x, y, z coordinates that correspond to the current control points.\n */\n getControlPointsArray(): number[][];\n\n /**\n * Returns the length of the spline when using nSubDivisions.\n * @param nSubDivisions number of subdivisions between control points. Default is 100.\n */\n getLength(nSubDivisions?: number): { chunks: number[]; total: number; };\n\n /**\n * Modifies the spline so that it looks similar to the original but has its points distributed in such way that moving along the spline it's done at a more or less constant speed. The points should also appear more uniformly spread along the curve.\n * This is done by resampling the original spline, with the density of sampling controlled by samplingCoef. Here it's interesting to note that denser sampling is not necessarily better: if sampling is too high, you may get weird kinks in curvature.\n *\n * @param samplingCoef how many intermediate values to use between spline points\n */\n reparametrizeByArcLength(samplingCoef: number): void;\n }\n\n class Triangle {\n constructor(a?: Vector3, b?: Vector3, c?: Vector3);\n\n a: Vector3;\n b: Vector3;\n c: Vector3;\n\n set(a: Vector3, b: Vector3, c: Vector3): Triangle;\n setFromPointsAndIndices(points: Vector3[], i0: number, i1: number, i2: number): Triangle;\n copy(triangle: Triangle): Triangle;\n area(): number;\n midpoint(optionalTarget?: Vector3): Vector3;\n normal(optionalTarget?: Vector3): Vector3;\n plane(optionalTarget?: Vector3): Plane;\n barycoordFromPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n containsPoint(point: Vector3): boolean;\n equals(triangle: Triangle): boolean;\n clone(): Triangle;\n\n static normal(a: Vector3, b: Vector3, c: Vector3, optionalTarget?: Vector3): Vector3;\n static barycoordFromPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3, optionalTarget: Vector3): Vector3;\n static containsPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3): boolean;\n }\n\n\n /**\n * ( interface Vector<T> )\n *\n * Abstract interface of Vector2, Vector3 and Vector4.\n * Currently the members of Vector is NOT type safe because it accepts different typed vectors.\n * Those definitions will be changed when TypeScript innovates Generics to be type safe.\n *\n * @example\n * var v:THREE.Vector = new THREE.Vector3();\n * v.addVectors(new THREE.Vector2(0, 1), new THREE.Vector2(2, 3)); // invalid but compiled successfully\n */\n export interface Vector {\n setComponent(index: number, value: number): void;\n\n getComponent(index: number): number;\n\n /**\n * copy(v:T):T;\n */\n copy(v: Vector): Vector;\n\n /**\n * add(v:T):T;\n */\n add(v: Vector): Vector;\n\n /**\n * addVectors(a:T, b:T):T;\n */\n addVectors(a: Vector, b: Vector): Vector;\n\n /**\n * sub(v:T):T;\n */\n sub(v: Vector): Vector;\n\n /**\n * subVectors(a:T, b:T):T;\n */\n subVectors(a: Vector, b: Vector): Vector;\n\n /**\n * multiplyScalar(s:number):T;\n */\n multiplyScalar(s: number): Vector;\n\n /**\n * divideScalar(s:number):T;\n */\n divideScalar(s: number): Vector;\n\n /**\n * negate():T;\n */\n negate(): Vector;\n\n /**\n * dot(v:T):T;\n */\n dot(v: Vector): number;\n\n /**\n * lengthSq():number;\n */\n lengthSq(): number;\n\n /**\n * length():number;\n */\n length(): number;\n\n /**\n * normalize():T;\n */\n normalize(): Vector;\n\n /**\n * NOTE: Vector4 doesn't have the property.\n *\n * distanceTo(v:T):number;\n */\n distanceTo?(v: Vector): number;\n\n /**\n * NOTE: Vector4 doesn't have the property.\n *\n * distanceToSquared(v:T):number;\n */\n distanceToSquared?(v: Vector): number;\n\n /**\n * setLength(l:number):T;\n */\n setLength(l: number): Vector;\n\n /**\n * lerp(v:T, alpha:number):T;\n */\n lerp(v: Vector, alpha: number): Vector;\n\n /**\n * equals(v:T):boolean;\n */\n equals(v: Vector): boolean;\n\n /**\n * clone():T;\n */\n clone(): Vector;\n }\n\n /**\n * 2D vector.\n *\n * ( class Vector2 implements Vector )\n */\n export class Vector2 implements Vector {\n constructor(x?: number, y?: number);\n\n x: number;\n y: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number): Vector2;\n\n /**\n * Sets X component of this vector.\n */\n setX(x: number): Vector2;\n\n /**\n * Sets Y component of this vector.\n */\n setY(y: number): Vector2;\n\n /**\n * Sets a component of this vector.\n */\n setComponent(index: number, value: number): void;\n\n /**\n * Gets a component of this vector.\n */\n getComponent(index: number): number;\n\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector2): Vector2;\n\n /**\n * Adds v to this vector.\n */\n add(v: Vector2): Vector2;\n\n /**\n * Sets this vector to a + b.\n */\n addScalar(s: number): Vector2;\n addVectors(a: Vector2, b: Vector2): Vector2;\n addScaledVector(v: Vector2, s: number): Vector2;\n\n /**\n * Subtracts v from this vector.\n */\n sub(v: Vector2): Vector2;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector2, b: Vector2): Vector2;\n\n multiply(v: Vector2): Vector2;\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(s: number): Vector2;\n\n divide(v: Vector2): Vector2;\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector2;\n\n min(v: Vector2): Vector2;\n\n max(v: Vector2): Vector2;\n clamp(min: Vector2, max: Vector2): Vector2;\n clampScalar(min: number, max: number): Vector2;\n clampLength(min: number, max: number): Vector2;\n floor(): Vector2;\n ceil(): Vector2;\n round(): Vector2;\n roundToZero(): Vector2;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector2;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector2): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n\n /**\n * Computes Manhattan length of this vector.\n */\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector2;\n\n /**\n * Computes distance of this vector to v.\n */\n distanceTo(v: Vector2): number;\n\n /**\n * Computes squared distance of this vector to v.\n */\n distanceToSquared(v: Vector2): number;\n\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(l: number): Vector2;\n\n lerp(v: Vector2, alpha: number): Vector2;\n\n lerpVectors(v1: Vector2, v2: Vector2, alpha: number): Vector2;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector2): boolean;\n\n fromArray(xy: number[], offset?: number): Vector2;\n\n toArray(xy?: number[], offset?: number): number[];\n\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector2;\n\n rotateAround(center: Vector2, angle: number): Vector2;\n\n /**\n * Clones this vector.\n */\n clone(): Vector2;\n }\n\n /**\n * 3D vector.\n *\n * @example\n * var a = new THREE.Vector3( 1, 0, 0 );\n * var b = new THREE.Vector3( 0, 1, 0 );\n * var c = new THREE.Vector3();\n * c.crossVectors( a, b );\n *\n * @see src/math/Vector3.js\n *\n * ( class Vector3 implements Vector )\n */\n export class Vector3 implements Vector {\n\n constructor(x?: number, y?: number, z?: number);\n\n x: number;\n y: number;\n z: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number, z: number): Vector3;\n\n /**\n * Sets x value of this vector.\n */\n setX(x: number): Vector3;\n\n /**\n * Sets y value of this vector.\n */\n setY(y: number): Vector3;\n\n /**\n * Sets z value of this vector.\n */\n setZ(z: number): Vector3;\n\n setComponent(index: number, value: number): void;\n getComponent(index: number): number;\n\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector3): Vector3;\n\n /**\n * Adds v to this vector.\n */\n add(a: Vector3): Vector3;\n addScalar(s: number): Vector3;\n addScaledVector(v: Vector3, s: number): Vector3;\n\n /**\n * Sets this vector to a + b.\n */\n addVectors(a: Vector3, b: Vector3): Vector3;\n\n /**\n * Subtracts v from this vector.\n */\n sub(a: Vector3): Vector3;\n\n subScalar( s: number ): Vector3;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector3, b: Vector3): Vector3;\n\n multiply(v: Vector3): Vector3;\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(s: number): Vector3;\n multiplyVectors(a: Vector3, b: Vector3): Vector3;\n applyEuler(euler: Euler): Vector3;\n applyAxisAngle(axis: Vector3, angle: number): Vector3;\n applyMatrix3(m: Matrix3): Vector3;\n applyMatrix4(m: Matrix4): Vector3;\n applyProjection(m: Matrix4): Vector3;\n applyQuaternion(q: Quaternion): Vector3;\n project(camrea: Camera): Vector3;\n unproject(camera: Camera): Vector3;\n transformDirection(m: Matrix4): Vector3;\n divide(v: Vector3): Vector3;\n\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector3;\n min(v: Vector3): Vector3;\n max(v: Vector3): Vector3;\n clamp(min: Vector3, max: Vector3): Vector3;\n clampScalar(min: number, max: number): Vector3;\n clampLength(min: number, max: number): Vector3;\n floor(): Vector3;\n ceil(): Vector3;\n round(): Vector3;\n roundToZero(): Vector3;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector3;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector3): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n\n /**\n * Computes Manhattan length of this vector.\n * http://en.wikipedia.org/wiki/Taxicab_geometry\n */\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector3;\n\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(l: number): Vector3;\n lerp(v: Vector3, alpha: number): Vector3;\n\n lerpVectors(v1: Vector3, v2: Vector3, alpha: number): Vector3;\n\n /**\n * Sets this vector to cross product of itself and v.\n */\n cross(a: Vector3): Vector3;\n\n /**\n * Sets this vector to cross product of a and b.\n */\n crossVectors(a: Vector3, b: Vector3): Vector3;\n projectOnVector(v: Vector3): Vector3;\n projectOnPlane(planeNormal: Vector3): Vector3;\n reflect(vector: Vector3): Vector3;\n angleTo(v: Vector3): number;\n\n /**\n * Computes distance of this vector to v.\n */\n distanceTo(v: Vector3): number;\n\n /**\n * Computes squared distance of this vector to v.\n */\n distanceToSquared(v: Vector3): number;\n\n setFromMatrixPosition(m: Matrix4): Vector3;\n setFromMatrixScale(m: Matrix4): Vector3;\n setFromMatrixColumn(index: number, matrix: Matrix4): Vector3;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector3): boolean;\n\n fromArray(xyz: number[], offset?: number): Vector3;\n\n toArray(xyz?: number[], offset?: number): number[];\n\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector3;\n\n /**\n * Clones this vector.\n */\n clone(): Vector3;\n }\n\n /**\n * 4D vector.\n *\n * ( class Vector4 implements Vector )\n */\n export class Vector4 implements Vector {\n constructor(x?: number, y?: number, z?: number, w?: number);\n x: number;\n y: number;\n z: number;\n w: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number, z: number, w: number): Vector4;\n\n /**\n * Sets X component of this vector.\n */\n setX(x: number): Vector4;\n\n /**\n * Sets Y component of this vector.\n */\n setY(y: number): Vector4;\n\n /**\n * Sets Z component of this vector.\n */\n setZ(z: number): Vector4;\n\n /**\n * Sets w component of this vector.\n */\n setW(w: number): Vector4;\n\n setComponent(index: number, value: number): void;\n getComponent(index: number): number;\n\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector4): Vector4;\n\n /**\n * Adds v to this vector.\n */\n add(v: Vector4): Vector4;\n addScalar(s: number): Vector4;\n\n /**\n * Sets this vector to a + b.\n */\n addVectors(a: Vector4, b: Vector4): Vector4;\n addScaledVector(v: Vector4, s: number): Vector4;\n\n /**\n * Subtracts v from this vector.\n */\n sub(v: Vector4): Vector4;\n\n subScalar(s: number): Vector4;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector4, b: Vector4): Vector4;\n\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(s: number): Vector4;\n applyMatrix4(m: Matrix4): Vector4;\n\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector4;\n\n /**\n * http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm\n * @param q is assumed to be normalized\n */\n setAxisAngleFromQuaternion(q: Quaternion): Vector4;\n\n /**\n * http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm\n * @param m assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n */\n setAxisAngleFromRotationMatrix(m: Matrix3): Vector4;\n\n min(v: Vector4): Vector4;\n max(v: Vector4): Vector4;\n clamp(min: Vector4, max: Vector4): Vector4;\n clampScalar(min: number, max: number): Vector4;\n floor(): Vector4;\n ceil(): Vector4;\n round(): Vector4;\n roundToZero(): Vector4;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector4;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector4): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector4;\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(l: number): Vector4;\n\n /**\n * Linearly interpolate between this vector and v with alpha factor.\n */\n lerp(v: Vector4, alpha: number): Vector4;\n\n lerpVectors(v1: Vector4, v2: Vector4, alpha: number): Vector4;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector4): boolean;\n\n fromArray(xyzw: number[], offset?: number): Vector4;\n\n toArray(xyzw?: number[], offset?: number): number[];\n\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector4;\n\n /**\n * Clones this vector.\n */\n clone(): Vector4;\n }\n\n // Objects //////////////////////////////////////////////////////////////////////////////////\n\n export class Bone extends Object3D {\n constructor(skin: SkinnedMesh);\n\n skin: SkinnedMesh;\n }\n\n export class Group extends Object3D {\n constructor();\n }\n\n export interface LensFlareProperty {\n texture: Texture; // Texture\n size: number; // size in pixels (-1 = use texture.width)\n distance: number; // distance (0-1) from light source (0=at light source)\n x: number;\n y: number;\n z: number; // screen position (-1 => 1) z = 0 is ontop z = 1 is back\n scale: number; // scale\n rotation: number; // rotation\n opacity: number; // opacity\n color: Color; // color\n blending: Blending;\n }\n\n export class LensFlare extends Object3D {\n constructor(texture?: Texture, size?: number, distance?: number, blending?: Blending, color?: Color);\n\n lensFlares: LensFlareProperty[];\n positionScreen: Vector3;\n customUpdateCallback: (object: LensFlare) => void;\n\n add(texture: Texture, size?: number, distance?: number, blending?: Blending, color?: Color): void;\n add(obj: Object3D): void;\n\n\n updateLensFlares(): void;\n }\n\n export class Line extends Object3D {\n constructor(geometry?: Geometry, material?: LineDashedMaterial, mode?: number);\n constructor(geometry?: Geometry, material?: LineBasicMaterial, mode?: number);\n constructor(geometry?: Geometry, material?: ShaderMaterial, mode?: number);\n constructor(geometry?: BufferGeometry, material?: LineDashedMaterial, mode?: number);\n constructor(geometry?: BufferGeometry, material?: LineBasicMaterial, mode?: number);\n constructor(geometry?: BufferGeometry, material?: ShaderMaterial, mode?: number);\n\n geometry: Geometry|BufferGeometry;\n material: Material; // LineDashedMaterial or LineBasicMaterial or ShaderMaterial\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(object?: Line): Line;\n }\n\n export class LineSegments extends Line {\n constructor(geometry?: Geometry, material?: LineDashedMaterial);\n constructor(geometry?: Geometry, material?: LineBasicMaterial);\n constructor(geometry?: Geometry, material?: ShaderMaterial);\n constructor(geometry?: BufferGeometry, material?: LineDashedMaterial);\n constructor(geometry?: BufferGeometry, material?: LineBasicMaterial);\n constructor(geometry?: BufferGeometry, material?: ShaderMaterial);\n\n geometry: Geometry|BufferGeometry;\n material: Material; // LineDashedMaterial or LineBasicMaterial or ShaderMaterial\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(object?: LineSegments): LineSegments;\n }\n\n enum LineMode{}\n var LineStrip: LineMode;\n var LinePieces: LineMode;\n\n export class LOD extends Object3D {\n constructor();\n\n levels: any[];\n /** Deprecated, use levels instead */\n objects: any[];\n\n addLevel(object: Object3D, distance?: number): void;\n getObjectForDistance(distance: number): Object3D;\n raycast(raycaster: Raycaster, intersects: any): void;\n update(camera: Camera): void;\n clone(object?: LOD): LOD;\n }\n\n export class Mesh extends Object3D {\n constructor(geometry?: Geometry, material?: Material);\n constructor(geometry?: BufferGeometry, material?: Material);\n\n geometry: Geometry|BufferGeometry;\n material: Material;\n\n updateMorphTargets(): void;\n getMorphTargetIndexByName(name: string): number;\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(object?: Mesh): Mesh;\n }\n\n export class MorphAnimMesh extends Mesh {\n constructor(geometry?: Geometry, material?: MeshBasicMaterial);\n constructor(geometry?: Geometry, material?: MeshDepthMaterial);\n constructor(geometry?: Geometry, material?: MeshFaceMaterial);\n constructor(geometry?: Geometry, material?: MeshLambertMaterial);\n constructor(geometry?: Geometry, material?: MeshNormalMaterial);\n constructor(geometry?: Geometry, material?: MeshPhongMaterial);\n constructor(geometry?: Geometry, material?: ShaderMaterial);\n\n duration: number; // milliseconds\n mirroredLoop: boolean;\n time: number;\n lastKeyframe: number;\n currentKeyframe: number;\n direction: number;\n directionBackwards: boolean;\n\n startKeyframe: number;\n endKeyframe: number;\n length: number;\n\n setFrameRange(start: number, end: number): void;\n setDirectionForward(): void;\n setDirectionBackward(): void;\n parseAnimations(): void;\n setAnimationLabel(label: string, start: number, end: number): void;\n playAnimation(label: string, fps: number): void;\n updateAnimation(delta: number): void;\n interpolateTargets( a: number, b: number, t: number ): void;\n clone(object?: MorphAnimMesh): MorphAnimMesh;\n }\n\n /**\n * A class for displaying particles in the form of variable size points. For example, if using the WebGLRenderer, the particles are displayed using GL_POINTS.\n *\n * @see src/objects/ParticleSystem.js\n */\n export class PointCloud extends Object3D {\n\n /**\n * @param geometry An instance of Geometry.\n * @param material An instance of Material (optional).\n */\n constructor(geometry: Geometry, material?: PointCloudMaterial);\n constructor(geometry: Geometry, material?: ShaderMaterial);\n constructor(geometry: BufferGeometry, material?: PointCloudMaterial);\n constructor(geometry: BufferGeometry, material?: ShaderMaterial);\n\n /**\n * An instance of Geometry, where each vertex designates the position of a particle in the system.\n */\n geometry: Geometry;\n\n /**\n * An instance of Material, defining the object's appearance. Default is a ParticleBasicMaterial with randomised colour.\n */\n material: Material;\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(object?: PointCloud): PointCloud;\n }\n\n export class Skeleton {\n constructor(bones: Bone[], boneInverses?: Matrix4[], useVertexTexture?: boolean);\n\n useVertexTexture: boolean;\n identityMatrix: Matrix4;\n bones: Bone[];\n boneTextureWidth: number;\n boneTextureHeight: number;\n boneMatrices: Float32Array;\n boneTexture: DataTexture;\n boneInverses: Matrix4[];\n\n calculateInverses(bone: Bone): void;\n pose(): void;\n update(): void;\n clone(): Skeleton;\n }\n\n export class SkinnedMesh extends Mesh {\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshBasicMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshDepthMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshFaceMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshLambertMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshNormalMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshPhongMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: ShaderMaterial, useVertexTexture?: boolean);\n\n bindMode: string;\n bindMatrix: Matrix4;\n bindMatrixInverse: Matrix4;\n\n bind( skeleton: Skeleton, bindMatrix?: Matrix4 ): void;\n pose(): void;\n normalizeSkinWeights(): void;\n updateMatrixWorld(force?: boolean): void;\n clone(object?: SkinnedMesh): SkinnedMesh;\n\n skeleton: Skeleton;\n }\n\n export class Sprite extends Object3D {\n constructor(material?: Material);\n\n geometry: BufferGeometry;\n material: SpriteMaterial;\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(object?: Sprite): Sprite;\n }\n\n\n // Renderers //////////////////////////////////////////////////////////////////////////////////\n\n export interface Renderer {\n render(scene: Scene, camera: Camera): void;\n setSize(width:number, height:number, updateStyle?:boolean): void;\n domElement: HTMLCanvasElement;\n }\n\n export interface WebGLRendererParameters {\n /**\n * A Canvas where the renderer draws its output.\n */\n canvas?: HTMLCanvasElement;\n\n /**\n * shader precision. Can be \"highp\", \"mediump\" or \"lowp\".\n */\n precision?: string;\n\n /**\n * default is true.\n */\n alpha?: boolean;\n\n /**\n * default is true.\n */\n premultipliedAlpha?: boolean;\n\n /**\n * default is false.\n */\n antialias?: boolean;\n\n /**\n * default is true.\n */\n stencil?: boolean;\n\n /**\n * default is false.\n */\n preserveDrawingBuffer?: boolean;\n\n /**\n * default is 0x000000.\n */\n clearColor?: number;\n\n /**\n * default is 0.\n */\n clearAlpha?: number;\n\n devicePixelRatio?: number;\n }\n\n\n /**\n * The WebGL renderer displays your beautifully crafted scenes using WebGL, if your device supports it.\n * This renderer has way better performance than CanvasRenderer.\n *\n * @see src/renderers/WebGLRenderer.js\n */\n export class WebGLRenderer implements Renderer {\n /**\n * parameters is an optional object with properties defining the renderer's behaviour. The constructor also accepts no parameters at all. In all cases, it will assume sane defaults when parameters are missing.\n */\n constructor(parameters?: WebGLRendererParameters);\n\n /**\n * A Canvas where the renderer draws its output.\n * This is automatically created by the renderer in the constructor (if not provided already); you just need to add it to your page.\n */\n domElement: HTMLCanvasElement;\n\n /**\n * The HTML5 Canvas's 'webgl' context obtained from the canvas where the renderer will draw.\n */\n context: WebGLRenderingContext;\n\n /**\n * Defines whether the renderer should automatically clear its output before rendering.\n */\n autoClear: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the color buffer. Default is true.\n */\n autoClearColor: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the depth buffer. Default is true.\n */\n autoClearDepth: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the stencil buffer. Default is true.\n */\n autoClearStencil: boolean;\n\n /**\n * Defines whether the renderer should sort objects. Default is true.\n */\n sortObjects: boolean;\n\n extensions: WebGLExtensions;\n\n gammaFactor: number;\n\n /**\n * Default is false.\n */\n gammaInput: boolean;\n\n /**\n * Default is false.\n */\n gammaOutput: boolean;\n\n /**\n * Default is false.\n */\n shadowMapEnabled: boolean;\n\n /**\n * Defines shadow map type (unfiltered, percentage close filtering, percentage close filtering with bilinear filtering in shader)\n * Options are THREE.BasicShadowMap, THREE.PCFShadowMap, THREE.PCFSoftShadowMap. Default is THREE.PCFShadowMap.\n */\n shadowMapType: ShadowMapType;\n\n /**\n * Default is true\n */\n shadowMapCullFace: CullFace;\n\n /**\n * Default is false.\n */\n shadowMapDebug: boolean;\n\n /**\n * Default is 8.\n */\n maxMorphTargets: number;\n\n /**\n * Default is 4.\n */\n maxMorphNormals: number;\n\n /**\n * Default is true.\n */\n autoScaleCubemaps: boolean;\n\n /**\n * An object with a series of statistical information about the graphics board memory and the rendering process. Useful for debugging or just for the sake of curiosity. The object contains the following fields:\n */\n info: {\n memory: {\n programs: number;\n geometries: number;\n textures: number;\n };\n render: {\n calls: number;\n vertices: number;\n faces: number;\n points: number;\n };\n };\n\n shadowMap: WebGLShadowMap;\n\n /**\n * Return the WebGL context.\n */\n getContext(): WebGLRenderingContext;\n\n forceContextLoss(): void;\n\n capabilities: WebGLCapabilities;\n\n /** Deprecated, use capabilities instead */\n supportsVertexTextures(): boolean;\n supportsFloatTextures(): boolean;\n supportsStandardDerivatives(): boolean;\n supportsCompressedTextureS3TC(): boolean;\n supportsCompressedTexturePVRTC(): boolean;\n supportsBlendMinMax(): boolean;\n getPrecision(): string;\n\n getMaxAnisotropy(): number;\n getPixelRatio(): number;\n setPixelRatio(value: number): void;\n \n getSize(): { width: number; height: number; };\n\n /**\n * Resizes the output canvas to (width, height), and also sets the viewport to fit that size, starting in (0, 0).\n */\n setSize(width: number, height: number, updateStyle?: boolean): void;\n\n /**\n * Sets the viewport to render from (x, y) to (x + width, y + height).\n */\n setViewport(x?: number, y?: number, width?: number, height?: number): void;\n\n /**\n * Sets the scissor area from (x, y) to (x + width, y + height).\n */\n setScissor(x: number, y: number, width: number, height: number): void;\n\n /**\n * Enable the scissor test. When this is enabled, only the pixels within the defined scissor area will be affected by further renderer actions.\n */\n enableScissorTest(enable: boolean): void;\n\n /**\n * Sets the clear color, using color for the color and alpha for the opacity.\n */\n setClearColor(color: Color, alpha?: number): void;\n setClearColor(color: string, alpha?: number): void;\n setClearColor(color: number, alpha?: number): void;\n\n setClearAlpha(alpha: number): void;\n\n /**\n * Sets the clear color, using hex for the color and alpha for the opacity.\n *\n * @example\n * // Creates a renderer with black background\n * var renderer = new THREE.WebGLRenderer();\n * renderer.setSize(200, 100);\n * renderer.setClearColorHex(0x000000, 1);\n */\n setClearColorHex(hex: number, alpha: number): void;\n\n /**\n * Returns a THREE.Color instance with the current clear color.\n */\n getClearColor(): Color;\n\n /**\n * Returns a float with the current clear alpha. Ranges from 0 to 1.\n */\n getClearAlpha(): number;\n\n /**\n * Tells the renderer to clear its color, depth or stencil drawing buffer(s).\n * If no parameters are passed, no buffer will be cleared.\n */\n clear(color?: boolean, depth?: boolean, stencil?: boolean): void;\n\n clearColor(): void;\n clearDepth(): void;\n clearStencil(): void;\n clearTarget(renderTarget:WebGLRenderTarget, color: boolean, depth: boolean, stencil: boolean): void;\n resetGLState(): void;\n dispose(): void;\n\n /**\n * Tells the shadow map plugin to update using the passed scene and camera parameters.\n *\n * @param scene an instance of Scene\n * @param camera — an instance of Camera\n */\n updateShadowMap(scene: Scene, camera: Camera): void;\n\n renderBufferImmediate(object: Object3D, program: Object, material: Material): void;\n\n renderBufferDirect(camera: Camera, lights: Light[], fog: Fog, material: Material, geometryGroup: any, object: Object3D): void;\n\n renderBuffer(camera: Camera, lights: Light[], fog: Fog, material: Material, geometryGroup: any, object: Object3D): void;\n\n /**\n * Render a scene using a camera.\n * The render is done to the renderTarget (if specified) or to the canvas as usual.\n * If forceClear is true, the canvas will be cleared before rendering, even if the renderer's autoClear property is false.\n */\n render(scene: Scene, camera: Camera, renderTarget?: RenderTarget, forceClear?: boolean): void;\n renderImmediateObject(camera: Camera, lights: Light[], fog: Fog, material: Material, object: Object3D): void;\n\n /**\n * Used for setting the gl frontFace, cullFace states in the GPU, thus enabling/disabling face culling when rendering.\n * If cullFace is false, culling will be disabled.\n * @param cullFace \"back\", \"front\", \"front_and_back\", or false.\n * @param frontFace \"ccw\" or \"cw\n */\n setFaceCulling(cullFace?: CullFace, frontFace?: FrontFaceDirection): void;\n setMaterialFaces(material: Material): void;\n setDepthTest(depthTest: boolean): void;\n setDepthWrite(depthWrite: boolean): void;\n setBlending(blending: Blending, blendEquation: BlendingEquation, blendSrc: BlendingSrcFactor, blendDst: BlendingDstFactor): void;\n uploadTexture(texture: Texture): void;\n setTexture(texture: Texture, slot: number): void;\n setRenderTarget(renderTarget: RenderTarget): void;\n readRenderTargetPixels( renderTarget: RenderTarget, x: number, y: number, width: number, height: number, buffer: any ): void;\n }\n \n export interface WebGLCapabilities {\n getMaxPrecision(precision: string): string;\n precision: string;\n logarithmicDepthBuffer: boolean;\n maxTextures: number;\n maxVertexTextures: number;\n maxTextureSize: number;\n maxCubemapSize: number;\n maxAttributes: number;\n maxVertexUniforms: number;\n maxVaryings: number;\n maxFragmentUniforms: number;\n vertexTextures: boolean;\n floatFragmentTextures: boolean;\n floatVertexTextures: boolean;\n }\n \n export interface RenderTarget {\n }\n\n export interface WebGLRenderTargetOptions {\n wrapS?: Wrapping;\n wrapT?: Wrapping;\n magFilter?: TextureFilter;\n minFilter?: TextureFilter;\n anisotropy?: number; // 1;\n format?: number; // RGBAFormat;\n type?: TextureDataType; // UnsignedByteType;\n depthBuffer?: boolean; // true;\n stencilBuffer?: boolean; // true;\n }\n\n export class WebGLRenderTarget implements RenderTarget {\n constructor(width: number, height: number, options?: WebGLRenderTargetOptions);\n\n width: number;\n height: number;\n wrapS: Wrapping;\n wrapT: Wrapping;\n magFilter: TextureFilter;\n minFilter: TextureFilter;\n anisotropy: number;\n offset: Vector2;\n repeat: Vector2;\n format: number;\n type: number;\n depthBuffer: boolean;\n stencilBuffer: boolean;\n generateMipmaps: boolean;\n shareDepthFrom: any;\n\n setSize(width: number, height: number): void;\n clone(): WebGLRenderTarget;\n dispose(): void;\n\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n export class WebGLRenderTargetCube extends WebGLRenderTarget {\n constructor(width: number, height: number, options?: WebGLRenderTargetOptions);\n\n activeCubeFace: number; // PX 0, NX 1, PY 2, NY 3, PZ 4, NZ 5\n }\n\n // Renderers / Shaders /////////////////////////////////////////////////////////////////////\n export interface ShaderChunk {\n [name: string]: string;\n\n common: string;\n alphamap_fragment: string;\n alphamap_pars_fragment: string;\n alphatest_fragment: string;\n bumpmap_pars_fragment: string;\n color_fragment: string;\n color_pars_fragment: string;\n color_pars_vertex: string;\n color_vertex: string;\n default_vertex: string;\n defaultnormal_vertex: string;\n envmap_fragment: string;\n envmap_pars_fragment: string;\n envmap_pars_vertex: string;\n envmap_vertex: string;\n fog_fragment: string;\n fog_pars_fragment: string;\n\n lightmap_fragment: string;\n lightmap_pars_fragment: string;\n lightmap_pars_vertex: string;\n lightmap_vertex: string;\n lights_lambert_pars_vertex: string;\n lights_lambert_vertex: string;\n lights_phong_fragment: string;\n lights_phong_pars_fragment: string;\n lights_phong_pars_vertex: string;\n lights_phong_vertex: string;\n linear_to_gamma_fragment: string;\n logdepthbuf_fragment: string;\n logdepthbuf_pars_fragment: string;\n logdepthbuf_pars_vertex: string;\n logdepthbuf_vertex: string;\n map_fragment: string;\n map_pars_fragment: string;\n map_pars_vertex: string;\n map_particle_fragment: string;\n map_particle_pars_fragment: string;\n map_vertex: string;\n morphnormal_vertex: string;\n morphtarget_pars_vertex: string;\n morphtarget_vertex: string;\n normalmap_pars_fragment: string;\n shadowmap_fragment: string;\n shadowmap_pars_fragment: string;\n shadowmap_pars_vertex: string;\n shadowmap_vertex: string;\n skinbase_vertex: string;\n skinning_pars_vertex: string;\n skinning_vertex: string;\n skinnormal_vertex: string;\n specularmap_fragment: string;\n specularmap_pars_fragment: string;\n worldpos_vertex: string;\n }\n\n export var ShaderChunk: ShaderChunk;\n\n export interface Shader {\n uniforms: any;\n vertexShader: string;\n fragmentShader: string;\n }\n\n export var ShaderLib: {\n [name: string]: Shader;\n basic: Shader;\n lambert: Shader;\n phong: Shader;\n particle_basic: Shader;\n dashed: Shader;\n depth: Shader;\n normal: Shader;\n normalmap: Shader;\n cube: Shader;\n equirect: Shader;\n depthRGBA: Shader;\n };\n\n export var UniformsLib: {\n common: any;\n bump: any;\n normalmap: any;\n fog: any;\n lights: any;\n particle: any;\n shadowmap: any;\n };\n\n export var UniformsUtils: {\n merge(uniforms: any[]): any;\n clone(uniforms_src: any): any;\n };\n\n // Renderers / WebGL /////////////////////////////////////////////////////////////////////\n export class WebGLExtensions {\n constructor(gl: WebGLRenderingContext);\n\n get(name: string): any;\n }\n\n export class WebGLProgram {\n constructor(renderer: WebGLRenderer, code: string, material: ShaderMaterial, parameters: WebGLRendererParameters);\n \n getUniforms(): any;\n getAttributes(): any;\n\n /** Deprecated, use getUniforms */\n uniforms: any;\n /** Deprecated, use getAttributes */\n attributes: any;\n\n id: number;\n code: string;\n usedTimes: number;\n program: any;\n vertexShader: WebGLShader;\n fragmentShader: WebGLShader;\n }\n\n export class WebGLShader {\n constructor(gl: WebGLRenderingContext, type: string, string: string);\n }\n\n interface WebGLStateInstance {\n new(gl: WebGLRenderingContext, paramThreeToGL: Function): void;\n initAttributes(): void;\n enableAttribute(attribute: string): void;\n disableUnusedAttributes(): void;\n setBlending(blending: number, blendEquation: number, blendSrc: number, blendDst: number, blendEquationAlpha: number, blendSrcAlpha: number, blendDstAlpha: number): void;\n setDepthTest(depthTest: number): void;\n setDepthWrite(depthWrite: number): void;\n setColorWrite(colorWrite: number): void;\n setDoubleSided(doubleSided: number): void;\n setFlipSided(flipSided: number): void;\n setLineWidth(width: number): void;\n setPolygonOffset(polygonoffset: number, factor: number, units: number): void;\n reset(): void;\n }\n interface WebGLStateStatic {\n (gl: WebGLRenderingContext, paramThreeToGL: Function): WebGLStateInstance;\n }\n export var WebGLState: WebGLStateStatic;\n\n\n interface WebGLTexturesInstance{\n new (webgglcontext: any): WebGLTexturesInstance;\n\n get(texture: Texture): any; // it will return result of gl.createTexture().\n create(texture: Texture): any; // it will return result of gl.createTexture().\n delete(texture: Texture): void;\n }\n interface WebGLTexturesStatic{\n (webgglcontext: any): WebGLTexturesInstance;\n }\n export var WebGLTextures: WebGLTexturesStatic;\n\n\n // Renderers / WebGL / Plugins /////////////////////////////////////////////////////////////////////\n export interface RendererPlugin {\n init(renderer: WebGLRenderer): void;\n render(scene: Scene, camera: Camera, currentWidth: number, currentHeight: number): void;\n }\n\n export class LensFlarePlugin implements RendererPlugin {\n constructor();\n\n init(renderer: Renderer): void;\n render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void;\n }\n\n export class WebGLShadowMap implements RendererPlugin {\n constructor();\n\n enabled: boolean;\n type: ShadowMapType;\n cullFace: CullFace;\n\n init(renderer: Renderer): void;\n render(scene: Scene, camera: Camera): void;\n update(scene: Scene, camera: Camera): void;\n }\n\n export class SpritePlugin implements RendererPlugin {\n constructor();\n\n init(renderer: Renderer): void;\n render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void;\n }\n\n // Scenes /////////////////////////////////////////////////////////////////////\n\n export interface IFog {\n name:string;\n color: Color;\n clone():IFog;\n }\n\n\n /**\n * This class contains the parameters that define linear fog, i.e., that grows linearly denser with the distance.\n */\n export class Fog implements IFog {\n constructor(hex: number, near?: number, far?: number);\n\n name:string;\n\n /**\n * Fog color.\n */\n color: Color;\n\n /**\n * The minimum distance to start applying fog. Objects that are less than 'near' units from the active camera won't be affected by fog.\n */\n near: number;\n\n /**\n * The maximum distance at which fog stops being calculated and applied. Objects that are more than 'far' units away from the active camera won't be affected by fog.\n * Default is 1000.\n */\n far: number;\n\n clone(): Fog;\n }\n\n /**\n * This class contains the parameters that define linear fog, i.e., that grows exponentially denser with the distance.\n */\n export class FogExp2 implements IFog {\n constructor(hex: number, density?: number);\n\n name: string;\n color: Color;\n\n /**\n * Defines how fast the fog will grow dense.\n * Default is 0.00025.\n */\n density: number;\n\n clone(): FogExp2;\n }\n\n /**\n * Scenes allow you to set up what and where is to be rendered by three.js. This is where you place objects, lights and cameras.\n */\n export class Scene extends Object3D {\n constructor();\n\n /**\n * A fog instance defining the type of fog that affects everything rendered in the scene. Default is null.\n */\n fog: IFog;\n\n /**\n * If not null, it will force everything in the scene to be rendered with that material. Default is null.\n */\n overrideMaterial: Material;\n autoUpdate: boolean;\n\n clone(): Scene;\n }\n\n // Textures /////////////////////////////////////////////////////////////////////\n export class CanvasTexture extends Texture {\n constructor(\n canvas?: HTMLCanvasElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n }\n\n export class CompressedTexture extends Texture {\n constructor(\n mipmaps: ImageData[],\n width: number,\n height: number,\n format?: PixelFormat,\n type?: TextureDataType,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n anisotropy?: number\n );\n\n image: { width: number; height: number; };\n mipmaps: ImageData[];\n flipY: boolean;\n generateMipmaps: boolean;\n\n clone(): CompressedTexture;\n }\n\n export class CubeTexture extends Texture {\n constructor(\n images: any[], // HTMLImageElement or HTMLCanvasElement\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n\n images: any[];\n\n clone(texture?: CubeTexture): CubeTexture;\n }\n\n export class DataTexture extends Texture {\n constructor(\n data: ImageData,\n width: number,\n height: number,\n format: PixelFormat,\n type: TextureDataType,\n mapping: Mapping,\n wrapS: Wrapping,\n wrapT: Wrapping,\n magFilter: TextureFilter,\n minFilter: TextureFilter,\n anisotropy?: number\n );\n\n image: { data: ImageData; width: number; height: number; };\n\n clone(): DataTexture;\n }\n\n export class Texture {\n constructor(\n image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n\n id: number;\n uuid: string;\n name: string;\n sourceFile: string;\n image: any; // HTMLImageElement or ImageData ;\n mipmaps: ImageData[];\n mapping: Mapping;\n wrapS: Wrapping;\n wrapT: Wrapping;\n magFilter: TextureFilter;\n minFilter: TextureFilter;\n anisotropy: number;\n format: PixelFormat;\n type: TextureDataType;\n offset: Vector2;\n repeat: Vector2;\n generateMipmaps: boolean;\n premultiplyAlpha: boolean;\n flipY: boolean;\n unpackAlignment: number;\n needsUpdate: boolean;\n onUpdate: () => void;\n static DEFAULT_IMAGE: any;\n static DEFAULT_MAPPING: any;\n\n clone(): Texture;\n update(): void;\n toJSON(): any;\n dispose(): void;\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: any) => void ): void;\n hasEventListener(type: string, listener: (event: any) => void): void;\n removeEventListener(type: string, listener: (event: any) => void): void;\n dispatchEvent(event: { type: string; target: any; }): void;\n }\n\n class VideoTexture extends Texture {\n constructor(\n video: HTMLVideoElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n\n generateMipmaps: boolean;\n }\n\n // Extras /////////////////////////////////////////////////////////////////////\n\n export interface TypefaceData {\n familyName: string;\n cssFontWeight: string;\n cssFontStyle: string;\n }\n\n export var FontUtils: {\n faces: { [weight: string]: { [style: string]: Face3; }; };\n face: string;\n weight: string;\n style: string;\n size: number;\n divisions: number;\n\n getFace(): Face3;\n loadFace(data: TypefaceData): TypefaceData;\n drawText(text: string): { paths: Path[]; offset: number; };\n extractGlyphPoints(c: string, face: Face3, scale: number, offset: number, path: Path): { offset: number; path: Path; };\n\n generateShapes(text: string, parameters?: { size?: number; curveSegments?: number; font?: string; weight?: string; style?: string; }): Shape[];\n Triangulate: {\n (contour: Vector2[], indices: boolean): Vector2[];\n area(contour: Vector2[]): number;\n };\n };\n\n export var GeometryUtils: {\n // DEPRECATED\n merge(geometry1: Geometry, object2: Mesh, materialIndexOffset?: number): void;\n\n // DEPRECATED\n merge(geometry1: Geometry, object2: Geometry, materialIndexOffset?: number): void;\n\n // DEPRECATED\n center(geometry: Geometry): Vector3;\n };\n\n export var ImageUtils: {\n crossOrigin: string;\n\n loadTexture(url: string, mapping?: Mapping, onLoad?: (texture: Texture) => void, onError?: (message: string) => void): Texture;\n loadTextureCube(array: string[], mapping?: Mapping, onLoad?: (texture: Texture) => void , onError?: (message: string) => void ): Texture;\n getNormalMap(image: HTMLImageElement, depth?: number): HTMLCanvasElement;\n generateDataTexture(width: number, height: number, color: Color): DataTexture;\n };\n\n export var SceneUtils: {\n createMultiMaterialObject(geometry: Geometry, materials: Material[]): Object3D;\n detach(child: Object3D, parent: Object3D, scene: Scene): void;\n attach(child: Object3D, scene: Scene, parent: Object3D): void;\n };\n\n // Extras / Animation /////////////////////////////////////////////////////////////////////\n\n export interface KeyFrame {\n pos: number[];\n rot: number[];\n scl: number[];\n time: number;\n }\n\n export interface KeyFrames {\n keys: KeyFrame[];\n parent: number;\n }\n\n export interface AnimationData {\n JIT: number;\n fps: number;\n hierarchy: KeyFrames[];\n length: number;\n name: string;\n }\n\n export class Animation {\n constructor(root: Mesh, data: AnimationData);\n\n root: Mesh;\n data: AnimationData;\n hierarchy: Bone[];\n currentTime: number;\n timeScale: number;\n isPlaying: boolean;\n loop: boolean;\n weight: number;\n interpolationType: number;\n\n play(startTime?: number, weight?: number): void;\n stop(): void;\n reset(): void;\n resetBlendWeights(): void;\n update(delta: number): void;\n getNextKeyWith(type: string, h: number, key: number): KeyFrame;\n getPrevKeyWith(type: string, h: number, key: number): KeyFrame;\n }\n\n export var AnimationHandler: {\n LINEAR: number;\n CATMULLROM: number;\n CATMULLROM_FORWARD: number;\n\n animations: any[];\n\n init(data: AnimationData): AnimationData;\n parse(root: Mesh): Object3D[];\n play(animation: Animation): void;\n stop(animation: Animation): void;\n update(deltaTimeMS: number): void;\n };\n\n export class KeyFrameAnimation {\n constructor(data: any);\n\n root: Mesh;\n data: AnimationData;\n hierarchy: KeyFrames[];\n currentTime: number;\n timeScale: number;\n isPlaying: boolean;\n isPaused: boolean;\n loop: boolean;\n\n play(startTime?: number): void;\n stop(): void;\n update(delta: number): void;\n getNextKeyWith(type: string, h: number, key: number): KeyFrame;\n getPrevKeyWith(type: string, h: number, key: number): KeyFrame;\n }\n\n export class MorphAnimation {\n constructor(mesh: Mesh);\n\n mesh: Mesh;\n frames: number;\n currentTime: number;\n duration: number;\n loop: boolean;\n lastFrame: number;\n currentFrame: number;\n isPlaying: boolean;\n\n play(): void;\n pause(): void;\n update(delta: number): void;\n }\n\n // Extras / Audio /////////////////////////////////////////////////////////////////////\n\n export class Audio extends Object3D {\n constructor(listener: AudioListener);\n type: string;\n context: AudioContext;\n source: AudioBufferSourceNode;\n gain: GainNode;\n panner: PannerNode;\n autoplay: boolean;\n startTime: number;\n isPlaying: boolean;\n\n load(file: string): Audio;\n play(): void;\n pause(): void;\n stop(): void;\n setLoop(value: boolean): void;\n setRefDistance(value: number): void;\n setRolloffFactor(value: number): void;\n setVolume(value: number): void;\n updateMatrixWorld(force?: boolean): void;\n }\n\n export class AudioListener extends Object3D {\n constructor();\n\n type: string;\n context: AudioContext;\n\n updateMatrixWorld(force?: boolean): void;\n }\n\n // Extras / Core /////////////////////////////////////////////////////////////////////\n\n /**\n * An extensible curve object which contains methods for interpolation\n * class Curve<T extends Vector>\n */\n export class Curve {\n /**\n * Returns a vector for point t of the curve where t is between 0 and 1\n * getPoint(t: number): T;\n */\n getPoint(t: number): T;\n\n /**\n * Returns a vector for point at relative position in curve according to arc length\n * getPointAt(u: number): T;\n */\n getPointAt(u: number):T;\n\n /**\n * Get sequence of points using getPoint( t )\n * getPoints(divisions?: number): T[];\n */\n getPoints(divisions?: number): T[];\n\n /**\n * Get sequence of equi-spaced points using getPointAt( u )\n * getSpacedPoints(divisions?: number): T[];\n */\n getSpacedPoints(divisions?: number): T[];\n\n /**\n * Get total curve arc length\n */\n getLength(): number;\n\n /**\n * Get list of cumulative segment lengths\n */\n getLengths(divisions?: number): number[];\n\n /**\n * Update the cumlative segment distance cache\n */\n updateArcLengths(): void;\n\n /**\n * Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equi distance\n */\n getUtoTmapping(u: number, distance: number): number;\n\n /**\n * Returns a unit vector tangent at t. If the subclassed curve do not implement its tangent derivation, 2 points a small delta apart will be used to find its gradient which seems to give a reasonable approximation\n * getTangent(t: number): T;\n */\n getTangent(t: number): T;\n\n /**\n * Returns tangent at equidistance point u on the curve\n * getTangentAt(u: number): T;\n */\n getTangentAt(u: number): T;\n\n static create(constructorFunc: Function, getPointFunc: Function): Function;\n }\n\n export var CurveUtils: {\n tangentQuadraticBezier(t: number, p0: number, p1: number, p2: number): number;\n tangentCubicBezier(t: number, p0: number, p1: number, p2: number, p3: number): number;\n tangentSpline(t: number, p0: number, p1: number, p2: number, p3: number): number;\n interpolate(p0: number, p1: number, p2: number, p3: number, t: number): number;\n };\n\n export interface BoundingBox {\n minX: number;\n minY: number;\n minZ?: number;\n maxX: number;\n maxY: number;\n maxZ?: number;\n }\n\n export class CurvePath extends Curve {\n constructor();\n\n curves: Curve[];\n bends: Path[];\n autoClose: boolean;\n\n add(curve: Curve): void;\n checkConnection(): boolean;\n closePath(): void;\n getLength(): number;\n getCurveLengths(): number[];\n getBoundingBox(): BoundingBox;\n createPointsGeometry(divisions: number): Geometry;\n createSpacedPointsGeometry(divisions: number): Geometry;\n createGeometry(points: T[]): Geometry;\n addWrapPath(bendpath: Path): void;\n getTransformedPoints(segments: number, bends?: Path[]): T[];\n getTransformedSpacedPoints(segments: number, bends?: Path[]): T[];\n getWrapPoints(oldPts: T[], path: Path): T[];\n }\n\n export class Gyroscope extends Object3D {\n constructor();\n\n updateMatrixWorld(force?: boolean): void;\n }\n\n export enum PathActions {\n MOVE_TO,\n LINE_TO,\n QUADRATIC_CURVE_TO, // Bezier quadratic curve\n BEZIER_CURVE_TO, // Bezier cubic curve\n CSPLINE_THRU, // Catmull-rom spline\n ARC, // Circle\n ELLIPSE,\n }\n\n export interface PathAction {\n action: PathActions;\n args: any;\n }\n\n /**\n * a 2d path representation, comprising of points, lines, and cubes, similar to the html5 2d canvas api. It extends CurvePath.\n */\n export class Path extends CurvePath {\n constructor(points?: Vector2[]);\n\n actions: PathAction[];\n\n fromPoints(vectors: Vector2[]): void;\n moveTo(x: number, y: number): void;\n lineTo(x: number, y: number): void;\n quadraticCurveTo(aCPx: number, aCPy: number, aX: number, aY: number): void;\n bezierCurveTo(aCP1x: number, aCP1y: number, aCP2x: number, aCP2y: number, aX: number, aY: number): void;\n splineThru(pts: Vector2[]): void;\n arc(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean): void;\n absarc(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean): void;\n ellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void;\n absellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void;\n getSpacedPoints(divisions?: number, closedPath?: boolean): Vector2[];\n getPoints(divisions?: number, closedPath?: boolean): Vector2[];\n toShapes(): Shape[];\n }\n\n /**\n * Defines a 2d shape plane using paths.\n */\n export class Shape extends Path {\n constructor(points?: Vector2[]);\n\n holes: Path[];\n\n extrude(options?: any): ExtrudeGeometry;\n makeGeometry(options?: any): ShapeGeometry;\n getPointsHoles(divisions: number): Vector2[][];\n getSpacedPointsHoles(divisions: number): Vector2[][];\n extractAllPoints(divisions: number): {\n shape: Vector2[];\n holes: Vector2[][];\n };\n extractPoints(divisions: number): Vector2[];\n extractAllSpacedPoints(divisions: Vector2): {\n shape: Vector2[];\n holes: Vector2[][];\n };\n\n }\n\n // Extras / Curves /////////////////////////////////////////////////////////////////////\n export class ArcCurve extends EllipseCurve {\n constructor(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number);\n }\n\n export class CatmullRomCurve3 extends Curve {\n constructor(points?: Vector3[]);\n\n points: Vector3[];\n }\n\n export class ClosedSplineCurve3 extends Curve {\n constructor(points?: Vector3[]);\n\n points: Vector3[];\n }\n\n export class CubicBezierCurve extends Curve {\n constructor(v0: Vector2, v1: Vector2, v2: Vector2, v3: Vector2);\n\n v0: Vector2;\n v1: Vector2;\n v2: Vector2;\n v3: Vector2;\n }\n export class CubicBezierCurve3 extends Curve {\n constructor(v0: Vector3, v1: Vector3, v2: Vector3, v3: Vector3);\n\n v0: Vector3;\n v1: Vector3;\n v2: Vector3;\n v3: Vector3;\n }\n export class EllipseCurve extends Curve {\n constructor(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number);\n\n aX: number;\n aY: number;\n xRadius: number;\n yRadius: number;\n aStartAngle: number;\n aEndAngle: number;\n aClockwise: boolean;\n aRotation: number;\n }\n export class LineCurve extends Curve {\n constructor( v1: Vector2, v2: Vector2 );\n\n v1: Vector2;\n v2: Vector2;\n\n }\n export class LineCurve3 extends Curve {\n constructor( v1: Vector3, v2: Vector3 );\n\n v1: Vector3;\n v2: Vector3;\n }\n export class QuadraticBezierCurve extends Curve {\n constructor( v0: Vector2, v1: Vector2, v2: Vector2 );\n\n v0: Vector2;\n v1: Vector2;\n v2: Vector2;\n }\n export class QuadraticBezierCurve3 extends Curve {\n constructor( v0: Vector3, v1: Vector3, v2: Vector3 );\n\n v0: Vector3;\n v1: Vector3;\n v2: Vector3;\n }\n export class SplineCurve extends Curve {\n constructor( points?: Vector2[] );\n\n points:Vector2[];\n }\n export class SplineCurve3 extends Curve {\n constructor( points?: Vector3[] );\n\n points:Vector3[];\n }\n\n // Extras / Geomerties /////////////////////////////////////////////////////////////////////\n /**\n * BoxGeometry is the quadrilateral primitive geometry class. It is typically used for creating a cube or irregular quadrilateral of the dimensions provided within the (optional) 'width', 'height', & 'depth' constructor arguments.\n */\n export class BoxGeometry extends Geometry {\n /**\n * @param width — Width of the sides on the X axis.\n * @param height — Height of the sides on the Y axis.\n * @param depth — Depth of the sides on the Z axis.\n * @param widthSegments — Number of segmented faces along the width of the sides.\n * @param heightSegments — Number of segmented faces along the height of the sides.\n * @param depthSegments — Number of segmented faces along the depth of the sides.\n */\n constructor(width: number, height: number, depth: number, widthSegments?: number, heightSegments?: number, depthSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n depth: number;\n widthSegments: number;\n heightSegments: number;\n depthSegments: number;\n };\n }\n\n export class CircleBufferGeometry extends BufferGeometry {\n constructor(radius?: number, segments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n segments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class CircleGeometry extends Geometry {\n constructor(radius?: number, segments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n segments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n // deprecated\n export class CubeGeometry extends BoxGeometry {\n }\n\n export class CylinderGeometry extends Geometry {\n /**\n * @param radiusTop — Radius of the cylinder at the top.\n * @param radiusBottom — Radius of the cylinder at the bottom.\n * @param height — Height of the cylinder.\n * @param radiusSegments — Number of segmented faces around the circumference of the cylinder.\n * @param heightSegments — Number of rows of faces along the height of the cylinder.\n * @param openEnded - A Boolean indicating whether or not to cap the ends of the cylinder.\n */\n constructor(radiusTop?: number, radiusBottom?: number, height?: number, radiusSegments?: number, heightSegments?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radiusTop: number;\n radiusBottom: number;\n height: number;\n radialSegments: number;\n heightSegments: number;\n openEnded: boolean;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class DodecahedronGeometry extends Geometry {\n constructor(radius: number, detail: number);\n\n parameters: {\n radius: number;\n detail: number;\n };\n }\n\n export class EdgesGeometry extends BufferGeometry {\n constructor(geometry: Geometry|BufferGeometry, thresholdAngle?: number);\n }\n\n export class ExtrudeGeometry extends Geometry {\n constructor(shape?: Shape, options?: any);\n constructor(shapes?: Shape[], options?: any);\n\n WorldUVGenerator: {\n generateTopUV(geometry: Geometry, indexA: number, indexB: number, indexC: number): Vector2[];\n generateSideWallUV(geometry: Geometry, indexA: number, indexB: number, indexC: number, indexD: number): Vector2[];\n };\n\n addShapeList(shapes: Shape[], options?: any): void;\n addShape(shape: Shape, options?: any): void;\n }\n\n export class IcosahedronGeometry extends PolyhedronGeometry {\n constructor(radius: number, detail: number);\n }\n\n export class LatheGeometry extends Geometry {\n constructor(points: Vector3[], segments?: number, phiStart?: number, phiLength?: number);\n\n parameters: {\n points: Vector3[];\n segments: number;\n phiStart: number;\n phiLength: number;\n };\n }\n\n export class OctahedronGeometry extends PolyhedronGeometry {\n constructor(radius: number, detail: number);\n }\n\n export class ParametricGeometry extends Geometry {\n constructor(func: (u: number, v: number) => Vector3, slices: number, stacks: number);\n\n parameters: {\n func: (u: number, v: number) => Vector3;\n slices: number;\n stacks: number;\n };\n }\n\n export class PlaneBufferGeometry extends BufferGeometry {\n constructor(width: number, height: number, widthSegments?: number, heightSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n widthSegments: number;\n heightSegments: number;\n };\n }\n\n export class PlaneGeometry extends Geometry {\n constructor(width: number, height: number, widthSegments?: number, heightSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n widthSegments: number;\n heightSegments: number;\n };\n }\n\n export class PolyhedronGeometry extends Geometry {\n constructor(vertices: Vector3[], faces: Face3[], radius?: number, detail?: number);\n\n parameters: {\n vertices: Vector3[];\n faces: Face3[];\n radius: number;\n detail: number;\n };\n }\n\n export class RingGeometry extends Geometry {\n constructor(innerRadius?: number, outerRadius?: number, thetaSegments?: number, phiSegments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n innerRadius: number;\n outerRadius: number;\n thetaSegments: number;\n phiSegments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class ShapeGeometry extends Geometry {\n constructor(shape: Shape, options?: any);\n constructor(shapes: Shape[], options?: any);\n\n\n addShapeList(shapes: Shape[], options: any): ShapeGeometry;\n addShape(shape: Shape, options?: any): void;\n }\n\n interface SphereParameters {\n radius: number;\n widthSegments: number;\n heightSegments: number;\n phiStart: number;\n phiLength: number;\n thetaStart: number;\n thetaLength: number;\n }\n\n export class SphereBufferGeometry extends BufferGeometry {\n constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: SphereParameters;\n\n }\n\n /**\n * A class for generating sphere geometries\n */\n export class SphereGeometry extends Geometry {\n /**\n * The geometry is created by sweeping and calculating vertexes around the Y axis (horizontal sweep) and the Z axis (vertical sweep). Thus, incomplete spheres (akin to 'sphere slices') can be created through the use of different values of phiStart, phiLength, thetaStart and thetaLength, in order to define the points in which we start (or end) calculating those vertices.\n *\n * @param radius — sphere radius. Default is 50.\n * @param widthSegments — number of horizontal segments. Minimum value is 3, and the default is 8.\n * @param heightSegments — number of vertical segments. Minimum value is 2, and the default is 6.\n * @param phiStart — specify horizontal starting angle. Default is 0.\n * @param phiLength — specify horizontal sweep angle size. Default is Math.PI * 2.\n * @param thetaStart — specify vertical starting angle. Default is 0.\n * @param thetaLength — specify vertical sweep angle size. Default is Math.PI.\n */\n constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: SphereParameters;\n }\n\n export class TetrahedronGeometry extends PolyhedronGeometry {\n constructor(radius?: number, detail?: number);\n }\n\n export interface TextGeometryParameters {\n size?: number; // size of the text\n height?: number; // thickness to extrude text\n curveSegments?: number; // number of points on the curves\n font?: string; // font name\n weight?: string; // font weight (normal, bold)\n style?: string; // font style (normal, italics)\n bevelEnabled?: boolean; // turn on bevel\n bevelThickness?: number; // how deep into text bevel goes\n bevelSize?: number; // how far from text outline is bevel\n }\n\n export class TextGeometry extends ExtrudeGeometry {\n constructor(text: string, TextGeometryParameters?: TextGeometryParameters);\n }\n\n export class TorusGeometry extends Geometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, arc?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n arc: number;\n };\n }\n\n export class TorusKnotGeometry extends Geometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, p?: number, q?: number, heightScale?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n p: number;\n q: number;\n heightScale: number;\n };\n }\n\n\n export class TubeGeometry extends Geometry {\n constructor(path: Path, segments?: number, radius?: number, radiusSegments?: number, closed?: boolean, taper?: (u: number) => number);\n\n parameters: {\n path: Path;\n segments: number;\n radius: number;\n radialSegments: number;\n closed: boolean;\n taper: (u: number) => number; // NoTaper or SinusoidalTaper;\n };\n tangents: Vector3[];\n normals: Vector3[];\n binormals: Vector3[];\n\n static NoTaper(u?: number): number;\n static SinusoidalTaper(u: number): number;\n }\n\n export class WireframeGeometry extends BufferGeometry {\n constructor(geometry: Geometry|BufferGeometry);\n }\n\n // Extras / Helpers /////////////////////////////////////////////////////////////////////\n\n export class ArrowHelper extends Object3D {\n constructor(dir: Vector3, origin?: Vector3, length?: number, hex?: number, headLength?: number, headWidth?: number);\n\n line: Line;\n cone: Mesh;\n\n setDirection(dir: Vector3): void;\n setLength(length: number, headLength?: number, headWidth?: number): void;\n setColor(hex: number): void;\n }\n\n export class AxisHelper extends Line {\n constructor(size?: number);\n }\n\n export class BoundingBoxHelper extends Mesh {\n constructor(object?: Object3D, hex?: number);\n\n object: Object3D;\n box: Box3;\n\n update(): void;\n }\n\n export class BoxHelper extends Line {\n constructor(object?: Object3D);\n\n update(object?: Object3D): void;\n }\n\n export class CameraHelper extends Line {\n constructor(camera: Camera);\n\n camera: Camera;\n pointMap: { [id: string]: number[]; };\n\n update(): void;\n }\n\n export class DirectionalLightHelper extends Object3D {\n constructor(light: Light, size?: number);\n\n light: Light;\n lightPlane: Line;\n targetLine: Line;\n\n dispose(): void;\n update(): void;\n }\n\n export class EdgesHelper extends Line {\n constructor(object: Object3D, hex?: number, thresholdAngle?: number);\n\n }\n\n export class FaceNormalsHelper extends Line {\n constructor(object: Object3D, size?: number, hex?: number, linewidth?: number);\n\n object: Object3D;\n size: number;\n normalMatrix: Matrix3;\n\n update(object?: Object3D): void;\n }\n\n export class GridHelper extends Line {\n constructor(size: number, step: number);\n\n color1: Color;\n color2: Color;\n\n setColors(colorCenterLine: number, colorGrid: number): void;\n }\n export class HemisphereLightHelper extends Object3D {\n constructor(light: Light, sphereSize: number);\n\n light: Light;\n colors: Color[];\n lightSphere: Mesh;\n\n dispose(): void;\n update(): void;\n }\n\n export class PointLightHelper extends Object3D {\n constructor(light: Light, sphereSize: number);\n\n light: Light;\n\n dispose(): void;\n update(): void;\n }\n\n export class SkeletonHelper extends Line {\n constructor(bone: Object3D);\n\n bones: Bone[];\n root: Object3D;\n\n getBoneList(object: Object3D): Bone[];\n update(): void;\n }\n\n export class SpotLightHelper extends Object3D {\n constructor(light: Light, sphereSize: number, arrowLength: number);\n\n light: Light;\n cone: Mesh;\n\n dispose(): void;\n update(): void;\n }\n\n export class VertexNormalsHelper extends Line {\n constructor(object: Object3D, size?: number, hex?: number, linewidth?: number);\n\n object: Object3D;\n size: number;\n normalMatrix: Matrix3;\n\n update(object?: Object3D): void;\n }\n\n export class VertexTangentsHelper extends Line {\n constructor(object: Object3D, size?: number, hex?: number, linewidth?: number);\n\n object: Object3D;\n size: number;\n\n update(object?: Object3D): void;\n }\n\n export class WireframeHelper extends Line {\n constructor(object: Object3D, hex?: number);\n\n }\n\n // Extras / Objects /////////////////////////////////////////////////////////////////////\n\n export class ImmediateRenderObject extends Object3D {\n constructor(material: Material);\n\n material: Material;\n\n render(renderCallback: Function): void;\n }\n\n export interface MorphBlendMeshAnimation {\n startFrame: number;\n endFrame: number;\n length: number;\n fps: number;\n duration: number;\n lastFrame: number;\n currentFrame: number;\n active: boolean;\n time: number;\n direction: number;\n weight: number;\n directionBackwards: boolean;\n mirroredLoop: boolean;\n }\n\n export class MorphBlendMesh extends Mesh {\n constructor(geometry: Geometry, material: Material);\n\n animationsMap: { [name: string]: MorphBlendMeshAnimation; };\n animationsList: MorphBlendMeshAnimation[];\n\n createAnimation(name: string, start: number, end: number, fps: number): void;\n autoCreateAnimations(fps: number): void;\n setAnimationDirectionForward(name: string): void;\n setAnimationDirectionBackward(name: string): void;\n setAnimationFPS(name: string, fps: number): void;\n setAnimationDuration(name: string, duration: number): void;\n setAnimationWeight(name: string, weight: number): void;\n setAnimationTime(name: string, time: number): void;\n getAnimationTime(name: string): number;\n getAnimationDuration(name: string): number;\n playAnimation(name: string): void;\n stopAnimation(name: string): void;\n update(delta: number): void;\n }\n}\n\ndeclare module 'three' {\n export = THREE;\n}\n" + defs: "// THREE.js plugin\n// https://github.com/florentpoujol/superpowers-game-threejs-plugin\n// Expose Three.js to the Typescript API\n\ndeclare var SupWebGLRenderer: THREE.WebGLRenderer;\ndeclare var SupThreeScene: THREE.Scene;\n\n// below is the content of https://raw.githubusercontent.com/florentpoujol/DefinitelyTyped/a8657deb82bd819a5d041e58463c19398a3163ee/threejs/three.d.ts\n\n// Type definitions for three.js r80\n// Project: http://mrdoob.github.com/three.js/\n// Definitions by: Kon , Satoru Kimura , Florent Poujol , SereznoKot \n// Definitions: https://github.com/borisyankov/DefinitelyTyped\n\ndeclare namespace THREE {\n export const REVISION: string;\n\n // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent.button\n export enum MOUSE { LEFT, MIDDLE, RIGHT }\n\n // GL STATE CONSTANTS\n export enum CullFace { }\n export const CullFaceNone: CullFace;\n export const CullFaceBack: CullFace;\n export const CullFaceFront: CullFace;\n export const CullFaceFrontBack: CullFace;\n\n export enum FrontFaceDirection { }\n export const FrontFaceDirectionCW: FrontFaceDirection;\n export const FrontFaceDirectionCCW: FrontFaceDirection;\n\n // Shadowing Type\n export enum ShadowMapType { }\n export const BasicShadowMap: ShadowMapType;\n export const PCFShadowMap: ShadowMapType;\n export const PCFSoftShadowMap: ShadowMapType;\n\n // MATERIAL CONSTANTS\n\n // side\n export enum Side { }\n export const FrontSide: Side;\n export const BackSide: Side;\n export const DoubleSide: Side;\n\n // shading\n export enum Shading { }\n export const FlatShading: Shading;\n export const SmoothShading: Shading;\n\n // colors\n export enum Colors { }\n export const NoColors: Colors;\n export const FaceColors: Colors;\n export const VertexColors: Colors;\n\n // blending modes\n export enum Blending { }\n export const NoBlending: Blending;\n export const NormalBlending: Blending;\n export const AdditiveBlending: Blending;\n export const SubtractiveBlending: Blending;\n export const MultiplyBlending: Blending;\n export const CustomBlending: Blending;\n\n // custom blending equations\n // (numbers start from 100 not to clash with other\n // mappings to OpenGL constants defined in Texture.js)\n export enum BlendingEquation { }\n export const AddEquation: BlendingEquation;\n export const SubtractEquation: BlendingEquation;\n export const ReverseSubtractEquation: BlendingEquation;\n export const MinEquation: BlendingEquation;\n export const MaxEquation: BlendingEquation;\n\n // custom blending destination factors\n export enum BlendingDstFactor { }\n export const ZeroFactor: BlendingDstFactor;\n export const OneFactor: BlendingDstFactor;\n export const SrcColorFactor: BlendingDstFactor;\n export const OneMinusSrcColorFactor: BlendingDstFactor;\n export const SrcAlphaFactor: BlendingDstFactor;\n export const OneMinusSrcAlphaFactor: BlendingDstFactor;\n export const DstAlphaFactor: BlendingDstFactor;\n export const OneMinusDstAlphaFactor: BlendingDstFactor;\n\n // custom blending src factors\n export enum BlendingSrcFactor { }\n export const DstColorFactor: BlendingSrcFactor;\n export const OneMinusDstColorFactor: BlendingSrcFactor;\n export const SrcAlphaSaturateFactor: BlendingSrcFactor;\n\n // depth modes\n export enum DepthModes { }\n export const NeverDepth: DepthModes;\n export const AlwaysDepth: DepthModes;\n export const LessDepth: DepthModes;\n export const LessEqualDepth: DepthModes;\n export const EqualDepth: DepthModes;\n export const GreaterEqualDepth: DepthModes;\n export const GreaterDepth: DepthModes;\n export const NotEqualDepth: DepthModes;\n\n // TEXTURE CONSTANTS\n // Operations\n export enum Combine { }\n export const MultiplyOperation: Combine;\n export const MixOperation: Combine;\n export const AddOperation: Combine;\n\n // Tone Mapping modes\n export enum ToneMapping { }\n export const NoToneMapping: ToneMapping;\n export const LinearToneMapping: ToneMapping;\n export const ReinhardToneMapping: ToneMapping;\n export const Uncharted2ToneMapping: ToneMapping;\n export const CineonToneMapping: ToneMapping;\n\n // Mapping modes\n export enum Mapping { }\n export const UVMapping: Mapping;\n export const CubeReflectionMapping: Mapping;\n export const CubeRefractionMapping: Mapping;\n export const EquirectangularReflectionMapping: Mapping;\n export const EquirectangularRefractionMapping: Mapping;\n export const SphericalReflectionMapping: Mapping;\n export const CubeUVReflectionMapping: Mapping;\n export const CubeUVRefractionMapping: Mapping;\n\n // Wrapping modes\n export enum Wrapping { }\n export const RepeatWrapping: Wrapping;\n export const ClampToEdgeWrapping: Wrapping;\n export const MirroredRepeatWrapping: Wrapping;\n\n // Filters\n export enum TextureFilter { }\n export const NearestFilter: TextureFilter;\n export const NearestMipMapNearestFilter: TextureFilter;\n export const NearestMipMapLinearFilter: TextureFilter;\n export const LinearFilter: TextureFilter;\n export const LinearMipMapNearestFilter: TextureFilter;\n export const LinearMipMapLinearFilter: TextureFilter;\n\n // Data types\n export enum TextureDataType { }\n export const UnsignedByteType: TextureDataType;\n export const ByteType: TextureDataType;\n export const ShortType: TextureDataType;\n export const UnsignedShortType: TextureDataType;\n export const IntType: TextureDataType;\n export const UnsignedIntType: TextureDataType;\n export const FloatType: TextureDataType;\n export const HalfFloatType: TextureDataType;\n\n // Pixel types\n export enum PixelType { }\n export const UnsignedShort4444Type: PixelType;\n export const UnsignedShort5551Type: PixelType;\n export const UnsignedShort565Type: PixelType;\n export const UnsignedInt248Type: PixelType;\n\n // Pixel formats\n export enum PixelFormat { }\n export const AlphaFormat: PixelFormat;\n export const RGBFormat: PixelFormat;\n export const RGBAFormat: PixelFormat;\n export const LuminanceFormat: PixelFormat;\n export const LuminanceAlphaFormat: PixelFormat;\n export const RGBEFormat: PixelFormat;\n export const DepthFormat: PixelFormat;\n export const DepthStencilFormat: PixelFormat;\n\n // Compressed texture formats\n // DDS / ST3C Compressed texture formats\n export enum CompressedPixelFormat { }\n export const RGB_S3TC_DXT1_Format: CompressedPixelFormat;\n export const RGBA_S3TC_DXT1_Format: CompressedPixelFormat;\n export const RGBA_S3TC_DXT3_Format: CompressedPixelFormat;\n export const RGBA_S3TC_DXT5_Format: CompressedPixelFormat;\n\n // PVRTC compressed texture formats\n export const RGB_PVRTC_4BPPV1_Format: CompressedPixelFormat;\n export const RGB_PVRTC_2BPPV1_Format: CompressedPixelFormat;\n export const RGBA_PVRTC_4BPPV1_Format: CompressedPixelFormat;\n export const RGBA_PVRTC_2BPPV1_Format: CompressedPixelFormat;\n\n // ETC compressed texture formats\n export const RGB_ETC1_Format: CompressedPixelFormat;\n\n // Loop styles for AnimationAction\n export enum AnimationActionLoopStyles { }\n export const LoopOnce: AnimationActionLoopStyles;\n export const LoopRepeat: AnimationActionLoopStyles;\n export const LoopPingPong: AnimationActionLoopStyles;\n\n // Interpolation\n export enum InterpolationModes { }\n export const InterpolateDiscrete: InterpolationModes;\n export const InterpolateLinear: InterpolationModes;\n export const InterpolateSmooth: InterpolationModes;\n\n // Interpolant ending modes\n export enum InterpolationEndingModes { }\n export const ZeroCurvatureEnding: InterpolationEndingModes;\n export const ZeroSlopeEnding: InterpolationEndingModes;\n export const WrapAroundEnding: InterpolationEndingModes;\n\n // Triangle Draw modes\n export enum TrianglesDrawModes { }\n export const TrianglesDrawModesMode: TrianglesDrawModes;\n export const TriangleStripDrawMode: TrianglesDrawModes;\n export const TriangleFanDrawMode: TrianglesDrawModes;\n\n // Texture Encodings\n export enum TextureEncoding { }\n export const LinearEncoding: TextureEncoding;\n export const sRGBEncoding: TextureEncoding;\n export const GammaEncoding: TextureEncoding;\n export const RGBEEncoding: TextureEncoding;\n export const LogLuvEncoding: TextureEncoding;\n export const RGBM7Encoding: TextureEncoding;\n export const RGBM16Encoding: TextureEncoding;\n export const RGBDEncoding: TextureEncoding;\n\n // Depth packing strategies\n export enum DepthPackingStrategies { }\n export const BasicDepthPacking: DepthPackingStrategies;\n export const RGBADepthPacking: DepthPackingStrategies;\n\n // log handlers\n export function warn(message?: any, ...optionalParams: any[]): void;\n export function error(message?: any, ...optionalParams: any[]): void;\n export function log(message?: any, ...optionalParams: any[]): void;\n\n // Animation ////////////////////////////////////////////////////////////////////////////////////////\n\n export class AnimationAction {\n loop: boolean;\n time: number;\n timeScale: number;\n weight: number;\n repetitions: number;\n paused: boolean;\n enabled: boolean;\n clampWhenFinished: boolean;\n zeroSlopeAtStart: boolean;\n zeroSlopeAtEnd: boolean;\n\n play(): AnimationAction;\n stop(): AnimationAction;\n reset(): AnimationAction;\n isRunning(): boolean;\n startAt(time: number): AnimationAction;\n setLoop(mode: boolean, repetitions: number): AnimationAction;\n setEffectiveWeight(weight: number): AnimationAction;\n getEffectiveWeight(): number;\n fadeIn(duration: number): AnimationAction;\n fadeOut(duration: number): AnimationAction;\n crossFadeFrom(fadeOutAction: AnimationAction, duration: number, warp: boolean): AnimationAction;\n crossFadeTo(fadeInAction: AnimationAction, duration: number, warp: boolean): AnimationAction;\n stopFading(): AnimationAction;\n setEffectiveTimeScale(timeScale: number): AnimationAction;\n getEffectiveTimeScale(): number;\n setDuration(duration: number): AnimationAction;\n syncWith(action: AnimationAction): AnimationAction;\n halt(duration: number): AnimationAction;\n warp(statTimeScale: number, endTimeScale: number, duration: number): AnimationAction;\n stopWarping(): AnimationAction;\n getMixer(): AnimationMixer;\n getClip(): AnimationClip;\n getRoot(): any;\n }\n\n export class AnimationClip {\n constructor( name?: string, duration?: number, tracks?: KeyframeTrack[] );\n\n name: string;\n tracks: KeyframeTrack[];\n duration: number;\n uuid: string;\n results: any[];\n\n resetDuration(): void;\n trim(): AnimationClip;\n optimize(): AnimationClip;\n\n static CreateFromMorphTargetSequence( name: string, morphTargetSequence: MorphTarget[], fps: number, noLoop: boolean ): AnimationClip;\n static findByName( clipArray: AnimationClip, name: string ): AnimationClip;\n static CreateClipsFromMorphTargetSequences( morphTargets: MorphTarget[], fps: number, noLoop: boolean ): AnimationClip[];\n static parse( json: any ): AnimationClip;\n static parseAnimation( animation: any, bones: Bone[], nodeName: string ): AnimationClip;\n static toJSON(): any;\n }\n\n export class AnimationMixer extends EventDispatcher {\n constructor(root: any);\n\n time: number;\n timeScale: number;\n\n clipAction(clip: AnimationClip, root?: any): AnimationAction;\n existingAction(clip: AnimationClip, root?: any): AnimationAction;\n stopAllAction(clip: AnimationClip, root?: any): AnimationMixer;\n update(deltaTime: number): AnimationMixer;\n getRoot(): any;\n uncacheClip(clip: AnimationClip): void;\n uncacheRoot(root: any): void;\n uncacheAction(clip: AnimationClip, root?: any): void;\n }\n\n export class AnimationObjectGroup {\n constructor(...args: any[]);\n\n uuid: string;\n stats: {\n bindingsPerObject: number;\n objects: {\n total: number;\n inUse: number;\n }\n };\n\n add(...args: any[]): void;\n remove(...args: any[]): void;\n uncache(...args: any[]): void;\n }\n\n export namespace AnimationUtils {\n export function arraySlice(array: any, from: number, to: number): any;\n export function convertArray(array: any, type: any, forceClone: boolean): any;\n export function isTypedArray(object: any): boolean;\n export function getKeyFrameOrder(times: number): number[];\n export function sortedArray(values: any[], stride: number, order: number[]): any[];\n export function flattenJSON(jsonKeys: string[], times: any[], values: any[], valuePropertyName: string): void;\n }\n\n export class KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n\n name: string;\n times: any[];\n values: any[];\n\n ValueTypeName: string;\n TimeBufferType: Float32Array;\n ValueBufferType: Float32Array;\n\n DefaultInterpolation: InterpolationModes;\n\n InterpolantFactoryMethodDiscrete(result: any): DiscreteInterpolant;\n InterpolantFactoryMethodLinear(result: any): LinearInterpolant;\n InterpolantFactoryMethodSmooth(result: any): CubicInterpolant;\n\n setInterpolation(interpolation: InterpolationModes): void;\n getInterpolation(): InterpolationModes;\n\n getValuesize(): number;\n\n shift( timeOffset: number ): KeyframeTrack;\n scale( timeScale: number ): KeyframeTrack;\n trim( startTime: number, endTime: number ): KeyframeTrack;\n validate(): boolean;\n optimize(): KeyframeTrack;\n\n static parse(json: any): KeyframeTrack;\n static toJSON(track: KeyframeTrack): any;\n }\n\n export class PropertyBinding {\n constructor(rootNode: any, path: string, parsedPath?: any);\n\n path: string;\n parsedPath: any;\n node: any;\n rootNode: any;\n\n getValue(targetArray: any, offset: number): any;\n setValue(sourceArray: any, offset: number): void;\n bind(): void;\n unbind(): void;\n\n BindingType: { [bindingType: string]: number };\n Versioning: { [versioning: string]: number };\n\n GetterByBindingType: Function[];\n SetterByBindingTypeAndVersioning: Array;\n\n static create(root: any, path: any, parsedPath?: any): PropertyBinding|PropertyBinding.Composite;\n static parseTrackName(trackName: string): any;\n static findNode(root: any, nodeName: string): any;\n }\n\n export namespace PropertyBinding {\n export class Composite {\n constructor(targetGroup: any, path: any, parsedPath?: any);\n\n getValue(array: any, offset: number): any;\n setValue(array: any, offset: number): void;\n bind(): void;\n unbind(): void;\n }\n }\n\n export class PropertyMixer {\n constructor(binding: any, typeName: string, valueSize: number);\n\n binding: any;\n valueSize: number;\n buffer: any;\n cumulativeWeight: number;\n useCount: number;\n referenceCount: number;\n\n accumulate(accuIndex: number, weight: number): void;\n apply(accuIndex: number): void;\n saveOriginalState(): void;\n restoreOriginalState(): void;\n }\n\n export class BooleanKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[]);\n }\n\n export class ColorKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n }\n\n export class NumberKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n }\n\n export class QuaternionKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n }\n\n export class StringKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n }\n\n export class VectorKeyframeTrack extends KeyframeTrack {\n constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes);\n }\n\n // Cameras ////////////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Abstract base class for cameras. This class should always be inherited when you build a new camera.\n */\n export class Camera extends Object3D {\n /**\n * This constructor sets following properties to the correct type: matrixWorldInverse, projectionMatrix and projectionMatrixInverse.\n */\n constructor();\n\n /**\n * This is the inverse of matrixWorld. MatrixWorld contains the Matrix which has the world transform of the Camera.\n */\n matrixWorldInverse: Matrix4;\n\n /**\n * This is the matrix which contains the projection.\n */\n projectionMatrix: Matrix4;\n\n getWorldDirection(optionalTarget?: Vector3): Vector3;\n\n /**\n * This make the camera look at the vector position in local space.\n * @param vector point to look at\n */\n lookAt(vector: Vector3): void;\n\n clone(): Camera;\n copy(camera?: Camera): Camera;\n }\n\n export class CubeCamera extends Object3D {\n constructor(near?: number, far?: number, cubeResolution?: number);\n\n renderTarget: WebGLRenderTargetCube;\n\n updateCubeMap(renderer: Renderer, scene: Scene): void;\n }\n\n /**\n * Camera with orthographic projection\n *\n * @example\n * var camera = new THREE.OrthographicCamera( width / - 2, width / 2, height / 2, height / - 2, 1, 1000 );\n * scene.add( camera );\n *\n * @see src/cameras/OrthographicCamera.js\n */\n export class OrthographicCamera extends Camera {\n /**\n * @param left Camera frustum left plane.\n * @param right Camera frustum right plane.\n * @param top Camera frustum top plane.\n * @param bottom Camera frustum bottom plane.\n * @param near Camera frustum near plane.\n * @param far Camera frustum far plane.\n */\n constructor(left: number, right: number, top: number, bottom: number, near?: number, far?: number);\n\n zoom: number;\n view: {\n fullWidth: number,\n fullHeight: number,\n offsetX: number,\n offsetY: number,\n width: number,\n height: number\n };\n\n /**\n * Camera frustum left plane.\n */\n left: number;\n\n /**\n * Camera frustum right plane.\n */\n right: number;\n\n /**\n * Camera frustum top plane.\n */\n top: number;\n\n /**\n * Camera frustum bottom plane.\n */\n bottom: number;\n\n /**\n * Camera frustum near plane.\n */\n near: number;\n\n /**\n * Camera frustum far plane.\n */\n far: number;\n\n /**\n * Updates the camera projection matrix. Must be called after change of parameters.\n */\n updateProjectionMatrix(): void;\n setViewOffset(fullWidth: number, fullHeight: number, offsetX: number, offsetY: number, width: number, height: number): void;\n clearViewOffset(): void;\n clone(): OrthographicCamera;\n copy(source: OrthographicCamera): OrthographicCamera;\n toJSON(meta?: any): any;\n }\n\n /**\n * Camera with perspective projection.\n *\n * # example\n * var camera = new THREE.PerspectiveCamera( 45, width / height, 1, 1000 );\n * scene.add( camera );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/cameras/PerspectiveCamera.js\n */\n export class PerspectiveCamera extends Camera {\n /**\n * @param fov Camera frustum vertical field of view. Default value is 50.\n * @param aspect Camera frustum aspect ratio. Default value is 1.\n * @param near Camera frustum near plane. Default value is 0.1.\n * @param far Camera frustum far plane. Default value is 2000.\n */\n constructor(fov?: number, aspect?: number, near?: number, far?: number);\n\n zoom: number;\n\n /**\n * Camera frustum vertical field of view, from bottom to top of view, in degrees.\n */\n fov: number;\n\n /**\n * Camera frustum aspect ratio, window width divided by window height.\n */\n aspect: number;\n\n /**\n * Camera frustum near plane.\n */\n near: number;\n\n /**\n * Camera frustum far plane.\n */\n far: number;\n\n focus: number;\n view: {\n fullWidth: number,\n fullHeight: number,\n offsetX: number,\n offsetY: number,\n width: number,\n height: number\n };\n filmGauge: number;\n filmOffset: number;\n\n setFocalLength(focalLength: number): void;\n getFocalLength(): number;\n getEffectiveFOV(): number;\n getFilmWidth(): number;\n getFilmHeight(): number;\n /**\n * Sets an offset in a larger frustum. This is useful for multi-window or multi-monitor/multi-machine setups.\n * For example, if you have 3x2 monitors and each monitor is 1920x1080 and the monitors are in grid like this:\n *\n * +---+---+---+\n * | A | B | C |\n * +---+---+---+\n * | D | E | F |\n * +---+---+---+\n *\n * then for each monitor you would call it like this:\n *\n * var w = 1920;\n * var h = 1080;\n * var fullWidth = w * 3;\n * var fullHeight = h * 2;\n *\n * // A\n * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );\n * // B\n * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );\n * // C\n * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );\n * // D\n * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );\n * // E\n * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );\n * // F\n * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 1, w, h ); Note there is no reason monitors have to be the same size or in a grid.\n *\n * @param fullWidth full width of multiview setup\n * @param fullHeight full height of multiview setup\n * @param x horizontal offset of subcamera\n * @param y vertical offset of subcamera\n * @param width width of subcamera\n * @param height height of subcamera\n */\n setViewOffset(fullWidth: number, fullHeight: number, x: number, y: number, width: number, height: number): void;\n clearViewOffset(): void;\n\n /**\n * Updates the camera projection matrix. Must be called after change of parameters.\n */\n updateProjectionMatrix(): void;\n clone(): PerspectiveCamera;\n toJSON(meta?: any): any;\n\n // deprecated\n setLens(focalLength: number, frameHeight?: number): void;\n }\n\n export class StereoCamera extends Camera {\n constructor();\n\n aspect: number;\n cameraL: PerspectiveCamera;\n cameraR: PerspectiveCamera;\n\n update(camera: PerspectiveCamera): void;\n }\n\n // Core ///////////////////////////////////////////////////////////////////////////////////////////////\n\n /**\n * @see src/core/BufferAttribute.js\n */\n export class BufferAttribute {\n constructor(array: ArrayLike, itemSize: number, normalized?: boolean); // array parameter should be TypedArray.\n\n uuid: string;\n array: ArrayLike;\n itemSize: number;\n dynamic: boolean;\n updateRange: {offset: number, count: number};\n version: number;\n normalized: boolean;\n needsUpdate: boolean;\n count: number;\n\n setDynamic(dynamic: boolean): BufferAttribute;\n clone(): BufferAttribute;\n copy(source: BufferAttribute): BufferAttribute;\n copyAt(index1: number, attribute: BufferAttribute, index2: number): BufferAttribute;\n copyArray(array: ArrayLike): BufferAttribute;\n copyColorsArray(colors: {r: number, g: number, b: number}[]): BufferAttribute;\n copyIndicesArray(indices: {a: number, b: number, c: number}[]): BufferAttribute;\n copyVector2sArray(vectors: {x: number, y: number}[]): BufferAttribute;\n copyVector3sArray(vectors: {x: number, y: number, z: number}[]): BufferAttribute;\n copyVector4sArray(vectors: {x: number, y: number, z: number, w: number}[]): BufferAttribute;\n set(value: ArrayLike, offset?: number): BufferAttribute;\n getX(index: number): number;\n setX(index: number, x: number): BufferAttribute;\n getY(index: number): number;\n setY(index: number, y: number): BufferAttribute;\n getZ(index: number): number;\n setZ(index: number, z: number): BufferAttribute;\n getW(index: number): number;\n setW(index: number, z: number): BufferAttribute;\n setXY(index: number, x: number, y: number): BufferAttribute;\n setXYZ(index: number, x: number, y: number, z: number): BufferAttribute;\n setXYZW(index: number, x: number, y: number, z: number, w: number): BufferAttribute;\n clone(): BufferAttribute;\n\n length: number; // deprecated, use count\n }\n\n export class Int8Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Uint8Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Uint8ClampedAttribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Int16Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Uint16Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Int32Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Uint32Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Float32Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n export class Float64Attribute extends BufferAttribute {\n constructor(array: any, itemSize: number);\n }\n\n // deprecated, use new THREE.BufferAttribute().setDynamic( true )\n export class DynamicBufferAttribute extends BufferAttribute {}\n\n /**\n * This is a superefficent class for geometries because it saves all data in buffers.\n * It reduces memory costs and cpu cycles. But it is not as easy to work with because of all the nessecary buffer calculations.\n * It is mainly interesting when working with static objects.\n *\n * @see src/core/BufferGeometry.js\n */\n export class BufferGeometry extends EventDispatcher {\n /**\n * This creates a new BufferGeometry. It also sets several properties to an default value.\n */\n constructor();\n\n static MaxIndex: number;\n\n /**\n * Unique number of this buffergeometry instance\n */\n id: number;\n uuid: string;\n name: string;\n type: string;\n index: BufferAttribute;\n attributes: BufferAttribute|InterleavedBufferAttribute[];\n morphAttributes: any;\n groups: {start: number, count: number, materialIndex?: number}[];\n boundingBox: Box3;\n boundingSphere: Sphere;\n drawRange: { start: number, count: number };\n\n getIndex(): BufferAttribute;\n setIndex( index: BufferAttribute ): void;\n\n addAttribute(name: string, attribute: BufferAttribute|InterleavedBufferAttribute): BufferGeometry;\n\n getAttribute(name: string): BufferAttribute|InterleavedBufferAttribute;\n removeAttribute(name: string): BufferGeometry;\n\n addGroup(start: number, count: number, materialIndex?: number): void;\n clearGroups(): void;\n\n setDrawRange(start: number, count: number): void;\n\n /**\n * Bakes matrix transform directly into vertex coordinates.\n */\n applyMatrix(matrix: Matrix4): BufferGeometry;\n\n rotateX(angle: number): BufferGeometry;\n rotateY(angle: number): BufferGeometry;\n rotateZ(angle: number): BufferGeometry;\n translate(x: number, y: number, z: number): BufferGeometry;\n scale(x: number, y: number, z: number): BufferGeometry;\n lookAt(v: Vector3): void;\n\n center(): Vector3;\n\n setFromObject(object: Object3D): void;\n updateFromObject(object: Object3D): void;\n\n fromGeometry(geometry: Geometry, settings?: any): BufferGeometry;\n\n fromDirectGeometry(geometry: DirectGeometry): BufferGeometry;\n\n /**\n * Computes bounding box of the geometry, updating Geometry.boundingBox attribute.\n * Bounding boxes aren't computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingBox(): void;\n\n /**\n * Computes bounding sphere of the geometry, updating Geometry.boundingSphere attribute.\n * Bounding spheres aren't' computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingSphere(): void;\n\n /**\n * Computes vertex normals by averaging face normals.\n */\n computeVertexNormals(): void;\n\n merge(geometry: BufferGeometry, offset: number): BufferGeometry;\n normalizeNormals(): void;\n\n toNonIndexed(): BufferGeometry;\n\n toJSON(): any;\n clone(): BufferGeometry;\n copy(source: BufferGeometry): BufferGeometry;\n\n /**\n * Disposes the object from memory.\n * You need to call this when you want the bufferGeometry removed while the application is running.\n */\n dispose(): void;\n\n // deprecated\n drawcalls: any;\n offsets: any;\n\n addIndex(index: any): void;\n addDrawCall(start: any, count: any, indexOffset?: any): void;\n clearDrawCalls(): void;\n addAttribute(name: any, array: any, itemSize: any): any;\n }\n\n /**\n * Object for keeping track of time.\n *\n * @see src/core/Clock.js\n */\n export class Clock {\n /**\n * @param autoStart Automatically start the clock.\n */\n constructor(autoStart?: boolean);\n\n /**\n * If set, starts the clock automatically when the first update is called.\n */\n autoStart: boolean;\n\n /**\n * When the clock is running, It holds the starttime of the clock.\n * This counted from the number of milliseconds elapsed since 1 January 1970 00:00:00 UTC.\n */\n startTime: number;\n\n /**\n * When the clock is running, It holds the previous time from a update.\n * This counted from the number of milliseconds elapsed since 1 January 1970 00:00:00 UTC.\n */\n oldTime: number;\n\n /**\n * When the clock is running, It holds the time elapsed between the start of the clock to the previous update.\n * This parameter is in seconds of three decimal places.\n */\n elapsedTime: number;\n\n /**\n * This property keeps track whether the clock is running or not.\n */\n running: boolean;\n\n /**\n * Starts clock.\n */\n start(): void;\n\n /**\n * Stops clock.\n */\n stop(): void;\n\n /**\n * Get the seconds passed since the clock started.\n */\n getElapsedTime(): number;\n\n /**\n * Get the seconds passed since the last call to this method.\n */\n getDelta(): number;\n }\n\n /**\n * @see src/core/DirectGeometry.js\n */\n export class DirectGeometry extends EventDispatcher {\n constructor();\n\n id: number;\n uuid: string;\n name: string;\n type: string;\n indices: number[];\n vertices: Vector3[];\n normals: Vector3[];\n colors: Color[];\n uvs: Vector2[];\n uvs2: Vector2[];\n groups: {start: number, materialIndex: number}[];\n morphTargets: MorphTarget[];\n skinWeights: number[];\n skinIndices: number[];\n boundingBox: Box3;\n boundingSphere: Sphere;\n verticesNeedUpdate: boolean;\n normalsNeedUpdate: boolean;\n colorsNeedUpdate: boolean;\n uvsNeedUpdate: boolean;\n groupsNeedUpdate: boolean;\n\n computeBoundingBox(): void;\n computeBoundingSphere(): void;\n computeGroups(geometry: Geometry): void;\n fromGeometry(geometry: Geometry): DirectGeometry;\n dispose(): void;\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: Event) => void ): void;\n hasEventListener(type: string, listener: (event: Event) => void): void;\n removeEventListener(type: string, listener: (event: Event) => void): void;\n dispatchEvent(event: { type: string; [attachment: string]: any; }): void;\n }\n\n\n /**\n * JavaScript events for custom objects\n *\n * # Example\n * var Car = function () {\n *\n * EventDispatcher.call( this );\n * this.start = function () {\n *\n * this.dispatchEvent( { type: 'start', message: 'vroom vroom!' } );\n *\n * };\n *\n * };\n *\n * var car = new Car();\n * car.addEventListener( 'start', function ( event ) {\n *\n * alert( event.message );\n *\n * } );\n * car.start();\n *\n * @source src/core/EventDispatcher.js\n */\n export class EventDispatcher {\n /**\n * Creates eventDispatcher object. It needs to be call with '.call' to add the functionality to an object.\n */\n constructor();\n\n /**\n * Adds a listener to an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n addEventListener(type: string, listener: (event: Event) => void ): void;\n\n /**\n * Adds a listener to an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n hasEventListener(type: string, listener: (event: Event) => void): void;\n\n /**\n * Removes a listener from an event type.\n * @param type The type of the listener that gets removed.\n * @param listener The listener function that gets removed.\n */\n removeEventListener(type: string, listener: (event: Event) => void): void;\n\n /**\n * Fire an event type.\n * @param type The type of event that gets fired.\n */\n dispatchEvent(event: { type: string; [attachment: string]: any; }): void;\n\n // deprecated\n apply(target: any): void;\n }\n\n export interface Event {\n type: string;\n target: any;\n }\n\n /**\n * Triangle face.\n *\n * # Example\n * var normal = new THREE.Vector3( 0, 1, 0 );\n * var color = new THREE.Color( 0xffaa00 );\n * var face = new THREE.Face3( 0, 1, 2, normal, color, 0 );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/core/Face3.js\n */\n export class Face3 {\n /**\n * @param a Vertex A index.\n * @param b Vertex B index.\n * @param c Vertex C index.\n * @param normal Face normal or array of vertex normals.\n * @param color Face color or array of vertex colors.\n * @param materialIndex Material index.\n */\n constructor(a: number, b: number, c: number, normal?: Vector3, color?: Color, materialIndex?: number);\n constructor(a: number, b: number, c: number, normal?: Vector3, vertexColors?: Color[], materialIndex?: number);\n constructor(a: number, b: number, c: number, vertexNormals?: Vector3[], color?: Color, materialIndex?: number);\n constructor(a: number, b: number, c: number, vertexNormals?: Vector3[], vertexColors?: Color[], materialIndex?: number);\n\n /**\n * Vertex A index.\n */\n a: number;\n\n /**\n * Vertex B index.\n */\n b: number;\n\n /**\n * Vertex C index.\n */\n c: number;\n\n /**\n * Face normal.\n */\n normal: Vector3;\n\n /**\n * Array of 4 vertex normals.\n */\n vertexNormals: Vector3[];\n\n /**\n * Face color.\n */\n color: Color;\n\n /**\n * Array of 4 vertex normals.\n */\n vertexColors: Color[];\n\n /**\n * Material index (points to {@link Geometry.materials}).\n */\n materialIndex: number;\n\n clone(): Face3;\n copy(source: Face3): Face3;\n }\n\n export class Face4 extends Face3 {} // deprecated, use Face3\n\n export interface MorphTarget {\n name: string;\n vertices: Vector3[];\n }\n\n export interface MorphColor {\n name: string;\n colors: Color[];\n }\n\n export interface MorphNormals {\n name: string;\n normals: Vector3[];\n }\n\n export let GeometryIdCount: number;\n\n /**\n * Base class for geometries\n *\n * # Example\n * var geometry = new THREE.Geometry();\n * geometry.vertices.push( new THREE.Vector3( -10, 10, 0 ) );\n * geometry.vertices.push( new THREE.Vector3( -10, -10, 0 ) );\n * geometry.vertices.push( new THREE.Vector3( 10, -10, 0 ) );\n * geometry.faces.push( new THREE.Face3( 0, 1, 2 ) );\n * geometry.computeBoundingSphere();\n *\n * @see https://github.com/mrdoob/three.js/blob/master/src/core/Geometry.js\n */\n export class Geometry extends EventDispatcher {\n constructor();\n\n /**\n * Unique number of this geometry instance\n */\n id: number;\n\n uuid: string;\n\n /**\n * Name for this geometry. Default is an empty string.\n */\n name: string;\n\n type: string;\n\n /**\n * The array of vertices hold every position of points of the model.\n * To signal an update in this array, Geometry.verticesNeedUpdate needs to be set to true.\n */\n vertices: Vector3[];\n\n /**\n * Array of vertex colors, matching number and order of vertices.\n * Used in ParticleSystem, Line and Ribbon.\n * Meshes use per-face-use-of-vertex colors embedded directly in faces.\n * To signal an update in this array, Geometry.colorsNeedUpdate needs to be set to true.\n */\n colors: Color[];\n\n /**\n * Array of triangles or/and quads.\n * The array of faces describe how each vertex in the model is connected with each other.\n * To signal an update in this array, Geometry.elementsNeedUpdate needs to be set to true.\n */\n faces: Face3[];\n\n /**\n * Array of face UV layers.\n * Each UV layer is an array of UV matching order and number of vertices in faces.\n * To signal an update in this array, Geometry.uvsNeedUpdate needs to be set to true.\n */\n faceVertexUvs: Vector2[][][];\n\n /**\n * Array of morph targets. Each morph target is a Javascript object:\n *\n * { name: \"targetName\", vertices: [ new THREE.Vector3(), ... ] }\n *\n * Morph vertices match number and order of primary vertices.\n */\n morphTargets: MorphTarget[];\n\n /**\n * Array of morph normals. Morph normals have similar structure as morph targets, each normal set is a Javascript object:\n *\n * morphNormal = { name: \"NormalName\", normals: [ new THREE.Vector3(), ... ] }\n */\n morphNormals: MorphNormals[];\n\n /**\n * Array of skinning weights, matching number and order of vertices.\n */\n skinWeights: number[];\n\n /**\n * Array of skinning indices, matching number and order of vertices.\n */\n skinIndices: number[];\n\n /**\n *\n */\n lineDistances: number[];\n\n /**\n * Bounding box.\n */\n boundingBox: Box3;\n\n /**\n * Bounding sphere.\n */\n boundingSphere: Sphere;\n\n /**\n * Set to true if the vertices array has been updated.\n */\n verticesNeedUpdate: boolean;\n\n /**\n * Set to true if the faces array has been updated.\n */\n elementsNeedUpdate: boolean;\n\n /**\n * Set to true if the uvs array has been updated.\n */\n uvsNeedUpdate: boolean;\n\n /**\n * Set to true if the normals array has been updated.\n */\n normalsNeedUpdate: boolean;\n\n /**\n * Set to true if the colors array has been updated.\n */\n colorsNeedUpdate: boolean;\n\n /**\n * Set to true if the linedistances array has been updated.\n */\n lineDistancesNeedUpdate: boolean;\n\n /**\n *\n */\n groupsNeedUpdate: boolean;\n\n /**\n * Bakes matrix transform directly into vertex coordinates.\n */\n applyMatrix(matrix: Matrix4): Geometry;\n\n rotateX(angle: number): Geometry;\n rotateY(angle: number): Geometry;\n rotateZ(angle: number): Geometry;\n\n translate(x: number, y: number, z: number): Geometry;\n scale(x: number, y: number, z: number): Geometry;\n lookAt( vector: Vector3 ): void;\n\n fromBufferGeometry(geometry: BufferGeometry): Geometry;\n\n center(): Vector3;\n\n normalize(): Geometry;\n\n /**\n * Computes face normals.\n */\n computeFaceNormals(): void;\n\n /**\n * Computes vertex normals by averaging face normals.\n * Face normals must be existing / computed beforehand.\n */\n computeVertexNormals(areaWeighted?: boolean): void;\n\n /**\n * Computes morph normals.\n */\n computeMorphNormals(): void;\n\n computeLineDistances(): void;\n\n /**\n * Computes bounding box of the geometry, updating {@link Geometry.boundingBox} attribute.\n */\n computeBoundingBox(): void;\n\n /**\n * Computes bounding sphere of the geometry, updating Geometry.boundingSphere attribute.\n * Neither bounding boxes or bounding spheres are computed by default. They need to be explicitly computed, otherwise they are null.\n */\n computeBoundingSphere(): void;\n\n merge(geometry: Geometry, matrix: Matrix, materialIndexOffset?: number): void;\n\n mergeMesh(mesh: Mesh): void;\n\n /**\n * Checks for duplicate vertices using hashmap.\n * Duplicated vertices are removed and faces' vertices are updated.\n */\n mergeVertices(): number;\n\n sortFacesByMaterialIndex(): void;\n\n toJSON(): any;\n\n /**\n * Creates a new clone of the Geometry.\n */\n clone(): Geometry;\n\n copy(source: Geometry): Geometry;\n\n /**\n * Removes The object from memory.\n * Don't forget to call this method when you remove an geometry because it can cuase meomory leaks.\n */\n dispose(): void;\n\n\n // These properties do not exist in a normal Geometry class, but if you use the instance that was passed by JSONLoader, it will be added.\n bones: Bone[];\n animation: AnimationClip;\n animations: AnimationClip[];\n\n // EventDispatcher mixins\n addEventListener(type: string, listener: (event: Event) => void ): void;\n hasEventListener(type: string, listener: (event: Event) => void): void;\n removeEventListener(type: string, listener: (event: Event) => void): void;\n dispatchEvent(event: { type: string; [attachment: string]: any; }): void;\n }\n\n export namespace GeometryUtils { // deprecated\n export function merge(geometry1: any, geometry2: any, materialIndexOffset?: any): any; // deprecated, use geometry.merge( geometry2, matrix, materialIndexOffset )\n export function center(geometry: any): any; // deprecated, use geometry.center()\n }\n\n /**\n * @see src/core/InstancedBufferAttribute.js\n */\n export class InstancedBufferAttribute extends BufferAttribute {\n constructor(data: ArrayLike, itemSize: number, meshPerAttribute?: number);\n\n meshPerAttribute: number;\n\n clone(): InstancedBufferAttribute;\n copy(source: InstancedBufferAttribute): InstancedBufferAttribute;\n }\n\n /**\n * @see src/core/InstancedBufferGeometry.js\n */\n export class InstancedBufferGeometry extends BufferGeometry {\n constructor();\n\n groups: {start: number, count: number, instances: number}[];\n maxInstancedCount: number;\n\n addGroup(start: number, count: number, instances: number): void;\n clone(): InstancedBufferGeometry;\n copy(source: InstancedBufferGeometry): InstancedBufferGeometry;\n }\n\n /**\n * @see src/core/InterleavedBuffer.js\n */\n export class InterleavedBuffer {\n constructor(array: ArrayLike, stride: number);\n\n array: ArrayLike;\n stride: number;\n dynamic: boolean;\n updateRange: { offset: number; count: number };\n version: number;\n length: number;\n count: number;\n needsUpdate: boolean;\n\n setDynamic(dynamic: boolean): InterleavedBuffer;\n clone(): InterleavedBuffer;\n copy(source: InterleavedBuffer): InterleavedBuffer;\n copyAt(index1: number, attribute: InterleavedBufferAttribute, index2: number): InterleavedBuffer;\n set(value: ArrayLike, index: number): InterleavedBuffer;\n clone(): InterleavedBuffer;\n }\n\n /**\n * @see src/core/InstancedInterleavedBuffer.js\n */\n export class InstancedInterleavedBuffer extends InterleavedBuffer {\n constructor(array: ArrayLike, stride: number, meshPerAttribute?: number);\n\n meshPerAttribute: number;\n\n clone(): InstancedInterleavedBuffer;\n copy(source: InstancedInterleavedBuffer): InstancedInterleavedBuffer;\n }\n\n /**\n * @see src/core/InterleavedBufferAttribute.js\n */\n export class InterleavedBufferAttribute {\n constructor(interleavedBuffer: InterleavedBuffer, itemSize: number, offset: number, normalized: boolean);\n\n uuid: string;\n data: InterleavedBuffer;\n itemSize: number;\n offset: number;\n count: number;\n normalized: boolean;\n array: any[];\n\n getX(index: number): number;\n setX(index: number, x: number): InterleavedBufferAttribute;\n getY(index: number): number;\n setY(index: number, y: number): InterleavedBufferAttribute;\n getZ(index: number): number;\n setZ(index: number, z: number): InterleavedBufferAttribute;\n getW(index: number): number;\n setW(index: number, z: number): InterleavedBufferAttribute;\n setXY(index: number, x: number, y: number): InterleavedBufferAttribute;\n setXYZ(index: number, x: number, y: number, z: number): InterleavedBufferAttribute;\n setXYZW(index: number, x: number, y: number, z: number, w: number): InterleavedBufferAttribute;\n\n length: number; // deprecated, use count instead\n }\n\n export let Object3DIdCount: number;\n\n /**\n * Base class for scene graph objects\n */\n export class Object3D extends EventDispatcher {\n constructor();\n\n /**\n * Unique number of this object instance.\n */\n id: number;\n\n /**\n *\n */\n uuid: string;\n\n /**\n * Optional name of the object (doesn't need to be unique).\n */\n name: string;\n\n type: string;\n\n /**\n * Object's parent in the scene graph.\n */\n parent: Object3D;\n\n /**\n * Array with object's children.\n */\n children: Object3D[];\n\n /**\n * Up direction.\n */\n up: Vector3;\n\n /**\n * Object's local position.\n */\n position: Vector3;\n\n /**\n * Object's local rotation (Euler angles), in radians.\n */\n rotation: Euler;\n\n /**\n * Global rotation.\n */\n quaternion: Quaternion;\n\n /**\n * Object's local scale.\n */\n scale: Vector3;\n\n modelViewMatrix: Matrix4;\n\n normalMatrix: Matrix3;\n\n /**\n * Local transform.\n */\n matrix: Matrix4;\n\n /**\n * The global transform of the object. If the Object3d has no parent, then it's identical to the local transform.\n */\n matrixWorld: Matrix4;\n\n /**\n * When this is set, it calculates the matrix of position, (rotation or quaternion) and scale every frame and also recalculates the matrixWorld property.\n */\n matrixAutoUpdate: boolean;\n\n /**\n * When this is set, it calculates the matrixWorld in that frame and resets this property to false.\n */\n matrixWorldNeedsUpdate: boolean;\n\n layers: Layers;\n /**\n * Object gets rendered if true.\n */\n visible: boolean;\n\n /**\n * Gets rendered into shadow map.\n */\n castShadow: boolean;\n\n /**\n * Material gets baked in shadow receiving.\n */\n receiveShadow: boolean;\n\n /**\n * When this is set, it checks every frame if the object is in the frustum of the camera. Otherwise the object gets drawn every frame even if it isn't visible.\n */\n frustumCulled: boolean;\n\n renderOrder: number;\n\n /**\n * An object that can be used to store custom data about the Object3d. It should not hold references to functions as these will not be cloned.\n */\n userData: any;\n\n /**\n *\n */\n static DefaultUp: Vector3;\n static DefaultMatrixAutoUpdate: boolean;\n\n /**\n * This updates the position, rotation and scale with the matrix.\n */\n applyMatrix(matrix: Matrix4): void;\n\n /**\n *\n */\n setRotationFromAxisAngle(axis: Vector3, angle: number): void;\n\n /**\n *\n */\n setRotationFromEuler(euler: Euler): void;\n\n /**\n *\n */\n setRotationFromMatrix(m: Matrix4): void;\n\n /**\n *\n */\n setRotationFromQuaternion(q: Quaternion): void;\n\n /**\n * Rotate an object along an axis in object space. The axis is assumed to be normalized.\n * @param axis A normalized vector in object space.\n * @param angle The angle in radians.\n */\n rotateOnAxis(axis: Vector3, angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateX(angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateY(angle: number): Object3D;\n\n /**\n *\n * @param angle\n */\n rotateZ(angle: number): Object3D;\n\n /**\n * @param axis A normalized vector in object space.\n * @param distance The distance to translate.\n */\n translateOnAxis(axis: Vector3, distance: number): Object3D;\n\n /**\n * Translates object along x axis by distance.\n * @param distance Distance.\n */\n translateX(distance: number): Object3D;\n\n /**\n * Translates object along y axis by distance.\n * @param distance Distance.\n */\n translateY(distance: number): Object3D;\n\n /**\n * Translates object along z axis by distance.\n * @param distance Distance.\n */\n translateZ(distance: number): Object3D;\n\n /**\n * Updates the vector from local space to world space.\n * @param vector A local vector.\n */\n localToWorld(vector: Vector3): Vector3;\n\n /**\n * Updates the vector from world space to local space.\n * @param vector A world vector.\n */\n worldToLocal(vector: Vector3): Vector3;\n\n /**\n * Rotates object to face point in space.\n * @param vector A world vector to look at.\n */\n lookAt(vector: Vector3): void;\n\n /**\n * Adds object as child of this object.\n */\n add(object: Object3D): void;\n\n /**\n * Removes object as child of this object.\n */\n remove(object: Object3D): void;\n\n /**\n * Searches through the object's children and returns the first with a matching id, optionally recursive.\n * @param id Unique number of the object instance\n */\n getObjectById(id: number): Object3D;\n\n /**\n * Searches through the object's children and returns the first with a matching name, optionally recursive.\n * @param name String to match to the children's Object3d.name property.\n */\n getObjectByName(name: string): Object3D;\n\n getObjectByProperty( name: string, value: string ): Object3D;\n\n getWorldPosition(optionalTarget?: Vector3): Vector3;\n getWorldQuaternion(optionalTarget?: Quaternion): Quaternion;\n getWorldRotation(optionalTarget?: Euler): Euler;\n getWorldScale(optionalTarget?: Vector3): Vector3;\n getWorldDirection(optionalTarget?: Vector3): Vector3;\n\n raycast(raycaster: Raycaster, intersects: any): void;\n\n traverse(callback: (object: Object3D) => any): void;\n\n traverseVisible(callback: (object: Object3D) => any): void;\n\n traverseAncestors(callback: (object: Object3D) => any): void;\n\n /**\n * Updates local transform.\n */\n updateMatrix(): void;\n\n /**\n * Updates global transform of the object and its children.\n */\n updateMatrixWorld(force: boolean): void;\n\n toJSON(meta?: { geometries: any, materials: any, textures: any, images: any }): any;\n\n clone(recursive?: boolean): Object3D;\n\n /**\n *\n * @param object\n * @param recursive\n */\n copy(source: Object3D, recursive?: boolean): Object3D;\n\n // deprecated\n eulerOrder: string;\n getChildByName(name: string): Object3D;\n translate(distance: number, axis: Vector3): Object3D;\n }\n\n export interface Intersection {\n distance: number;\n distanceToRay: number;\n point: Vector3;\n index: number;\n face: Face3;\n faceIndex: number;\n object: Object3D;\n }\n\n export interface RaycasterParameters {\n Mesh?: any;\n Line?: any;\n LOD?: any;\n Points?: { threshold: number };\n Sprite?: any;\n }\n\n export class Raycaster {\n constructor(origin?: Vector3, direction?: Vector3, near?: number, far?: number);\n\n ray: Ray;\n near: number;\n far: number;\n params: RaycasterParameters;\n precision: number;\n linePrecision: number;\n\n set(origin: Vector3, direction: Vector3): void;\n setFromCamera(coords: { x: number; y: number; }, camera: Camera ): void;\n intersectObject(object: Object3D, recursive?: boolean): Intersection[];\n intersectObjects(objects: Object3D[], recursive?: boolean): Intersection[];\n }\n\n export class Layers {\n constructor();\n\n mask: number;\n\n set(channel: number): void;\n enable(channel: number): void;\n toggle(channel: number): void;\n disable(channel: number): void;\n test(layers: Layers): boolean;\n }\n\n export class Font {\n constructor(jsondata: string);\n\n data: string;\n\n generateShapes(text: string, size: number, divisions: number): any[];\n }\n\n // Lights //////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Abstract base class for lights.\n */\n export class Light extends Object3D {\n constructor(hex?: number|string, intensity?: number);\n\n color: Color;\n intensity: number;\n receiveShadow: boolean;\n shadow: LightShadow;\n shadowCameraFov: any; // deprecated, use shadow.camera.fov\n shadowCameraLeft: any; // deprecated, use shadow.camera.left\n shadowCameraRight: any; // deprecated, use shadow.camera.right\n shadowCameraTop: any; // deprecated, use shadow.camera.top\n shadowCameraBottom: any; // deprecated, use shadow.camera.bottom\n shadowCameraNear: any; // deprecated, use shadow.camera.near\n shadowCameraFar: any; // deprecated, use shadow.camera.far\n shadowBias: any; // deprecated, use shadow.bias\n shadowMapWidth: any; // deprecated, use shadow.mapSize.width\n shadowMapHeight: any; // deprecated, use shadow.mapSize.height\n\n copy(source: Light): Light;\n clone(recursive?: boolean): Light;\n }\n\n export class LightShadow {\n constructor(camera: Camera);\n\n camera: Camera;\n bias: number;\n radius: number;\n mapSize: Vector2;\n map: RenderTarget;\n matrix: Matrix4;\n\n copy(source: LightShadow): LightShadow;\n clone(recursive?: boolean): LightShadow;\n toJSON(): any;\n }\n\n /**\n * This light's color gets applied to all the objects in the scene globally.\n *\n * # example\n * var light = new THREE.AmbientLight( 0x404040 ); // soft white light\n * scene.add( light );\n *\n * @source https://github.com/mrdoob/three.js/blob/master/src/lights/AmbientLight.js\n */\n export class AmbientLight extends Light {\n /**\n * This creates a Ambientlight with a color.\n * @param hex Numeric value of the RGB component of the color.\n */\n constructor(hex?: number|string, intensity?: number);\n\n castShadow: boolean;\n\n copy(source: AmbientLight): AmbientLight;\n clone(recursive?: boolean): AmbientLight;\n }\n\n /**\n * Affects objects using MeshLambertMaterial or MeshPhongMaterial.\n *\n * @example\n * // White directional light at half intensity shining from the top.\n * var directionalLight = new THREE.DirectionalLight( 0xffffff, 0.5 );\n * directionalLight.position.set( 0, 1, 0 );\n * scene.add( directionalLight );\n *\n * @see src/lights/DirectionalLight.js\n */\n export class DirectionalLight extends Light {\n constructor(hex?: number|string, intensity?: number);\n\n /**\n * Target used for shadow camera orientation.\n */\n target: Object3D;\n\n /**\n * Light's intensity.\n * Default — 1.0.\n */\n intensity: number;\n\n shadow: LightShadow;\n\n copy(source: DirectionalLight): DirectionalLight;\n clone(recursive?: boolean): HemisphereLight;\n }\n\n export class DirectionalLightShadow extends LightShadow {}\n\n export class HemisphereLight extends Light {\n constructor(skyColorHex?: number|string, groundColorHex?: number|string, intensity?: number);\n\n groundColor: Color;\n intensity: number;\n\n copy(source: HemisphereLight): HemisphereLight;\n clone(recursive?: boolean): HemisphereLight;\n }\n\n /**\n * Affects objects using {@link MeshLambertMaterial} or {@link MeshPhongMaterial}.\n *\n * @example\n * var light = new THREE.PointLight( 0xff0000, 1, 100 );\n * light.position.set( 50, 50, 50 );\n * scene.add( light );\n */\n export class PointLight extends Light {\n constructor(hex?: number|string, intensity?: number, distance?: number, decay?: number);\n\n /*\n * Light's intensity.\n * Default - 1.0.\n */\n intensity: number;\n\n /**\n * If non-zero, light will attenuate linearly from maximum intensity at light position down to zero at distance.\n * Default — 0.0.\n */\n distance: number;\n\n decay: number;\n shadow: LightShadow;\n power: number;\n\n copy(source: PointLight): PointLight;\n clone(recursive?: boolean): PointLight;\n }\n\n /**\n * A point light that can cast shadow in one direction.\n */\n export class SpotLight extends Light {\n constructor(hex?: number|string, intensity?: number, distance?: number, angle?: number, exponent?: number, decay?: number);\n\n /**\n * Spotlight focus points at target.position.\n * Default position — (0,0,0).\n */\n target: Object3D;\n\n /**\n * Light's intensity.\n * Default — 1.0.\n */\n intensity: number;\n\n /**\n * If non-zero, light will attenuate linearly from maximum intensity at light position down to zero at distance.\n * Default — 0.0.\n */\n distance: number;\n\n /*\n * Maximum extent of the spotlight, in radians, from its direction.\n * Default — Math.PI/2.\n */\n angle: number;\n\n /**\n * Rapidity of the falloff of light from its target direction.\n * Default — 10.0.\n */\n exponent: number;\n\n decay: number;\n shadow: SpotLightShadow;\n power: number;\n penumbra: number;\n\n clone(recursive?: boolean): SpotLight;\n copy(source: PointLight): SpotLight;\n }\n\n export class SpotLightShadow extends LightShadow {\n update(light: Light): void;\n }\n\n // Loaders //////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Base class for implementing loaders.\n *\n * Events:\n * load\n * Dispatched when the image has completed loading\n * content — loaded image\n *\n * error\n *\n * Dispatched when the image can't be loaded\n * message — error message\n */\n export class Loader {\n constructor();\n\n /**\n * Will be called when load starts.\n * The default is a function with empty body.\n */\n onLoadStart: () => void;\n\n /**\n * Will be called while load progresses.\n * The default is a function with empty body.\n */\n onLoadProgress: () => void;\n\n /**\n * Will be called when load completes.\n * The default is a function with empty body.\n */\n onLoadComplete: () => void;\n\n /**\n * default — null.\n * If set, assigns the crossOrigin attribute of the image to the value of crossOrigin, prior to starting the load.\n */\n crossOrigin: string;\n\n extractUrlBase(url: string): string;\n initMaterials(materials: Material[], texturePath: string): Material[];\n createMaterial(m: Material, texturePath: string, crossOrigin?: string): boolean;\n\n static Handlers: LoaderHandler;\n }\n\n export interface LoaderHandler {\n handlers: (RegExp | Loader)[];\n\n add(regex: RegExp, loader: Loader): void;\n get(file: string): Loader;\n }\n\n export class XHRLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n path: string;\n responseType: string;\n withCredentials: boolean;\n\n load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): any;\n setPath(path: string): XHRLoader;\n setResponseType(responseType: string): XHRLoader;\n setWithCredentials(withCredentials: boolean): XHRLoader;\n }\n\n export class FontLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n\n load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n parse(json: string): Font;\n }\n\n /**\n * A loader for loading an image.\n * Unlike other loaders, this one emits events instead of using predefined callbacks. So if you're interested in getting notified when things happen, you need to add listeners to the object.\n */\n export class ImageLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n crossOrigin: string;\n withCredentials: string;\n path: string;\n\n /**\n * Begin loading from url\n * @param url\n */\n load(url: string, onLoad?: (image: HTMLImageElement) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): HTMLImageElement;\n setCrossOrigin(crossOrigin: string): ImageLoader;\n setWithCredentials(value: string): ImageLoader;\n setPath(value: string): ImageLoader;\n }\n\n /**\n * A loader for loading objects in JSON format.\n */\n export class JSONLoader extends Loader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n withCredentials: boolean;\n\n load(url: string, onLoad?: (geometry: Geometry, materials: Material[]) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n setTexturePath( value: string ): void;\n parse(json: any, texturePath?: string): { geometry: Geometry; materials?: Material[] };\n }\n\n /**\n * Handles and keeps track of loaded and pending data.\n */\n export class LoadingManager {\n constructor(onLoad?: () => void, onProgress?: (url: string, loaded: number, total: number) => void, onError?: () => void);\n\n onStart: () => void;\n\n /**\n * Will be called when load starts.\n * The default is a function with empty body.\n */\n onLoad: () => void;\n\n /**\n * Will be called while load progresses.\n * The default is a function with empty body.\n */\n onProgress: (item: any, loaded: number, total: number) => void;\n\n /**\n * Will be called when each element in the scene completes loading.\n * The default is a function with empty body.\n */\n onError: () => void;\n\n itemStart(url: string): void;\n itemEnd(url: string): void;\n itemError(url: string): void;\n }\n\n export const DefaultLoadingManager: LoadingManager;\n\n export class BufferGeometryLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n\n load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n parse(json: any): BufferGeometry;\n }\n\n export class MaterialLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n textures: { [key: string]: Texture };\n\n load(url: string, onLoad: (material: Material) => void): void;\n setTextures(textures: { [key: string]: Texture }): void;\n getTexture(name: string): Texture;\n parse(json: any): Material;\n }\n\n export class ObjectLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n texturePass: string;\n crossOrigin: string;\n\n load(url: string, onLoad?: (object: Object3D) => void): void;\n setTexturePath( value: string ): void;\n setCrossOrigin(crossOrigin: string): void;\n parse(json: any, onLoad?: (object: Object3D) => void): T;\n parseGeometries(json: any): any[]; // Array of BufferGeometry or Geometry or Geometry2.\n parseMaterials(json: any, textures: Texture[]): Material[]; // Array of Classes that inherits from Matrial.\n parseAnimations(json: any): AnimationClip[];\n parseImages(json: any, onLoad: () => void): any[];\n parseTextures(json: any, images: any): Texture[];\n parseObject(data: any, geometries: any[], materials: Material[]): T;\n }\n\n /**\n * Class for loading a texture.\n * Unlike other loaders, this one emits events instead of using predefined callbacks. So if you're interested in getting notified when things happen, you need to add listeners to the object.\n */\n export class TextureLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n crossOrigin: string;\n withCredentials: string;\n path: string;\n\n /**\n * Begin loading from url\n *\n * @param url\n */\n load(url: string, onLoad?: (texture: Texture) => void): Texture;\n setCrossOrigin(crossOrigin: string): TextureLoader;\n setWithCredentials(value: string): TextureLoader;\n setPath(path: string): TextureLoader;\n }\n\n export class CubeTextureLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n corssOrigin: string;\n path: string;\n\n load(urls: Array, onLoad?: (texture: CubeTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n setCrossOrigin(crossOrigin: string): CubeTextureLoader;\n setPath(path: string): CubeTextureLoader;\n }\n\n export class BinaryTextureLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n\n load(url: string, onLoad: (dataTexture: DataTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n }\n export class DataTextureLoader extends BinaryTextureLoader {}\n\n export class CompressedTextureLoader {\n constructor(manager?: LoadingManager);\n\n manager: LoadingManager;\n path: string;\n\n load(url: string, onLoad: (texture: CompressedTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void;\n setPath(path: string): CompressedTextureLoader;\n }\n\n export class AudioLoader {\n constructor(manager?: LoadingManager);\n\n load(url: string, onLoad: Function, onPrgress: Function, onError: Function): void;\n }\n\n export namespace Cache {\n export let enabled: boolean;\n export let files: any;\n\n export function add(key: string, file: any): void;\n export function get(key: string): any;\n export function remove(key: string): void;\n export function clear(): void;\n }\n\n // Materials //////////////////////////////////////////////////////////////////////////////////\n export let MaterialIdCount: number;\n\n export interface MaterialParameters {\n name?: string;\n side?: Side;\n opacity?: number;\n transparent?: boolean;\n blending?: Blending;\n blendSrc?: BlendingDstFactor;\n blendDst?: BlendingSrcFactor;\n blendEquation?: BlendingEquation;\n blendSrcAlpha?: number;\n blendDstAlpha?: number;\n blendEquationAlpha?: number;\n depthFunc?: DepthModes;\n depthTest?: boolean;\n depthWrite?: boolean;\n colorWrite?: boolean;\n precision?: number;\n polygonOffset?: boolean;\n polygonOffsetFactor?: number;\n polygonOffsetUnits?: number;\n alphaTest?: number;\n premultipliedAlpha?: boolean;\n overdraw?: number;\n visible?: boolean;\n fog?: boolean;\n lights?: boolean;\n shading?: Shading;\n vertexColors?: Colors;\n }\n\n /**\n * Materials describe the appearance of objects. They are defined in a (mostly) renderer-independent way, so you don't have to rewrite materials if you decide to use a different renderer.\n */\n export class Material extends EventDispatcher {\n constructor();\n\n /**\n * Unique number of this material instance.\n */\n id: number;\n\n uuid: string;\n\n /**\n * Material name. Default is an empty string.\n */\n name: string;\n\n type: string;\n\n /**\n * Defines which of the face sides will be rendered - front, back or both.\n * Default is THREE.FrontSide. Other options are THREE.BackSide and THREE.DoubleSide.\n */\n side: Side;\n\n /**\n * Opacity. Default is 1.\n */\n opacity: number;\n\n /**\n * Defines whether this material is transparent. This has an effect on rendering, as transparent objects need an special treatment, and are rendered after the opaque (i.e. non transparent) objects. For a working example of this behaviour, check the {@link WebGLRenderer} code.\n * Default is false.\n */\n transparent: boolean;\n\n /**\n * Which blending to use when displaying objects with this material. Default is {@link NormalBlending}.\n */\n blending: Blending;\n\n /**\n * Blending source. It's one of the blending mode constants defined in Three.js. Default is {@link SrcAlphaFactor}.\n */\n blendSrc: BlendingDstFactor;\n\n /**\n * Blending destination. It's one of the blending mode constants defined in Three.js. Default is {@link OneMinusSrcAlphaFactor}.\n */\n blendDst: BlendingSrcFactor;\n\n /**\n * Blending equation to use when applying blending. It's one of the constants defined in Three.js. Default is AddEquation.\n */\n blendEquation: BlendingEquation;\n\n blendSrcAlpha: number;\n blendDstAlpha: number;\n blendEquationAlpha: number;\n\n depthFunc: DepthModes;\n\n /**\n * Whether to have depth test enabled when rendering this material. Default is true.\n */\n depthTest: boolean;\n\n /**\n * Whether rendering this material has any effect on the depth buffer. Default is true.\n * When drawing 2D overlays it can be useful to disable the depth writing in order to layer several things together without creating z-index artifacts.\n */\n depthWrite: boolean;\n\n clippingPlanes: any;\n clipShadows: boolean;\n\n colorWrite: boolean;\n\n precision: any;\n\n /**\n * Whether to use polygon offset. Default is false. This corresponds to the POLYGON_OFFSET_FILL WebGL feature.\n */\n polygonOffset: boolean;\n\n /**\n * Sets the polygon offset factor. Default is 0.\n */\n polygonOffsetFactor: number;\n\n /**\n * Sets the polygon offset units. Default is 0.\n */\n polygonOffsetUnits: number;\n\n /**\n * Sets the alpha value to be used when running an alpha test. Default is 0.\n */\n alphaTest: number;\n\n premultipliedAlpha: boolean;\n\n /**\n * Enables/disables overdraw. If greater than zero, polygons are drawn slightly bigger in order to fix antialiasing gaps when using the CanvasRenderer. Default is 0.\n */\n overdraw: number;\n\n /**\n * Defines whether this material is visible. Default is true.\n */\n visible: boolean;\n\n /**\n * Specifies that the material needs to be updated, WebGL wise. Set it to true if you made changes that need to be reflected in WebGL.\n * This property is automatically set to true when instancing a new material.\n */\n needsUpdate: boolean;\n\n fog: boolean;\n lights: boolean;\n shading: Shading;\n vertexColors: Colors;\n\n setValues(parameters: MaterialParameters): void;\n toJSON(meta?: any): any;\n clone(): Material;\n copy(source: Material): Material;\n update(): void;\n dispose(): void;\n\n // deprecated\n warpRGB: Color;\n }\n\n export interface LineBasicMaterialParameters extends MaterialParameters {\n color?: number|string;\n linewidth?: number;\n linecap?: string;\n linejoin?: string;\n }\n\n export class LineBasicMaterial extends Material {\n constructor(parameters?: LineBasicMaterialParameters);\n\n color: Color;\n linewidth: number;\n linecap: string;\n linejoin: string;\n\n setValues(parameters: LineBasicMaterialParameters): void;\n clone(): LineBasicMaterial;\n copy(source: LineBasicMaterial): LineBasicMaterial;\n }\n\n export interface LineDashedMaterialParameters extends MaterialParameters {\n color?: number|string;\n linewidth?: number;\n scale?: number;\n dashSize?: number;\n gapSize?: number;\n }\n\n export class LineDashedMaterial extends Material {\n constructor(parameters?: LineDashedMaterialParameters);\n\n color: Color;\n linewidth: number;\n scale: number;\n dashSize: number;\n gapSize: number;\n\n setValues(parameters: LineDashedMaterialParameters): void;\n clone(): LineDashedMaterial;\n copy(source: LineDashedMaterial): LineDashedMaterial;\n }\n\n /**\n * parameters is an object with one or more properties defining the material's appearance.\n */\n export interface MeshBasicMaterialParameters extends MaterialParameters {\n color?: number|string;\n opacity?: number;\n map?: Texture;\n aoMap?: Texture;\n aoMapIntensity?: number;\n specularMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n shading?: Shading;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n wireframeLinecap?: string;\n wireframeLinejoin?: string;\n skinning?: boolean;\n morphTargets?: boolean;\n }\n\n export class MeshBasicMaterial extends Material {\n constructor(parameters?: MeshBasicMaterialParameters);\n\n color: Color;\n map: Texture;\n aoMap: Texture;\n aoMapIntensity: number;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n shading: Shading;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n skinning: boolean;\n morphTargets: boolean;\n\n setValues(parameters: MeshBasicMaterialParameters): void;\n clone(): MeshBasicMaterial;\n copy(source: MeshBasicMaterial): MeshBasicMaterial;\n }\n\n export interface MeshDepthMaterialParameters extends MaterialParameters {\n wireframe?: boolean;\n wireframeLinewidth?: number;\n }\n\n export class MeshDepthMaterial extends Material {\n constructor(parameters?: MeshDepthMaterialParameters);\n\n wireframe: boolean;\n wireframeLinewidth: number;\n\n setValues(parameters: MeshDepthMaterialParameters): void;\n clone(): MeshDepthMaterial;\n copy(source: MeshDepthMaterial): MeshDepthMaterial;\n }\n\n export interface MeshLambertMaterialParameters extends MaterialParameters {\n color?: number|string;\n emissive?: number|string;\n emissiveIntensity?: number;\n emissiveMap?: Texture;\n map?: Texture;\n lighhtMap?: Texture;\n lightMapIntensity?: number;\n aoMap?: Texture;\n aoMapIntensity?: number;\n specularMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n wireframeLinecap?: string;\n wireframeLinejoin?: string;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class MeshLambertMaterial extends Material {\n constructor(parameters?: MeshLambertMaterialParameters);\n\n color: Color;\n emissive: number|string;\n emissiveIntensity: number;\n emissiveMap: Texture;\n map: Texture;\n lighhtMap: Texture;\n lightMapIntensity: number;\n aoMap: Texture;\n aoMapIntensity: number;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n\n setValues(parameters: MeshLambertMaterialParameters): void;\n clone(): MeshLambertMaterial;\n copy(source: MeshLambertMaterial): MeshLambertMaterial;\n }\n\n export interface MeshStandardMaterialParameters extends MaterialParameters {\n color?: number|string;\n roughness?: number;\n metalness?: number;\n map?: Texture;\n lighhtMap?: Texture;\n lightMapIntensity?: number;\n aoMap?: Texture;\n aoMapIntensity?: number;\n emissive?: Color;\n emissiveIntensity?: number;\n emissiveMap?: Texture;\n bumpMap?: Texture;\n bumpScale?: number;\n normalMap?: Texture;\n normalScale?: number;\n displacementMap?: Texture;\n displacementScale?: number;\n displacementBias?: number;\n roughnessMap?: Texture;\n metalMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n envMapIntensity?: number;\n refractionRatio?: number;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class MeshStandardMaterial extends Material {\n constructor(parameters?: MeshStandardMaterialParameters);\n\n defines: any;\n color: Color;\n roughness: number;\n metalness: number;\n map: Texture;\n lighhtMap: Texture;\n lightMapIntensity: number;\n aoMap: Texture;\n aoMapIntensity: number;\n emissive: Color;\n emissiveIntensity: number;\n emissiveMap: Texture;\n bumpMap: Texture;\n bumpScale: number;\n normalMap: Texture;\n normalScale: number;\n displacementMap: Texture;\n displacementScale: number;\n displacementBias: number;\n roughnessMap: Texture;\n metalMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n envMapIntensity: number;\n refractionRatio: number;\n wireframe: boolean;\n wireframeLinewidth: number;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n\n setValues(parameters: MeshStandardMaterialParameters): void;\n clone(): MeshStandardMaterial;\n copy(source: MeshStandardMaterial): MeshStandardMaterial;\n }\n\n export interface MeshNormalMaterialParameters extends MaterialParameters {\n /** Render geometry as wireframe. Default is false (i.e. render as smooth shaded). */\n wireframe?: boolean;\n /** Controls wireframe thickness. Default is 1. */\n wireframeLinewidth?: number;\n morphTargets?: boolean;\n }\n\n export class MeshNormalMaterial extends Material {\n constructor(parameters?: MeshNormalMaterialParameters);\n\n wireframe: boolean;\n wireframeLinewidth: number;\n morphTargets: boolean;\n\n setValues(parameters: MeshNormalMaterialParameters): void;\n clone(): MeshNormalMaterial;\n copy(source: MeshNormalMaterial): MeshNormalMaterial;\n }\n\n export interface MeshPhongMaterialParameters extends MaterialParameters {\n /** geometry color in hexadecimal. Default is 0xffffff. */\n color?: number|string;\n specular?: number;\n shininess?: number;\n opacity?: number;\n map?: Texture;\n lightMap?: Texture;\n lightMapIntensity?: number;\n aoMap?: Texture;\n aoMapIntensity?: number;\n emissive?: number;\n emissiveIntensity?: number;\n emissiveMap?: Texture;\n bumpMap?: Texture;\n bumpScale?: number;\n normalMap?: Texture;\n normalScale?: Vector2;\n displacementMap?: Texture;\n displacementScale?: number;\n displacementBias?: number;\n specularMap?: Texture;\n alphaMap?: Texture;\n envMap?: Texture;\n combine?: Combine;\n reflectivity?: number;\n refractionRatio?: number;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n wireframeLinecap?: string;\n wireframeLinejoin?: string;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class MeshPhongMaterial extends Material {\n constructor(parameters?: MeshPhongMaterialParameters);\n\n color: Color; // diffuse\n specular: Color;\n shininess: number;\n map: Texture;\n lightMap: Texture;\n lightMapIntensity: number;\n aoMap: Texture;\n aoMapIntensity: number;\n emissive: Color;\n emissiveIntensity: number;\n emissiveMap: Texture;\n bumpMap: Texture;\n bumpScale: number;\n normalMap: Texture;\n normalScale: Vector2;\n displacementMap: Texture;\n displacementScale: number;\n displacementBias: number;\n specularMap: Texture;\n alphaMap: Texture;\n envMap: Texture;\n combine: Combine;\n reflectivity: number;\n refractionRatio: number;\n wireframe: boolean;\n wireframeLinewidth: number;\n wireframeLinecap: string;\n wireframeLinejoin: string;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n metal: boolean; // deprecated\n\n setValues(parameters: MeshPhongMaterialParameters): void;\n clone(): MeshPhongMaterial;\n copy(source: MeshPhongMaterial): MeshPhongMaterial;\n }\n\n export interface MeshPhysicalMaterialParameters extends MeshStandardMaterialParameters {\n reflectivity?: number;\n clearCoat?: number;\n clearCoatRoughness?: number;\n }\n\n export class MeshPhysicalMaterial extends MeshStandardMaterial {\n constructor(parameters: MeshPhysicalMaterialParameters);\n\n defines: any;\n reflectivity: number;\n clearCoat: number;\n clearCoatRoughness: number;\n }\n\n // MultiMaterial does not inherit the Material class in the original code. However, it should treat as Material class.\n // See tests/canvas/canvas_materials.ts.\n export class MultiMaterial extends Material {\n constructor(materials?: Material[]);\n\n materials: Material[];\n\n toJSON(meta: any): any;\n clone(): MultiMaterial;\n }\n\n export class MeshFaceMaterial extends MultiMaterial {} // deprecated, use MultiMaterial\n\n export interface PointsMaterialParameters extends MaterialParameters {\n color?: number|string;\n map?: Texture;\n size?: number;\n sizeAttenuation?: boolean;\n }\n\n export class PointsMaterial extends Material {\n constructor(parameters?: PointsMaterialParameters);\n\n color: Color;\n map: Texture;\n size: number;\n sizeAttenuation: boolean;\n\n setValues(parameters: PointsMaterialParameters): void;\n clone(): PointsMaterial;\n copy(source: PointsMaterial): PointsMaterial;\n }\n\n export class PointCloudMaterial extends PointsMaterial {} // deprecated\n export class ParticleBasicMaterial extends PointsMaterial {} // deprecated\n export class ParticleSystemMaterial extends PointsMaterial {} // deprecated\n\n export interface ShaderMaterialParameters extends MaterialParameters {\n defines?: any;\n uniforms?: any;\n vertexShader?: string;\n fragmentShader?: string;\n lineWidth?: number;\n wireframe?: boolean;\n wireframeLinewidth?: number;\n lights?: boolean;\n clipping?: boolean;\n skinning?: boolean;\n morphTargets?: boolean;\n morphNormals?: boolean;\n }\n\n export class ShaderMaterial extends Material {\n constructor(parameters?: ShaderMaterialParameters);\n\n defines: any;\n uniforms: any; // type should be { [uniform: string]: { value: any }; }; but gives \"Index signature is missing in type\" error during compilation\n vertexShader: string;\n fragmentShader: string;\n linewidth: number;\n wireframe: boolean;\n wireframeLinewidth: number;\n lights: boolean;\n clipping: boolean;\n skinning: boolean;\n morphTargets: boolean;\n morphNormals: boolean;\n derivatives: any; // deprecated, use extensions.derivatives\n extensions: { derivatives: boolean; fragDepth: boolean; drawBuffers: boolean; shaderTextureLOD: boolean };\n defaultAttributeValues: any;\n index0AttributeName: string;\n\n setValues(parameters: ShaderMaterialParameters): void;\n clone(): ShaderMaterial;\n copy(source: ShaderMaterial): ShaderMaterial;\n toJSON(meta: any): any;\n }\n\n export class RawShaderMaterial extends ShaderMaterial {\n constructor(parameters?: ShaderMaterialParameters);\n }\n\n export interface SpriteMaterialParameters extends MaterialParameters {\n color?: number|string;\n map?: Texture;\n rotation?: number;\n }\n\n export class SpriteMaterial extends Material {\n constructor(parameters?: SpriteMaterialParameters);\n\n color: Color;\n map: Texture;\n rotation: number;\n\n setValues(parameters: SpriteMaterialParameters): void;\n clone(): SpriteMaterial;\n copy(source: SpriteMaterial): SpriteMaterial;\n }\n\n export class ShadowMaterial extends ShaderMaterial {\n constructor(parameters?: ShaderMaterialParameters);\n }\n\n // Math //////////////////////////////////////////////////////////////////////////////////\n\n export class Box2 {\n constructor(min?: Vector2, max?: Vector2);\n\n max: Vector2;\n min: Vector2;\n\n set(min: Vector2, max: Vector2): Box2;\n setFromPoints(points: Vector2[]): Box2;\n setFromCenterAndSize(center: Vector2, size: Vector2): Box2;\n clone(): Box2;\n copy(box: Box2): Box2;\n makeEmpty(): Box2;\n isEmpty(): boolean;\n center(optionalTarget?: Vector2): Vector2;\n size(optionalTarget?: Vector2): Vector2;\n expandByPoint(point: Vector2): Box2;\n expandByVector(vector: Vector2): Box2;\n expandByScalar(scalar: number): Box2;\n containsPoint(point: Vector2): boolean;\n containsBox(box: Box2): boolean;\n getParameter(point: Vector2): Vector2;\n intersectsBox(box: Box2): boolean;\n clampPoint(point: Vector2, optionalTarget?: Vector2): Vector2;\n distanceToPoint(point: Vector2): number;\n intersect(box: Box2): Box2;\n union(box: Box2): Box2;\n translate(offset: Vector2): Box2;\n equals(box: Box2): boolean;\n\n empty(): any; // deprecated, use isEmpty()\n isIntersectionBox(b: any): any; // deprecated, use intersectsBox()\n }\n\n export class Box3 {\n constructor(min?: Vector3, max?: Vector3);\n\n max: Vector3;\n min: Vector3;\n\n set(min: Vector3, max: Vector3): Box3;\n setFromArray(array: ArrayLike): Box3;\n setFromPoints(points: Vector3[]): Box3;\n setFromCenterAndSize(center: Vector3, size: Vector3): Box3;\n setFromObject(object: Object3D): Box3;\n clone(): Box3;\n copy(box: Box3): Box3;\n makeEmpty(): Box3;\n isEmpty(): boolean;\n center(optionalTarget?: Vector3): Vector3;\n size(optionalTarget?: Vector3): Vector3;\n expandByPoint(point: Vector3): Box3;\n expandByVector(vector: Vector3): Box3;\n expandByScalar(scalar: number): Box3;\n containsPoint(point: Vector3): boolean;\n containsBox(box: Box3): boolean;\n getParameter(point: Vector3): Vector3;\n intersectsBox(box: Box3): boolean;\n intersectsSphere(sphere: Sphere): boolean;\n intersectsPlane(plane: Plane): boolean;\n clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n distanceToPoint(point: Vector3): number;\n getBoundingSphere(optionalTarget?: Sphere): Sphere;\n intersect(box: Box3): Box3;\n union(box: Box3): Box3;\n applyMatrix4(matrix: Matrix4): Box3;\n translate(offset: Vector3): Box3;\n equals(box: Box3): boolean;\n\n empty(): any; // deprecated, use isEmpty()\n isIntersectionBox(b: any): any; // deprecated, use intersectsBox()\n isIntersectionSphere(s: any): any; // deprecated, use intersectsSphere()\n }\n\n export interface HSL {\n h: number;\n s: number;\n l: number;\n }\n\n /**\n * Represents a color. See also {@link ColorUtils}.\n *\n * @example\n * var color = new THREE.Color( 0xff0000 );\n *\n * @see src/math/Color.js\n */\n export class Color {\n constructor(color?: Color);\n constructor(color?: string);\n constructor(color?: number);\n constructor(r: number, g: number, b: number);\n\n /**\n * Red channel value between 0 and 1. Default is 1.\n */\n r: number;\n\n /**\n * Green channel value between 0 and 1. Default is 1.\n */\n g: number;\n\n /**\n * Blue channel value between 0 and 1. Default is 1.\n */\n b: number;\n\n set(color: Color): Color;\n set(color: number): Color;\n set(color: string): Color;\n setScalar(scalar: number): Color;\n setHex(hex: number): Color;\n\n /**\n * Sets this color from RGB values.\n * @param r Red channel value between 0 and 1.\n * @param g Green channel value between 0 and 1.\n * @param b Blue channel value between 0 and 1.\n */\n setRGB(r: number, g: number, b: number): Color;\n\n /**\n * Sets this color from HSL values.\n * Based on MochiKit implementation by Bob Ippolito.\n *\n * @param h Hue channel value between 0 and 1.\n * @param s Saturation value channel between 0 and 1.\n * @param l Value channel value between 0 and 1.\n */\n setHSL(h: number, s: number, l: number): Color;\n\n /**\n * Sets this color from a CSS context style string.\n * @param contextStyle Color in CSS context style format.\n */\n setStyle(style: string): Color;\n\n /**\n * Clones this color.\n */\n clone(): Color;\n\n /**\n * Copies given color.\n * @param color Color to copy.\n */\n copy(color: Color): Color;\n\n /**\n * Copies given color making conversion from gamma to linear space.\n * @param color Color to copy.\n */\n copyGammaToLinear(color: Color, gammaFactor?: number): Color;\n\n /**\n * Copies given color making conversion from linear to gamma space.\n * @param color Color to copy.\n */\n copyLinearToGamma(color: Color, gammaFactor?: number): Color;\n\n /**\n * Converts this color from gamma to linear space.\n */\n convertGammaToLinear(): Color;\n\n /**\n * Converts this color from linear to gamma space.\n */\n convertLinearToGamma(): Color;\n\n /**\n * Returns the hexadecimal value of this color.\n */\n getHex(): number;\n\n /**\n * Returns the string formated hexadecimal value of this color.\n */\n getHexString(): string;\n\n getHSL(): HSL;\n\n /**\n * Returns the value of this color in CSS context style.\n * Example: rgb(r, g, b)\n */\n getStyle(): string;\n\n offsetHSL(h: number, s: number, l: number): Color;\n\n add(color: Color): Color;\n addColors(color1: Color, color2: Color): Color;\n addScalar(s: number): Color;\n sub(color: Color): Color;\n multiply(color: Color): Color;\n multiplyScalar(s: number): Color;\n lerp(color: Color, alpha: number): Color;\n equals(color: Color): boolean;\n fromArray(rgb: number[], offset?: number): Color;\n toArray(array?: number[], offset?: number): number[];\n }\n\n export namespace ColorKeywords {\n export const aliceblue: number;\n export const antiquewhite: number;\n export const aqua: number;\n export const aquamarine: number;\n export const azure: number;\n export const beige: number;\n export const bisque: number;\n export const black: number;\n export const blanchedalmond: number;\n export const blue: number;\n export const blueviolet: number;\n export const brown: number;\n export const burlywood: number;\n export const cadetblue: number;\n export const chartreuse: number;\n export const chocolate: number;\n export const coral: number;\n export const cornflowerblue: number;\n export const cornsilk: number;\n export const crimson: number;\n export const cyan: number;\n export const darkblue: number;\n export const darkcyan: number;\n export const darkgoldenrod: number;\n export const darkgray: number;\n export const darkgreen: number;\n export const darkgrey: number;\n export const darkkhaki: number;\n export const darkmagenta: number;\n export const darkolivegreen: number;\n export const darkorange: number;\n export const darkorchid: number;\n export const darkred: number;\n export const darksalmon: number;\n export const darkseagreen: number;\n export const darkslateblue: number;\n export const darkslategray: number;\n export const darkslategrey: number;\n export const darkturquoise: number;\n export const darkviolet: number;\n export const deeppink: number;\n export const deepskyblue: number;\n export const dimgray: number;\n export const dimgrey: number;\n export const dodgerblue: number;\n export const firebrick: number;\n export const floralwhite: number;\n export const forestgreen: number;\n export const fuchsia: number;\n export const gainsboro: number;\n export const ghostwhite: number;\n export const gold: number;\n export const goldenrod: number;\n export const gray: number;\n export const green: number;\n export const greenyellow: number;\n export const grey: number;\n export const honeydew: number;\n export const hotpink: number;\n export const indianred: number;\n export const indigo: number;\n export const ivory: number;\n export const khaki: number;\n export const lavender: number;\n export const lavenderblush: number;\n export const lawngreen: number;\n export const lemonchiffon: number;\n export const lightblue: number;\n export const lightcoral: number;\n export const lightcyan: number;\n export const lightgoldenrodyellow: number;\n export const lightgray: number;\n export const lightgreen: number;\n export const lightgrey: number;\n export const lightpink: number;\n export const lightsalmon: number;\n export const lightseagreen: number;\n export const lightskyblue: number;\n export const lightslategray: number;\n export const lightslategrey: number;\n export const lightsteelblue: number;\n export const lightyellow: number;\n export const lime: number;\n export const limegreen: number;\n export const linen: number;\n export const magenta: number;\n export const maroon: number;\n export const mediumaquamarine: number;\n export const mediumblue: number;\n export const mediumorchid: number;\n export const mediumpurple: number;\n export const mediumseagreen: number;\n export const mediumslateblue: number;\n export const mediumspringgreen: number;\n export const mediumturquoise: number;\n export const mediumvioletred: number;\n export const midnightblue: number;\n export const mintcream: number;\n export const mistyrose: number;\n export const moccasin: number;\n export const navajowhite: number;\n export const navy: number;\n export const oldlace: number;\n export const olive: number;\n export const olivedrab: number;\n export const orange: number;\n export const orangered: number;\n export const orchid: number;\n export const palegoldenrod: number;\n export const palegreen: number;\n export const paleturquoise: number;\n export const palevioletred: number;\n export const papayawhip: number;\n export const peachpuff: number;\n export const peru: number;\n export const pink: number;\n export const plum: number;\n export const powderblue: number;\n export const purple: number;\n export const red: number;\n export const rosybrown: number;\n export const royalblue: number;\n export const saddlebrown: number;\n export const salmon: number;\n export const sandybrown: number;\n export const seagreen: number;\n export const seashell: number;\n export const sienna: number;\n export const silver: number;\n export const skyblue: number;\n export const slateblue: number;\n export const slategray: number;\n export const slategrey: number;\n export const snow: number;\n export const springgreen: number;\n export const steelblue: number;\n export const tan: number;\n export const teal: number;\n export const thistle: number;\n export const tomato: number;\n export const turquoise: number;\n export const violet: number;\n export const wheat: number;\n export const white: number;\n export const whitesmoke: number;\n export const yellow: number;\n export const yellowgreen: number;\n }\n\n export class Euler {\n constructor(x?: number, y?: number, z?: number, order?: string);\n\n x: number;\n y: number;\n z: number;\n order: string;\n onChangeCallback: Function;\n\n set(x: number, y: number, z: number, order?: string): Euler;\n clone(): Euler;\n copy(euler: Euler): Euler;\n setFromRotationMatrix(m: Matrix4, order?: string, update?: boolean): Euler;\n setFromQuaternion(q: Quaternion, order?: string, update?: boolean): Euler;\n setFromVector3( v: Vector3, order?: string ): Euler;\n reorder(newOrder: string): Euler;\n equals(euler: Euler): boolean;\n fromArray(xyzo: any[]): Euler;\n toArray(array?: number[], offset?: number): number[];\n toVector3(optionalResult?: Vector3): Vector3;\n onChange(callback: Function): void;\n\n static RotationOrders: string[];\n static DefaultOrder: string;\n }\n\n /**\n * Frustums are used to determine what is inside the camera's field of view. They help speed up the rendering process.\n */\n export class Frustum {\n constructor(p0?: Plane, p1?: Plane, p2?: Plane, p3?: Plane, p4?: Plane, p5?: Plane);\n\n /**\n * Array of 6 vectors.\n */\n planes: Plane[];\n\n set(p0?: number, p1?: number, p2?: number, p3?: number, p4?: number, p5?: number): Frustum;\n clone(): Frustum;\n copy(frustum: Frustum): Frustum;\n setFromMatrix(m: Matrix4): Frustum;\n intersectsObject(object: Object3D): boolean;\n intersectsObject(sprite: Sprite): boolean;\n intersectsSphere(sphere: Sphere): boolean;\n intersectsBox(box: Box3): boolean;\n containsPoint(point: Vector3): boolean;\n }\n\n export class Line3 {\n constructor(start?: Vector3, end?: Vector3);\n\n start: Vector3;\n end: Vector3;\n\n set(start?: Vector3, end?: Vector3): Line3;\n clone(): Line3;\n copy(line: Line3): Line3;\n center(optionalTarget?: Vector3): Vector3;\n delta(optionalTarget?: Vector3): Vector3;\n distanceSq(): number;\n distance(): number;\n at(t: number, optionalTarget?: Vector3): Vector3;\n closestPointToPointParameter(point: Vector3, clampToLine?: boolean): number;\n closestPointToPoint(point: Vector3, clampToLine?: boolean, optionalTarget?: Vector3): Vector3;\n applyMatrix4(matrix: Matrix4): Line3;\n equals(line: Line3): boolean;\n }\n\n /**\n *\n * @see src/math/Math.js\n */\n export namespace Math {\n export const DEG2RAD: number;\n export const RAD2DEG: number;\n\n export function generateUUID(): string;\n\n /**\n * Clamps the x to be between a and b.\n *\n * @param value Value to be clamped.\n * @param min Minimum value\n * @param max Maximum value.\n */\n export function clamp(value: number, min: number, max: number): number;\n export function euclideanModulo( n: number, m: number ): number;\n\n /**\n * Linear mapping of x from range [a1, a2] to range [b1, b2].\n *\n * @param x Value to be mapped.\n * @param a1 Minimum value for range A.\n * @param a2 Maximum value for range A.\n * @param b1 Minimum value for range B.\n * @param b2 Maximum value for range B.\n */\n export function mapLinear(x: number, a1: number, a2: number, b1: number, b2: number): number;\n\n export function smoothstep(x: number, min: number, max: number): number;\n\n export function smootherstep(x: number, min: number, max: number): number;\n\n /**\n * Random float from 0 to 1 with 16 bits of randomness.\n * Standard Math.random() creates repetitive patterns when applied over larger space.\n */\n export function random16(): number; // deprecated, use Math.random()\n\n /**\n * Random integer from low to high interval.\n */\n export function randInt(low: number, high: number): number;\n\n /**\n * Random float from low to high interval.\n */\n export function randFloat(low: number, high: number): number;\n\n /**\n * Random float from - range / 2 to range / 2 interval.\n */\n export function randFloatSpread(range: number): number;\n\n export function degToRad(degrees: number): number;\n\n export function radToDeg(radians: number): number;\n\n export function isPowerOfTwo(value: number): boolean;\n\n export function nearestPowerOfTwo(value: number): number;\n\n export function nextPowerOfTwo(value: number): number;\n }\n\n /**\n * ( interface Matrix<T> )\n */\n export interface Matrix {\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n /**\n * identity():T;\n */\n identity(): Matrix;\n\n /**\n * copy(m:T):T;\n */\n copy(m: Matrix): Matrix;\n\n /**\n * multiplyScalar(s:number):T;\n */\n multiplyScalar(s: number): Matrix;\n\n determinant(): number;\n\n /**\n * getInverse(matrix:T, throwOnInvertible?:boolean):T;\n */\n getInverse(matrix: Matrix, throwOnInvertible?: boolean): Matrix;\n\n /**\n * transpose():T;\n */\n transpose(): Matrix;\n\n /**\n * clone():T;\n */\n clone(): Matrix;\n }\n\n /**\n * ( class Matrix3 implements Matrix<Matrix3> )\n */\n export class Matrix3 implements Matrix {\n /**\n * Creates an identity matrix.\n */\n constructor();\n\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n set(n11: number, n12: number, n13: number, n21: number, n22: number, n23: number, n31: number, n32: number, n33: number): Matrix3;\n identity(): Matrix3;\n clone(): Matrix3;\n copy(m: Matrix3): Matrix3;\n setFromMatrix4(m: Matrix4): Matrix3;\n applyToVector3Array(array: ArrayLike, offset?: number, length?: number): ArrayLike;\n applyToBuffer(buffer: BufferAttribute, offset?: number, length?: number): BufferAttribute;\n multiplyScalar(s: number): Matrix3;\n determinant(): number;\n getInverse(matrix: Matrix3, throwOnDegenerate?: boolean): Matrix3;\n\n /**\n * Transposes this matrix in place.\n */\n transpose(): Matrix3;\n getNormalMatrix(matrix4: Matrix4): Matrix3;\n\n /**\n * Transposes this matrix into the supplied array r, and returns itself.\n */\n transposeIntoArray(r: number[]): number[];\n fromArray(array: number[]): Matrix3;\n toArray(): number[];\n\n // deprecated\n multiplyVector3(vector: Vector3): any;\n multiplyVector3Array(a: any): any;\n getInverse(matrix: Matrix4, throwOnDegenerate?: boolean): Matrix3;\n flattenToArrayOffset(array: number[], offset: number): number[];\n }\n\n /**\n * A 4x4 Matrix.\n *\n * @example\n * // Simple rig for rotating around 3 axes\n * var m = new THREE.Matrix4();\n * var m1 = new THREE.Matrix4();\n * var m2 = new THREE.Matrix4();\n * var m3 = new THREE.Matrix4();\n * var alpha = 0;\n * var beta = Math.PI;\n * var gamma = Math.PI/2;\n * m1.makeRotationX( alpha );\n * m2.makeRotationY( beta );\n * m3.makeRotationZ( gamma );\n * m.multiplyMatrices( m1, m2 );\n * m.multiply( m3 );\n */\n export class Matrix4 implements Matrix {\n constructor();\n\n /**\n * Float32Array with matrix values.\n */\n elements: Float32Array;\n\n /**\n * Sets all fields of this matrix.\n */\n set(n11: number, n12: number, n13: number, n14: number, n21: number, n22: number, n23: number, n24: number, n31: number, n32: number, n33: number, n34: number, n41: number, n42: number, n43: number, n44: number): Matrix4;\n\n /**\n * Resets this matrix to identity.\n */\n identity(): Matrix4;\n clone(): Matrix4;\n copy(m: Matrix4): Matrix4;\n copyPosition(m: Matrix4): Matrix4;\n extractBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4;\n makeBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4;\n\n /**\n * Copies the rotation component of the supplied matrix m into this matrix rotation component.\n */\n extractRotation(m: Matrix4): Matrix4;\n makeRotationFromEuler(euler: Euler): Matrix4;\n makeRotationFromQuaternion(q: Quaternion): Matrix4;\n /**\n * Constructs a rotation matrix, looking from eye towards center with defined up vector.\n */\n lookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix4;\n\n /**\n * Multiplies this matrix by m.\n */\n multiply(m: Matrix4): Matrix4;\n\n premultiply(m: Matrix4): Matrix4;\n\n /**\n * Sets this matrix to a x b.\n */\n multiplyMatrices(a: Matrix4, b: Matrix4): Matrix4;\n\n /**\n * Sets this matrix to a x b and stores the result into the flat array r.\n * r can be either a regular Array or a TypedArray.\n */\n multiplyToArray(a: Matrix4, b: Matrix4, r: number[]): Matrix4;\n\n /**\n * Multiplies this matrix by s.\n */\n multiplyScalar(s: number): Matrix4;\n applyToVector3Array(array: ArrayLike, offset?: number, length?: number): ArrayLike;\n applyToBuffer( buffer: BufferAttribute, offset?: number, length?: number): BufferAttribute;\n /**\n * Computes determinant of this matrix.\n * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm\n */\n determinant(): number;\n\n /**\n * Transposes this matrix.\n */\n transpose(): Matrix4;\n\n\n\n /**\n * Sets the position component for this matrix from vector v.\n */\n setPosition(v: Vector3): Matrix4;\n\n\n /**\n * Sets this matrix to the inverse of matrix m.\n * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm.\n */\n getInverse(m: Matrix4, throwOnDegeneratee?: boolean): Matrix4;\n\n /**\n * Multiplies the columns of this matrix by vector v.\n */\n scale(v: Vector3): Matrix4;\n\n getMaxScaleOnAxis(): number;\n /**\n * Sets this matrix as translation transform.\n */\n makeTranslation(x: number, y: number, z: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around x axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationX(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around y axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationY(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around z axis by theta radians.\n *\n * @param theta Rotation angle in radians.\n */\n makeRotationZ(theta: number): Matrix4;\n\n /**\n * Sets this matrix as rotation transform around axis by angle radians.\n * Based on http://www.gamedev.net/reference/articles/article1199.asp.\n *\n * @param axis Rotation axis.\n * @param theta Rotation angle in radians.\n */\n makeRotationAxis(axis: Vector3, angle: number): Matrix4;\n\n /**\n * Sets this matrix as scale transform.\n */\n makeScale(x: number, y: number, z: number): Matrix4;\n\n /**\n * Sets this matrix to the transformation composed of translation, rotation and scale.\n */\n compose(translation: Vector3, rotation: Quaternion, scale: Vector3): Matrix4;\n\n /**\n * Decomposes this matrix into the translation, rotation and scale components.\n * If parameters are not passed, new instances will be created.\n */\n decompose(translation?: Vector3, rotation?: Quaternion, scale?: Vector3): Object[]; // [Vector3, Quaternion, Vector3]\n\n /**\n * Creates a frustum matrix.\n */\n makeFrustum(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix4;\n\n /**\n * Creates a perspective projection matrix.\n */\n makePerspective(fov: number, aspect: number, near: number, far: number): Matrix4;\n\n /**\n * Creates an orthographic projection matrix.\n */\n makeOrthographic(left: number, right: number, top: number, bottom: number, near: number, far: number): Matrix4;\n equals( matrix: Matrix4 ): boolean;\n fromArray(array: number[]): Matrix4;\n toArray(): number[];\n\n // deprecated\n extractPosition(m: Matrix4): Matrix4;\n setRotationFromQuaternion(q: Quaternion): Matrix4;\n multiplyVector3(v: any): any;\n multiplyVector4(v: any): any;\n multiplyVector3Array(array: number[]): number[];\n rotateAxis(v: any): void;\n crossVector(v: any): void;\n flattenToArrayOffset(array: number[], offset: number): number[];\n }\n\n export class Plane {\n constructor(normal?: Vector3, constant?: number);\n\n normal: Vector3;\n constant: number;\n\n set(normal: Vector3, constant: number): Plane;\n setComponents(x: number, y: number, z: number, w: number): Plane;\n setFromNormalAndCoplanarPoint(normal: Vector3, point: Vector3): Plane;\n setFromCoplanarPoints(a: Vector3, b: Vector3, c: Vector3): Plane;\n clone(): Plane;\n copy(plane: Plane): Plane;\n normalize(): Plane;\n negate(): Plane;\n distanceToPoint(point: Vector3): number;\n distanceToSphere(sphere: Sphere): number;\n projectPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n orthoPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n intersectLine(line: Line3, optionalTarget?: Vector3): Vector3;\n intersectsLine(line: Line3): boolean;\n intersectsBox(box: Box3): boolean;\n coplanarPoint(optionalTarget?: boolean): Vector3;\n applyMatrix4(matrix: Matrix4, optionalNormalMatrix?: Matrix3): Plane;\n translate(offset: Vector3): Plane;\n equals(plane: Plane): boolean;\n\n // deprecated\n isIntersectionLine(l: any): any;\n }\n\n export class Spherical {\n constructor(radius?: number, phi?: number, theta?: number);\n\n set(radius: number, phi: number, theta: number): Spherical;\n clone(): Spherical;\n copy(other: Spherical): Spherical;\n makeSafe(): void;\n setFromVector3(vec3: Vector3): Spherical;\n }\n\n /**\n * Implementation of a quaternion. This is used for rotating things without incurring in the dreaded gimbal lock issue, amongst other advantages.\n *\n * @example\n * var quaternion = new THREE.Quaternion();\n * quaternion.setFromAxisAngle( new THREE.Vector3( 0, 1, 0 ), Math.PI / 2 );\n * var vector = new THREE.Vector3( 1, 0, 0 );\n * vector.applyQuaternion( quaternion );\n */\n export class Quaternion {\n /**\n * @param x x coordinate\n * @param y y coordinate\n * @param z z coordinate\n * @param w w coordinate\n */\n constructor(x?: number, y?: number, z?: number, w?: number);\n\n x: number;\n y: number;\n z: number;\n w: number;\n\n /**\n * Sets values of this quaternion.\n */\n set(x: number, y: number, z: number, w: number): Quaternion;\n\n /**\n * Clones this quaternion.\n */\n clone(): Quaternion;\n\n /**\n * Copies values of q to this quaternion.\n */\n copy(q: Quaternion): Quaternion;\n\n /**\n * Sets this quaternion from rotation specified by Euler angles.\n */\n setFromEuler(euler: Euler, update?: boolean): Quaternion;\n\n /**\n * Sets this quaternion from rotation specified by axis and angle.\n * Adapted from http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm.\n * Axis have to be normalized, angle is in radians.\n */\n setFromAxisAngle(axis: Vector3, angle: number): Quaternion;\n\n /**\n * Sets this quaternion from rotation component of m. Adapted from http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm.\n */\n setFromRotationMatrix(m: Matrix4): Quaternion;\n setFromUnitVectors(vFrom: Vector3, vTo: Vector3): Quaternion;\n /**\n * Inverts this quaternion.\n */\n inverse(): Quaternion;\n\n conjugate(): Quaternion;\n dot(v: Vector3): number;\n lengthSq(): number;\n\n /**\n * Computes length of this quaternion.\n */\n length(): number;\n\n /**\n * Normalizes this quaternion.\n */\n normalize(): Quaternion;\n\n /**\n * Multiplies this quaternion by b.\n */\n multiply(q: Quaternion): Quaternion;\n premultiply(q: Quaternion): Quaternion;\n\n /**\n * Sets this quaternion to a x b\n * Adapted from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm.\n */\n multiplyQuaternions(a: Quaternion, b: Quaternion): Quaternion;\n\n\n slerp(qb: Quaternion, t: number): Quaternion;\n equals(v: Quaternion): boolean;\n fromArray(n: number[]): Quaternion;\n toArray(): number[];\n\n fromArray(xyzw: number[], offset?: number): Quaternion;\n toArray(xyzw?: number[], offset?: number): number[];\n\n onChange(callback: Function): Quaternion;\n onChangeCallback: Function;\n\n /**\n * Adapted from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/.\n */\n static slerp(qa: Quaternion, qb: Quaternion, qm: Quaternion, t: number): Quaternion;\n\n static slerpFlat(dst: number[], dstOffset: number, src0: number[], srcOffset: number, src1: number[], stcOffset1: number, t: number): Quaternion;\n\n // deprecated\n multiplyVector3(v: any): any;\n }\n\n export class Ray {\n constructor(origin?: Vector3, direction?: Vector3);\n\n origin: Vector3;\n direction: Vector3;\n\n set(origin: Vector3, direction: Vector3): Ray;\n clone(): Ray;\n copy(ray: Ray): Ray;\n at(t: number, optionalTarget?: Vector3): Vector3;\n lookAt(v: Vector3): Vector3;\n recast(t: number): Ray;\n closestPointToPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n distanceToPoint(point: Vector3): number;\n distanceSqToPoint(point: Vector3): number;\n distanceSqToSegment(v0: Vector3, v1: Vector3, optionalPointOnRay?: Vector3, optionalPointOnSegment?: Vector3): number;\n intersectSphere(sphere: Sphere, optionalTarget?: Vector3): Vector3;\n intersectsSphere(sphere: Sphere): boolean;\n distanceToPlane(plane: Plane): number;\n intersectPlane(plane: Plane, optionalTarget?: Vector3): Vector3;\n intersectsPlane(plane: Plane): boolean;\n intersectBox(box: Box3, optionalTarget?: Vector3): Vector3;\n intersectsBox(box: Box3): boolean;\n intersectTriangle(a: Vector3, b: Vector3, c: Vector3, backfaceCulling: boolean, optionalTarget?: Vector3): Vector3;\n applyMatrix4(matrix4: Matrix4): Ray;\n equals(ray: Ray): boolean;\n\n // deprecated\n isIntersectionBox(b: any): any;\n isIntersectionPlane(p: any): any;\n isIntersectionSphere(s: any): any;\n }\n\n export class Sphere {\n constructor(center?: Vector3, radius?: number);\n\n center: Vector3;\n radius: number;\n\n set(center: Vector3, radius: number): Sphere;\n setFromPoints(points: Vector3[], optionalCenter?: Vector3): Sphere;\n clone(): Sphere;\n copy(sphere: Sphere): Sphere;\n empty(): boolean;\n containsPoint(point: Vector3): boolean;\n distanceToPoint(point: Vector3): number;\n intersectsSphere(sphere: Sphere): boolean;\n intersectsBox(box: Box3): boolean;\n intersectsPlane(plane: Plane): boolean;\n clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n getBoundingBox(optionalTarget?: Box3): Box3;\n applyMatrix4(matrix: Matrix4): Sphere;\n translate(offset: Vector3): Sphere;\n equals(sphere: Sphere): boolean;\n }\n\n export interface SplineControlPoint {\n x: number;\n y: number;\n z: number;\n }\n\n /**\n * Represents a spline.\n *\n * @see src/math/Spline.js\n */\n export class Spline {\n /**\n * Initialises the spline with points, which are the places through which the spline will go.\n */\n constructor(points: SplineControlPoint[]);\n\n points: SplineControlPoint[];\n\n /**\n * Initialises using the data in the array as a series of points. Each value in a must be another array with three values, where a[n] is v, the value for the nth point, and v[0], v[1] and v[2] are the x, y and z coordinates of that point n, respectively.\n *\n * @param a array of triplets containing x, y, z coordinates\n */\n initFromArray(a: number[][]): void;\n\n /**\n * Return the interpolated point at k.\n *\n * @param k point index\n */\n getPoint(k: number): SplineControlPoint;\n\n /**\n * Returns an array with triplets of x, y, z coordinates that correspond to the current control points.\n */\n getControlPointsArray(): number[][];\n\n /**\n * Returns the length of the spline when using nSubDivisions.\n * @param nSubDivisions number of subdivisions between control points. Default is 100.\n */\n getLength(nSubDivisions?: number): { chunks: number[]; total: number; };\n\n /**\n * Modifies the spline so that it looks similar to the original but has its points distributed in such way that moving along the spline it's done at a more or less constant speed. The points should also appear more uniformly spread along the curve.\n * This is done by resampling the original spline, with the density of sampling controlled by samplingCoef. Here it's interesting to note that denser sampling is not necessarily better: if sampling is too high, you may get weird kinks in curvature.\n *\n * @param samplingCoef how many intermediate values to use between spline points\n */\n reparametrizeByArcLength(samplingCoef: number): void;\n }\n\n class Triangle {\n constructor(a?: Vector3, b?: Vector3, c?: Vector3);\n\n a: Vector3;\n b: Vector3;\n c: Vector3;\n\n set(a: Vector3, b: Vector3, c: Vector3): Triangle;\n setFromPointsAndIndices(points: Vector3[], i0: number, i1: number, i2: number): Triangle;\n clone(): Triangle;\n copy(triangle: Triangle): Triangle;\n area(): number;\n midpoint(optionalTarget?: Vector3): Vector3;\n normal(optionalTarget?: Vector3): Vector3;\n plane(optionalTarget?: Vector3): Plane;\n barycoordFromPoint(point: Vector3, optionalTarget?: Vector3): Vector3;\n containsPoint(point: Vector3): boolean;\n closestPointToPoint(): Vector3;\n equals(triangle: Triangle): boolean;\n\n static normal(a: Vector3, b: Vector3, c: Vector3, optionalTarget?: Vector3): Vector3;\n static barycoordFromPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3, optionalTarget: Vector3): Vector3;\n static containsPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3): boolean;\n }\n\n /**\n * ( interface Vector<T> )\n *\n * Abstract interface of Vector2, Vector3 and Vector4.\n * Currently the members of Vector is NOT type safe because it accepts different typed vectors.\n * Those definitions will be changed when TypeScript innovates Generics to be type safe.\n *\n * @example\n * var v:THREE.Vector = new THREE.Vector3();\n * v.addVectors(new THREE.Vector2(0, 1), new THREE.Vector2(2, 3)); // invalid but compiled successfully\n */\n export interface Vector {\n setComponent(index: number, value: number): void;\n\n getComponent(index: number): number;\n\n /**\n * copy(v:T):T;\n */\n copy(v: Vector): Vector;\n\n /**\n * add(v:T):T;\n */\n add(v: Vector): Vector;\n\n /**\n * addVectors(a:T, b:T):T;\n */\n addVectors(a: Vector, b: Vector): Vector;\n\n /**\n * sub(v:T):T;\n */\n sub(v: Vector): Vector;\n\n /**\n * subVectors(a:T, b:T):T;\n */\n subVectors(a: Vector, b: Vector): Vector;\n\n /**\n * multiplyScalar(s:number):T;\n */\n multiplyScalar(s: number): Vector;\n\n /**\n * divideScalar(s:number):T;\n */\n divideScalar(s: number): Vector;\n\n /**\n * negate():T;\n */\n negate(): Vector;\n\n /**\n * dot(v:T):T;\n */\n dot(v: Vector): number;\n\n /**\n * lengthSq():number;\n */\n lengthSq(): number;\n\n /**\n * length():number;\n */\n length(): number;\n\n /**\n * normalize():T;\n */\n normalize(): Vector;\n\n /**\n * NOTE: Vector4 doesn't have the property.\n *\n * distanceTo(v:T):number;\n */\n distanceTo?(v: Vector): number;\n\n /**\n * NOTE: Vector4 doesn't have the property.\n *\n * distanceToSquared(v:T):number;\n */\n distanceToSquared?(v: Vector): number;\n\n /**\n * setLength(l:number):T;\n */\n setLength(l: number): Vector;\n\n /**\n * lerp(v:T, alpha:number):T;\n */\n lerp(v: Vector, alpha: number): Vector;\n\n /**\n * equals(v:T):boolean;\n */\n equals(v: Vector): boolean;\n\n /**\n * clone():T;\n */\n clone(): Vector;\n }\n\n /**\n * 2D vector.\n *\n * ( class Vector2 implements Vector )\n */\n export class Vector2 implements Vector {\n constructor(x?: number, y?: number);\n\n x: number;\n y: number;\n width: number;\n height: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number): Vector2;\n\n setScalar(scalar: number): Vector2;\n\n /**\n * Sets X component of this vector.\n */\n setX(x: number): Vector2;\n\n /**\n * Sets Y component of this vector.\n */\n setY(y: number): Vector2;\n\n /**\n * Sets a component of this vector.\n */\n setComponent(index: number, value: number): void;\n\n /**\n * Gets a component of this vector.\n */\n getComponent(index: number): number;\n /**\n * Clones this vector.\n */\n clone(): Vector2;\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector2): Vector2;\n\n /**\n * Adds v to this vector.\n */\n add(v: Vector2): Vector2;\n\n /**\n * Sets this vector to a + b.\n */\n addScalar(s: number): Vector2;\n addVectors(a: Vector2, b: Vector2): Vector2;\n addScaledVector( v: Vector2, s: number ): Vector2;\n /**\n * Subtracts v from this vector.\n */\n sub(v: Vector2): Vector2;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector2, b: Vector2): Vector2;\n\n multiply(v: Vector2): Vector2;\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(scalar: number): Vector2;\n\n divide(v: Vector2): Vector2;\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector2;\n\n min(v: Vector2): Vector2;\n\n max(v: Vector2): Vector2;\n clamp(min: Vector2, max: Vector2): Vector2;\n clampScalar(min: number, max: number): Vector2;\n clampLength(min: number, max: number): Vector2;\n floor(): Vector2;\n ceil(): Vector2;\n round(): Vector2;\n roundToZero(): Vector2;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector2;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector2): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector2;\n\n /**\n * computes the angle in radians with respect to the positive x-axis\n */\n angle(): number;\n\n /**\n * Computes distance of this vector to v.\n */\n distanceTo(v: Vector2): number;\n\n /**\n * Computes squared distance of this vector to v.\n */\n distanceToSquared(v: Vector2): number;\n distanceToManhattan(v: Vector2): number;\n\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(length: number): Vector2;\n\n lerp(v: Vector2, alpha: number): Vector2;\n\n lerpVectors(v1: Vector2, v2: Vector2, alpha: number): Vector2;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector2): boolean;\n\n fromArray(xy: number[], offset?: number): Vector2;\n\n toArray(xy?: number[], offset?: number): number[];\n\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector2;\n\n rotateAround( center: Vector2, angle: number ): Vector2;\n }\n\n /**\n * 3D vector.\n *\n * @example\n * var a = new THREE.Vector3( 1, 0, 0 );\n * var b = new THREE.Vector3( 0, 1, 0 );\n * var c = new THREE.Vector3();\n * c.crossVectors( a, b );\n *\n * @see src/math/Vector3.js\n *\n * ( class Vector3 implements Vector )\n */\n export class Vector3 implements Vector {\n constructor(x?: number, y?: number, z?: number);\n\n x: number;\n y: number;\n z: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number, z: number): Vector3;\n\n /**\n * Sets all values of this vector.\n */\n setScalar(scalar: number): Vector3;\n\n /**\n * Sets x value of this vector.\n */\n setX(x: number): Vector3;\n\n /**\n * Sets y value of this vector.\n */\n setY(y: number): Vector3;\n\n /**\n * Sets z value of this vector.\n */\n setZ(z: number): Vector3;\n\n setComponent(index: number, value: number): void;\n getComponent(index: number): number;\n /**\n * Clones this vector.\n */\n clone(): Vector3;\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector3): Vector3;\n\n /**\n * Adds v to this vector.\n */\n add(a: Vector3): Vector3;\n addScalar(s: number): Vector3;\n addScaledVector(v: Vector3, s: number): Vector3;\n\n /**\n * Sets this vector to a + b.\n */\n addVectors(a: Vector3, b: Vector3): Vector3;\n\n /**\n * Subtracts v from this vector.\n */\n sub(a: Vector3): Vector3;\n\n subScalar( s: number ): Vector3;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector3, b: Vector3): Vector3;\n\n multiply(v: Vector3): Vector3;\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(s: number): Vector3;\n multiplyVectors(a: Vector3, b: Vector3): Vector3;\n applyEuler(euler: Euler): Vector3;\n applyAxisAngle(axis: Vector3, angle: number): Vector3;\n applyMatrix3(m: Matrix3): Vector3;\n applyMatrix4(m: Matrix4): Vector3;\n applyProjection(m: Matrix4): Vector3;\n applyQuaternion(q: Quaternion): Vector3;\n project(camrea: Camera): Vector3;\n unproject(camera: Camera): Vector3;\n transformDirection(m: Matrix4): Vector3;\n divide(v: Vector3): Vector3;\n\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector3;\n min(v: Vector3): Vector3;\n max(v: Vector3): Vector3;\n clamp(min: Vector3, max: Vector3): Vector3;\n clampScalar(min: number, max: number): Vector3;\n clampLength(min: number, max: number): Vector3;\n floor(): Vector3;\n ceil(): Vector3;\n round(): Vector3;\n roundToZero(): Vector3;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector3;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector3): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n\n /**\n * Computes Manhattan length of this vector.\n * http://en.wikipedia.org/wiki/Taxicab_geometry\n */\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector3;\n\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(l: number): Vector3;\n lerp(v: Vector3, alpha: number): Vector3;\n\n lerpVectors(v1: Vector3, v2: Vector3, alpha: number): Vector3;\n\n /**\n * Sets this vector to cross product of itself and v.\n */\n cross(a: Vector3): Vector3;\n\n /**\n * Sets this vector to cross product of a and b.\n */\n crossVectors(a: Vector3, b: Vector3): Vector3;\n projectOnVector(v: Vector3): Vector3;\n projectOnPlane(planeNormal: Vector3): Vector3;\n reflect(vector: Vector3): Vector3;\n angleTo(v: Vector3): number;\n\n /**\n * Computes distance of this vector to v.\n */\n distanceTo(v: Vector3): number;\n\n /**\n * Computes squared distance of this vector to v.\n */\n distanceToSquared(v: Vector3): number;\n distanceToManhattan(v: Vector3): number;\n\n setFromSpherical(s: Spherical): Matrix3;\n setFromMatrixPosition(m: Matrix4): Vector3;\n setFromMatrixScale(m: Matrix4): Vector3;\n setFromMatrixColumn(matrix: Matrix4, index: number): Vector3;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector3): boolean;\n\n fromArray(xyz: number[], offset?: number): Vector3;\n toArray(xyz?: number[], offset?: number): number[];\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector3;\n\n // deprecated\n getPositionFromMatrix(m: Matrix4): Vector3;\n getScaleFromMatrix(m: Matrix4): Vector3;\n getColumnFromMatrix(index: number, matrix: Matrix4): Vector3;\n }\n\n export class Vertex extends Vector3 {} // deprecated\n\n /**\n * 4D vector.\n *\n * ( class Vector4 implements Vector )\n */\n export class Vector4 implements Vector {\n constructor(x?: number, y?: number, z?: number, w?: number);\n\n x: number;\n y: number;\n z: number;\n w: number;\n\n /**\n * Sets value of this vector.\n */\n set(x: number, y: number, z: number, w: number): Vector4;\n\n /**\n * Sets all values of this vector.\n */\n setScalar(scalar: number): Vector4;\n\n /**\n * Sets X component of this vector.\n */\n setX(x: number): Vector4;\n\n /**\n * Sets Y component of this vector.\n */\n setY(y: number): Vector4;\n\n /**\n * Sets Z component of this vector.\n */\n setZ(z: number): Vector4;\n\n /**\n * Sets w component of this vector.\n */\n setW(w: number): Vector4;\n\n setComponent(index: number, value: number): void;\n getComponent(index: number): number;\n /**\n * Clones this vector.\n */\n clone(): Vector4;\n /**\n * Copies value of v to this vector.\n */\n copy(v: Vector4): Vector4;\n\n /**\n * Adds v to this vector.\n */\n add(v: Vector4): Vector4;\n addScalar(s: number): Vector4;\n\n /**\n * Sets this vector to a + b.\n */\n addVectors(a: Vector4, b: Vector4): Vector4;\n addScaledVector( v: Vector4, s: number ): Vector4;\n /**\n * Subtracts v from this vector.\n */\n sub(v: Vector4): Vector4;\n\n subScalar(s: number): Vector4;\n\n /**\n * Sets this vector to a - b.\n */\n subVectors(a: Vector4, b: Vector4): Vector4;\n\n /**\n * Multiplies this vector by scalar s.\n */\n multiplyScalar(s: number): Vector4;\n applyMatrix4(m: Matrix4): Vector4;\n\n /**\n * Divides this vector by scalar s.\n * Set vector to ( 0, 0, 0 ) if s == 0.\n */\n divideScalar(s: number): Vector4;\n\n /**\n * http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm\n * @param q is assumed to be normalized\n */\n setAxisAngleFromQuaternion(q: Quaternion): Vector4;\n\n /**\n * http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm\n * @param m assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n */\n setAxisAngleFromRotationMatrix(m: Matrix3): Vector4;\n\n min(v: Vector4): Vector4;\n max(v: Vector4): Vector4;\n clamp(min: Vector4, max: Vector4): Vector4;\n clampScalar(min: number, max: number): Vector4;\n floor(): Vector4;\n ceil(): Vector4;\n round(): Vector4;\n roundToZero(): Vector4;\n\n /**\n * Inverts this vector.\n */\n negate(): Vector4;\n\n /**\n * Computes dot product of this vector and v.\n */\n dot(v: Vector4): number;\n\n /**\n * Computes squared length of this vector.\n */\n lengthSq(): number;\n\n /**\n * Computes length of this vector.\n */\n length(): number;\n lengthManhattan(): number;\n\n /**\n * Normalizes this vector.\n */\n normalize(): Vector4;\n /**\n * Normalizes this vector and multiplies it by l.\n */\n setLength(length: number): Vector4;\n\n /**\n * Linearly interpolate between this vector and v with alpha factor.\n */\n lerp(v: Vector4, alpha: number): Vector4;\n\n lerpVectors(v1: Vector4, v2: Vector4, alpha: number): Vector4;\n\n /**\n * Checks for strict equality of this vector and v.\n */\n equals(v: Vector4): boolean;\n\n fromArray(xyzw: number[], offset?: number): Vector4;\n\n toArray(xyzw?: number[], offset?: number): number[];\n\n fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector4;\n }\n\n export abstract class Interpolant {\n constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any);\n\n parameterPositions: any;\n samplesValues: any;\n valueSize: number;\n resultBuffer: any;\n\n evaluate(time: number): any;\n }\n\n export class CubicInterpolant extends Interpolant {\n constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any);\n\n interpolate_(i1: number, t0: number, t: number, t1: number): any;\n }\n\n export class DiscreteInterpolant extends Interpolant {\n constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any);\n\n interpolate_(i1: number, t0: number, t: number, t1: number): any;\n }\n\n export class LinearInterpolant extends Interpolant {\n constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any);\n\n interpolate_(i1: number, t0: number, t: number, t1: number): any;\n }\n\n export class QuaternionLinearInterpolant extends Interpolant {\n constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any);\n\n interpolate_(i1: number, t0: number, t: number, t1: number): any;\n }\n\n // Objects //////////////////////////////////////////////////////////////////////////////////\n\n export class Bone extends Object3D {\n constructor(skin: SkinnedMesh);\n\n skin: SkinnedMesh;\n\n clone(): Bone;\n copy(source: Bone): Bone;\n }\n\n export class Group extends Object3D {\n constructor();\n }\n\n export class LOD extends Object3D {\n constructor();\n\n levels: any[];\n\n addLevel(object: Object3D, distance?: number): void;\n getObjectForDistance(distance: number): Object3D;\n raycast(raycaster: Raycaster, intersects: any): void;\n update(camera: Camera): void;\n clone(): LOD;\n copy(source: LOD): LOD;\n toJSON(meta: any): any;\n\n // deprecated\n objects: any[];\n }\n\n export interface LensFlareProperty {\n texture: Texture; // Texture\n size: number; // size in pixels (-1 = use texture.width)\n distance: number; // distance (0-1) from light source (0=at light source)\n x: number;\n y: number;\n z: number; // screen position (-1 => 1) z = 0 is ontop z = 1 is back\n scale: number; // scale\n rotation: number; // rotation\n opacity: number; // opacity\n color: Color; // color\n blending: Blending;\n }\n\n export class LensFlare extends Object3D {\n constructor(texture?: Texture, size?: number, distance?: number, blending?: Blending, color?: Color);\n\n lensFlares: LensFlareProperty[];\n positionScreen: Vector3;\n customUpdateCallback: (object: LensFlare) => void;\n\n add(object: Object3D): void;\n add(texture: Texture, size?: number, distance?: number, blending?: Blending, color?: Color): void;\n updateLensFlares(): void;\n clone(): LensFlare;\n copy(source: LensFlare): LensFlare;\n }\n\n export class Line extends Object3D {\n constructor(\n geometry?: Geometry | BufferGeometry,\n material?: LineDashedMaterial | LineBasicMaterial | ShaderMaterial,\n mode?: number\n );\n\n geometry: Geometry|BufferGeometry;\n material: Material; // LineDashedMaterial or LineBasicMaterial or ShaderMaterial\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(): Line;\n copy(source: Line): Line;\n }\n\n export const LineStrip: number; // deprecated\n export const LinePieces: number; // deprecated\n\n export class LineSegments extends Line {\n constructor(\n geometry?: Geometry | BufferGeometry,\n material?: LineDashedMaterial | LineBasicMaterial | ShaderMaterial,\n mode?: number\n );\n\n clone(): LineSegments;\n copy(source: LineSegments): LineSegments;\n }\n\n enum LineMode {}\n\n export class Mesh extends Object3D {\n constructor(geometry?: Geometry, material?: Material);\n constructor(geometry?: BufferGeometry, material?: Material);\n\n geometry: Geometry|BufferGeometry;\n material: Material;\n drawMode: TrianglesDrawModes;\n\n setDrawMode(drawMode: TrianglesDrawModes): void;\n updateMorphTargets(): void;\n getMorphTargetIndexByName(name: string): number;\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(): Mesh;\n copy(source: Mesh): Mesh;\n }\n\n /**\n * A class for displaying particles in the form of variable size points. For example, if using the WebGLRenderer, the particles are displayed using GL_POINTS.\n *\n * @see src/objects/ParticleSystem.js\n */\n export class Points extends Object3D {\n\n /**\n * @param geometry An instance of Geometry or BufferGeometry.\n * @param material An instance of Material (optional).\n */\n constructor(\n geometry?: Geometry | BufferGeometry,\n material?: Material\n );\n\n /**\n * An instance of Geometry or BufferGeometry, where each vertex designates the position of a particle in the system.\n */\n geometry: Geometry | BufferGeometry;\n\n /**\n * An instance of Material, defining the object's appearance. Default is a PointsMaterial with randomised colour.\n */\n material: Material;\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(): Points;\n copy(source: Points): Points;\n }\n\n export class PointCloud extends Points {} // deprecated\n export class ParticleSystem extends Points {} // deprecated\n\n export class Skeleton {\n constructor(bones: Bone[], boneInverses?: Matrix4[], useVertexTexture?: boolean);\n\n useVertexTexture: boolean;\n identityMatrix: Matrix4;\n bones: Bone[];\n boneTextureWidth: number;\n boneTextureHeight: number;\n boneMatrices: Float32Array;\n boneTexture: DataTexture;\n boneInverses: Matrix4[];\n\n calculateInverses(bone: Bone): void;\n pose(): void;\n update(): void;\n clone(): Skeleton;\n }\n\n export class SkinnedMesh extends Mesh {\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshBasicMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshDepthMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MultiMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshLambertMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshNormalMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: MeshPhongMaterial, useVertexTexture?: boolean);\n constructor(geometry?: Geometry|BufferGeometry, material?: ShaderMaterial, useVertexTexture?: boolean);\n\n bindMode: string;\n bindMatrix: Matrix4;\n bindMatrixInverse: Matrix4;\n skeleton: Skeleton;\n\n bind( skeleton: Skeleton, bindMatrix?: Matrix4 ): void;\n pose(): void;\n normalizeSkinWeights(): void;\n updateMatrixWorld(force?: boolean): void;\n clone(): SkinnedMesh;\n copy(source: SkinnedMesh): SkinnedMesh;\n }\n\n export class Sprite extends Object3D {\n constructor(material?: Material);\n\n geometry: BufferGeometry;\n material: SpriteMaterial;\n\n raycast(raycaster: Raycaster, intersects: any): void;\n clone(): Sprite;\n copy(source: Sprite): Sprite;\n }\n\n export class Particle extends Sprite {} // deprecated\n\n\n // Renderers //////////////////////////////////////////////////////////////////////////////////\n\n export interface Renderer {\n domElement: HTMLCanvasElement;\n\n render(scene: Scene, camera: Camera): void;\n setSize(width: number, height: number, updateStyle?: boolean): void;\n }\n\n export interface WebGLRendererParameters {\n /**\n * A Canvas where the renderer draws its output.\n */\n canvas?: HTMLCanvasElement;\n\n /**\n * shader precision. Can be \"highp\", \"mediump\" or \"lowp\".\n */\n precision?: string;\n\n /**\n * default is true.\n */\n alpha?: boolean;\n\n /**\n * default is true.\n */\n premultipliedAlpha?: boolean;\n\n /**\n * default is false.\n */\n antialias?: boolean;\n\n /**\n * default is true.\n */\n stencil?: boolean;\n\n /**\n * default is false.\n */\n preserveDrawingBuffer?: boolean;\n\n /**\n * default is 0x000000.\n */\n clearColor?: number;\n\n /**\n * default is 0.\n */\n clearAlpha?: number;\n\n devicePixelRatio?: number;\n\n /**\n * default is false.\n */\n logarithmicDepthBuffer?: boolean;\n }\n\n\n /**\n * The WebGL renderer displays your beautifully crafted scenes using WebGL, if your device supports it.\n * This renderer has way better performance than CanvasRenderer.\n *\n * @see src/renderers/WebGLRenderer.js\n */\n export class WebGLRenderer implements Renderer {\n /**\n * parameters is an optional object with properties defining the renderer's behaviour. The constructor also accepts no parameters at all. In all cases, it will assume sane defaults when parameters are missing.\n */\n constructor(parameters?: WebGLRendererParameters);\n\n /**\n * A Canvas where the renderer draws its output.\n * This is automatically created by the renderer in the constructor (if not provided already); you just need to add it to your page.\n */\n domElement: HTMLCanvasElement;\n\n /**\n * The HTML5 Canvas's 'webgl' context obtained from the canvas where the renderer will draw.\n */\n context: WebGLRenderingContext;\n\n /**\n * Defines whether the renderer should automatically clear its output before rendering.\n */\n autoClear: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the color buffer. Default is true.\n */\n autoClearColor: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the depth buffer. Default is true.\n */\n autoClearDepth: boolean;\n\n /**\n * If autoClear is true, defines whether the renderer should clear the stencil buffer. Default is true.\n */\n autoClearStencil: boolean;\n\n /**\n * Defines whether the renderer should sort objects. Default is true.\n */\n sortObjects: boolean;\n\n clippingPlanes: any[];\n localClippingEnabled: boolean;\n\n extensions: WebGLExtensions;\n\n /**\n * Default is false.\n */\n gammaInput: boolean;\n\n /**\n * Default is false.\n */\n gammaOutput: boolean;\n\n physicallyCorrectLights: boolean;\n toneMapping: ToneMapping;\n toneMappingExposure: number;\n toneMappingWhitePoint: number;\n\n /**\n * Default is false.\n */\n shadowMapDebug: boolean;\n\n /**\n * Default is 8.\n */\n maxMorphTargets: number;\n\n /**\n * Default is 4.\n */\n maxMorphNormals: number;\n\n /**\n * An object with a series of statistical information about the graphics board memory and the rendering process. Useful for debugging or just for the sake of curiosity. The object contains the following fields:\n */\n info: {\n memory: {\n geometries: number;\n textures: number;\n };\n render: {\n calls: number;\n vertices: number;\n faces: number;\n points: number;\n };\n programs: number;\n };\n\n shadowMap: WebGLShadowMap;\n\n pixelRation: number;\n\n capabilities: WebGLCapabilities;\n properties: WebGLProperties;\n state: WebGLState;\n allocTextureUnit: any;\n\n /**\n * Return the WebGL context.\n */\n getContext(): WebGLRenderingContext;\n getContextAttributes(): any;\n forceContextLoss(): void;\n\n getMaxAnisotropy(): number;\n getPrecision(): string;\n getPixelRatio(): number;\n setPixelRatio(value: number): void;\n\n getSize(): { width: number; height: number; };\n\n /**\n * Resizes the output canvas to (width, height), and also sets the viewport to fit that size, starting in (0, 0).\n */\n setSize(width: number, height: number, updateStyle?: boolean): void;\n\n /**\n * Sets the viewport to render from (x, y) to (x + width, y + height).\n */\n setViewport(x?: number, y?: number, width?: number, height?: number): void;\n\n /**\n * Sets the scissor area from (x, y) to (x + width, y + height).\n */\n setScissor(x: number, y: number, width: number, height: number): void;\n\n /**\n * Enable the scissor test. When this is enabled, only the pixels within the defined scissor area will be affected by further renderer actions.\n */\n setScissorTest(enable: boolean): void;\n\n /**\n * Returns a THREE.Color instance with the current clear color.\n */\n getClearColor(): Color;\n\n /**\n * Sets the clear color, using color for the color and alpha for the opacity.\n */\n setClearColor(color: Color, alpha?: number): void;\n setClearColor(color: string, alpha?: number): void;\n setClearColor(color: number, alpha?: number): void;\n\n /**\n * Returns a float with the current clear alpha. Ranges from 0 to 1.\n */\n getClearAlpha(): number;\n\n setClearAlpha(alpha: number): void;\n\n /**\n * Tells the renderer to clear its color, depth or stencil drawing buffer(s).\n * Arguments default to true\n */\n clear(color?: boolean, depth?: boolean, stencil?: boolean): void;\n\n clearColor(): void;\n clearDepth(): void;\n clearStencil(): void;\n clearTarget(renderTarget: WebGLRenderTarget, color: boolean, depth: boolean, stencil: boolean): void;\n resetGLState(): void;\n dispose(): void;\n\n /**\n * Tells the shadow map plugin to update using the passed scene and camera parameters.\n *\n * @param scene an instance of Scene\n * @param camera — an instance of Camera\n */\n renderBufferImmediate(object: Object3D, program: Object, material: Material): void;\n\n renderBufferDirect(camera: Camera, fog: Fog, material: Material, geometryGroup: any, object: Object3D): void;\n\n /**\n * Render a scene using a camera.\n * The render is done to the renderTarget (if specified) or to the canvas as usual.\n * If forceClear is true, the canvas will be cleared before rendering, even if the renderer's autoClear property is false.\n */\n render(scene: Scene, camera: Camera, renderTarget?: RenderTarget, forceClear?: boolean): void;\n\n /**\n * Used for setting the gl frontFace, cullFace states in the GPU, thus enabling/disabling face culling when rendering.\n * If cullFace is false, culling will be disabled.\n * @param cullFace \"back\", \"front\", \"front_and_back\", or false.\n * @param frontFace \"ccw\" or \"cw\n */\n setFaceCulling(cullFace?: CullFace, frontFace?: FrontFaceDirection): void;\n setTexture(texture: Texture, slot: number): void; // deprecated\n setTexture2D(texture: Texture, slot: number): void;\n setTextureCube(texture: Texture, slot: number): void;\n getCurrentRenderTarget(): RenderTarget;\n setRenderTarget(renderTarget: RenderTarget): void;\n readRenderTargetPixels( renderTarget: RenderTarget, x: number, y: number, width: number, height: number, buffer: any ): void;\n\n // deprecated\n gammaFactor: number;\n shadowMapEnabled: boolean;\n shadowMapType: ShadowMapType;\n shadowMapCullFace: CullFace;\n\n supportsFloatTextures(): any;\n supportsHalfFloatTextures(): any;\n supportsStandardDerivatives(): any;\n supportsCompressedTextureS3TC(): any;\n supportsCompressedTexturePVRTC(): any;\n supportsBlendMinMax(): any;\n supportsVertexTextures(): any;\n supportsInstancedArrays(): any;\n enableScissorTest(boolean: any): any;\n }\n\n export interface RenderTarget {} // not defined in the code, used in LightShadow and WebGRenderer classes\n\n export interface WebGLRenderTargetOptions {\n wrapS?: Wrapping;\n wrapT?: Wrapping;\n magFilter?: TextureFilter;\n minFilter?: TextureFilter;\n format?: number; // RGBAFormat;\n type?: TextureDataType; // UnsignedByteType;\n anisotropy?: number; // 1;\n depthBuffer?: boolean; // true;\n stencilBuffer?: boolean; // true;\n }\n\n export class WebGLRenderTarget extends EventDispatcher {\n constructor(width: number, height: number, options?: WebGLRenderTargetOptions);\n\n uuid: string;\n width: number;\n height: number;\n scissor: Vector4;\n scissorTest: boolean;\n viewpport: Vector4;\n texture: Texture;\n depthBuffer: boolean;\n stencilBuffer: boolean;\n depthTexture: Texture;\n wrapS: any; // deprecated, use texture.wrapS\n wrapT: any; // deprecated, use texture.wrapT\n magFilter: any; // deprecated, use texture.magFilter\n minFilter: any; // deprecated, use texture.minFilter\n anisotropy: any; // deprecated, use texture.anisotropy\n offset: any; // deprecated, use texture.offset\n repeat: any; // deprecated, use texture.repeat\n format: any; // deprecated, use texture.format\n type: any; // deprecated, use texture.type\n generateMipmaps: any; // deprecated, use texture.generateMipmaps\n\n setSize(width: number, height: number): void;\n clone(): WebGLRenderTarget;\n copy(source: WebGLRenderTarget): WebGLRenderTarget;\n dispose(): void;\n }\n\n export class WebGLRenderTargetCube extends WebGLRenderTarget {\n constructor(width: number, height: number, options?: WebGLRenderTargetOptions);\n\n activeCubeFace: number; // PX 0, NX 1, PY 2, NY 3, PZ 4, NZ 5\n activeMipMapLevel: number;\n }\n\n // Renderers / Shaders /////////////////////////////////////////////////////////////////////\n export let ShaderChunk: {\n [name: string]: string;\n\n alphamap_fragment: string;\n alphamap_pars_fragment: string;\n alphatest_fragment: string;\n aomap_fragment: string;\n aomap_pars_fragment: string;\n begin_vertex: string;\n beginnormal_vertex: string;\n bsdfs: string;\n bumpmap_pars_fragment: string;\n clipping_planes_fragment: string;\n clipping_planes_pars_fragment: string;\n clipping_planes_pars_vertex: string;\n clipping_planes_vertex: string;\n color_fragment: string;\n color_pars_fragment: string;\n color_pars_vertex: string;\n color_vertex: string;\n common: string;\n cube_frag: string;\n cube_vert: string;\n cube_uv_reflection_fragment: string;\n defaultnormal_vertex: string;\n depth_frag: string;\n depth_vert: string;\n distanceRGBA_frag: string;\n distanceRGBA_vert: string;\n displacementmap_vertex: string;\n displacementmap_pars_vertex: string;\n emissivemap_fragment: string;\n emissivemap_pars_fragment: string;\n encodings_pars_fragment: string;\n encodings_fragment: string;\n envmap_fragment: string;\n envmap_pars_fragment: string;\n envmap_pars_vertex: string;\n envmap_vertex: string;\n equirect_frag: string;\n equirect_vert: string;\n fog_fragment: string;\n fog_pars_fragment: string;\n linedashed_frag: string;\n linedashed_vert: string;\n lightmap_fragment: string;\n lightmap_pars_fragment: string;\n lights_lambert_vertex: string;\n lights_pars: string;\n lights_phong_fragment: string;\n lights_phong_pars_fragment: string;\n lights_physical_fragment: string;\n lights_physical_pars_fragment: string;\n lights_template: string;\n logdepthbuf_fragment: string;\n logdepthbuf_pars_fragment: string;\n logdepthbuf_pars_vertex: string;\n logdepthbuf_vertex: string;\n map_fragment: string;\n map_pars_fragment: string;\n map_particle_fragment: string;\n map_particle_pars_fragment: string;\n meshbasic_frag: string;\n meshbasic_vert: string;\n meshlambert_frag: string;\n meshlambert_vert: string;\n meshphong_frag: string;\n meshphong_vert: string;\n meshphysical_frag: string;\n meshphysical_vert: string;\n metalnessmap_fragment: string;\n metalnessmap_pars_fragment: string;\n morphnormal_vertex: string;\n morphtarget_pars_vertex: string;\n morphtarget_vertex: string;\n normal_flip: string;\n normal_frag: string;\n normal_fragment: string;\n normal_vert: string;\n normalmap_pars_fragment: string;\n packing: string;\n points_frag: string;\n points_vert: string;\n shadow_frag: string;\n shadow_vert: string;\n\n premultiplied_alpha_fragment: string;\n project_vertex: string;\n roughnessmap_fragment: string;\n roughnessmap_pars_fragment: string;\n shadowmap_pars_fragment: string;\n shadowmap_pars_vertex: string;\n shadowmap_vertex: string;\n shadowmask_pars_fragment: string;\n skinbase_vertex: string;\n skinning_pars_vertex: string;\n skinning_vertex: string;\n skinnormal_vertex: string;\n specularmap_fragment: string;\n specularmap_pars_fragment: string;\n tonemapping_fragment: string;\n tonemapping_pars_fragment: string;\n uv2_pars_fragment: string;\n uv2_pars_vertex: string;\n uv2_vertex: string;\n uv_pars_fragment: string;\n uv_pars_vertex: string;\n uv_vertex: string;\n worldpos_vertex: string;\n };\n\n export interface Shader {\n uniforms: IUniform;\n vertexShader: string;\n fragmentShader: string;\n }\n\n export let ShaderLib: {\n [name: string]: Shader;\n basic: Shader;\n lambert: Shader;\n phong: Shader;\n standard: Shader;\n points: Shader;\n dashed: Shader;\n depth: Shader;\n normal: Shader;\n cube: Shader;\n equirect: Shader;\n depthRGBA: Shader;\n distanceRGBA: Shader;\n physical: Shader;\n };\n\n export interface IUniform {\n value: any;\n }\n\n export let UniformsLib: {\n common: {\n diffuse: IUniform;\n opacity: IUniform;\n map: IUniform;\n offsetRepeat: IUniform;\n specularMap: IUniform;\n alphaMap: IUniform;\n envMap: IUniform;\n flipEnvMap: IUniform;\n reflectivity: IUniform;\n refractionRation: IUniform;\n };\n aomap: {\n aoMap: IUniform;\n aoMapIntensity: IUniform;\n };\n lightmap: {\n lightMap: IUniform;\n lightMapIntensity: IUniform;\n };\n emissivemap: { emissiveMap: IUniform };\n bumpmap: {\n bumpMap: IUniform;\n bumpScale: IUniform;\n };\n normalmap: {\n normalMap: IUniform;\n normalScale: IUniform;\n };\n displacementmap: {\n displacementMap: IUniform;\n displacementScale: IUniform;\n displacementBias: IUniform;\n };\n roughnessmap: { roughnessMap: IUniform };\n metalnessmap: { metalnessMap: IUniform };\n fog: {\n fogDensity: IUniform;\n fogNear: IUniform;\n fogFar: IUniform;\n fogColor: IUniform;\n };\n lights: {\n ambientLightColor: IUniform\n directionalLights: {\n value: any[];\n properties: {\n direction: {};\n color: {};\n shadow: {};\n shadowBias: {};\n shadowRadius: {};\n shadowMapSize: {};\n };\n };\n directionalShadowMap: IUniform;\n directionalShadowMatrix: IUniform;\n spotLights: {\n value: any[];\n properties: {\n color: {};\n position: {};\n direction: {};\n distance: {};\n coneCos: {};\n penumbraCos: {};\n decay: {};\n shadow: {};\n shadowBias: {};\n shadowRadius: {};\n shadowMapSize: {};\n };\n };\n spotShadowMap: IUniform;\n spotShadowMatrix: IUniform;\n pointLights: {\n value: any[];\n properties: {\n color: {};\n position: {};\n decay: {};\n distance: {};\n shadow: {};\n shadowBias: {};\n shadowRadius: {};\n shadowMapSize: {};\n };\n };\n pointShadowMap: IUniform;\n pointShadowMatrix: IUniform;\n hemisphereLigtts: {\n value: any[];\n properties: {\n direction: {};\n skycolor: {};\n groundColor: {};\n };\n };\n };\n points: {\n diffuse: IUniform;\n opacity: IUniform;\n size: IUniform;\n scale: IUniform;\n map: IUniform;\n offsetRepeat: IUniform;\n };\n };\n\n export namespace UniformsUtils {\n export function merge(uniforms: any[]): any;\n export function clone(uniforms_src: any): any;\n }\n\n export class Uniform {\n constructor(value: any);\n constructor(type: string, value: any); // deprecated\n\n type: string; // deprecated\n value: any;\n dynamic: boolean;\n onUpdateCallback: Function;\n\n onUpdate(callback: Function): Uniform;\n }\n\n // Renderers / WebGL /////////////////////////////////////////////////////////////////////\n export class WebGLBufferRenderer {\n constructor(_gl: WebGLRenderingContext, extensions: any, _infoRender: any);\n\n setMode(value: any): void;\n render(start: any, count: number): void;\n renderInstances(geometry: any): void;\n }\n\n export class WebGLClipping {\n uniform: { value: any, needsUpdate: boolean };\n numPlanes: number;\n\n init(planes: any[], enableLocalClipping: boolean, camera: Camera): boolean;\n beginShadows(): void;\n endShadows(): void;\n setState(planes: any[], clipShadows: boolean, camera: Camera, cache: boolean, fromCache: boolean): void;\n }\n\n export interface WebGLCapabilitiesParameters {\n precision?: any;\n logarithmicDepthBuffer?: any;\n }\n\n export class WebGLCapabilities {\n constructor(gl: WebGLRenderingContext, extensions: any, parameters: WebGLCapabilitiesParameters);\n\n precision: any;\n logarithmicDepthBuffer: any;\n maxTextures: any;\n maxVertexTextures: any;\n maxTextureSize: any;\n maxCubemapSize: any;\n maxAttributes: any;\n maxVertexUniforms: any;\n maxVaryings: any;\n maxFragmentUniforms: any;\n vertexTextures: any;\n floatFragmentTextures: any;\n floatVertexTextures: any;\n\n getMaxAnisotropy(): number;\n getMaxPrecision(precision: string): string;\n }\n\n export class WebGLExtensions {\n constructor(gl: WebGLRenderingContext);\n\n get(name: string): any;\n }\n\n export class WebGLGeometries {\n constructor(gl: WebGLRenderingContext, extensions: any, _infoRender: any);\n\n get(object: any): any;\n }\n\n export class WebGLLights {\n constructor(gl: WebGLRenderingContext, properties: any, info: any);\n\n get(light: any): any;\n }\n\n export class WebGLIndexedBufferRenderer {\n constructor(gl: WebGLRenderingContext, properties: any, info: any);\n\n setMode(value: any): void;\n setIndex(index: any): void;\n render(start: any, count: number): void;\n renderInstances(geometry: any, start: any, count: number): void;\n }\n\n export class WebGLObjects {\n constructor(gl: WebGLRenderingContext, properties: any, info: any);\n\n getAttributeBuffer(attribute: any): any;\n getWireframeAttribute(geometry: any): any;\n update(object: any): void;\n }\n\n export class WebGLProgram {\n constructor(renderer: WebGLRenderer, code: string, material: ShaderMaterial, parameters: WebGLRendererParameters);\n\n id: number;\n code: string;\n usedTimes: number;\n program: any;\n vertexShader: WebGLShader;\n fragmentShader: WebGLShader;\n uniforms: any; // deprecated, use getUniforms()\n attributes: any; // deprecated, use getAttributes()\n\n getUniforms(): WebGLUniforms;\n getAttributes(): any;\n destroy(): void;\n }\n\n export class WebGLPrograms {\n constructor(renderer: WebGLRenderer, capabilities: any);\n\n programs: any[];\n\n getParameters(material: ShaderMaterial, lights: any, fog: any, nClipPlanes: number, object: any): any;\n getProgramCode(material: ShaderMaterial, parameters: any): string;\n acquireProgram(material: ShaderMaterial, parameters: any, code: string): WebGLProgram;\n releaseProgram(program: WebGLProgram): void;\n }\n\n export class WebGLTextures {\n constructor(gl: any, extensions: any, state: any, properties: any, capabilities: any, paramThreeToGL: Function, info: any);\n\n setTexture2D(texture: any, slot: number): void;\n setTextureCube(texture: any, slot: number): void;\n setTextureCubeDynamic(texture: any, slot: number): void;\n setupRenderTarget(renderTarget: any): void;\n updateRenderTargetMipmap(renderTarget: any): void;\n }\n\n export class WebGLUniforms {\n constructor(gl: any, program: WebGLProgram, renderer: WebGLRenderer);\n\n renderer: WebGLRenderer;\n\n setValue(gl: any, value: any, renderer?: any): void;\n set(gl: any, object: any, name: string): void;\n setOptional(gl: any, object: any, name: string): void;\n\n static upload(gl: any, seq: any, values: any[], renderer: any): void;\n static seqWithValue(seq: any, values: any[]): any[];\n static splitDynamic(seq: any, values: any[]): any[];\n static evalDynamic(seq: any, values: any[], object: any, camera: any): any[];\n }\n\n export class WebGLProperties {\n constructor();\n\n get(object: any): any;\n delete(object: any): void;\n clear(): void;\n }\n\n export class WebGLShader {\n constructor(gl: any, type: string, string: string);\n }\n\n export class WebGLShadowMap {\n constructor(_renderer: Renderer, _lights: any[], _objects: any[], capabilities: any);\n\n enabled: boolean;\n autoUpdate: boolean;\n needsUpdate: boolean;\n type: ShadowMapType;\n renderReverseSided: boolean;\n renderSingleSided: boolean;\n\n render(scene: Scene, camera: Camera): void;\n\n // deprecated\n cullFace: any;\n }\n\n export class WebGLState {\n constructor(gl: any, extensions: any, paramThreeToGL: Function);\n\n buffers: {\n color: WebGLColorBuffer,\n depth: WebGLDepthBuffer,\n stencil: WebGLStencilBuffer,\n };\n\n init(): void;\n initAttributes(): void;\n enableAttribute(attribute: string): void;\n enableAttributeAndDivisor(attribute: string, meshPerAttribute: any, extension: any): void;\n disableUnusedAttributes(): void;\n enable(id: string): void;\n disable(id: string): void;\n getCompressedTextureFormats(): any[];\n setBlending(blending: number, blendEquation: number, blendSrc: number, blendDst: number, blendEquationAlpha: number, blendSrcAlpha: number, blendDstAlpha: number): void;\n setColorWrite(colorWrite: number): void;\n setDepthTest(depthTest: number): void;\n setDepthWrite(depthWrite: number): void;\n setDepthFunc(depthFunc: Function): void;\n setStencilTest(stencilTest: boolean): void;\n setStencilWrite(stencilWrite: any): void;\n setStencilFunc(stencilFunc: Function, stencilRef: any, stencilMask: number): void;\n setStencilOp(stencilFail: any, stencilZFail: any, stencilZPass: any): void;\n setFlipSided(flipSided: number): void;\n setCullFace(cullFace: CullFace): void;\n setLineWidth(width: number): void;\n setPolygonOffset(polygonoffset: number, factor: number, units: number): void;\n setScissorTest(scissorTest: boolean): void;\n getScissorTest(): boolean;\n activeTexture(webglSlot: any): void;\n bindTexture(webglType: any, webglTexture: any): void;\n compressedTexImage2D(): void;\n texImage2D(): void;\n clearColor(r: number, g: number, b: number, a: number): void;\n clearDepth(depth: number): void;\n clearStencil(stencil: any): void;\n scissor(scissor: any): void;\n viewport(viewport: any): void;\n reset(): void;\n }\n\n export class WebGLColorBuffer {\n constructor(gl: any, state: any);\n\n setMask(colorMask: number): void;\n setLocked(lock: boolean): void;\n setClear(r: number, g: number, b: number, a: number): void;\n reset(): void;\n }\n\n export class WebGLDepthBuffer {\n constructor(gl: any, state: any);\n\n setTest(depthTest: boolean): void;\n sertMask(depthMask: number): void;\n setFunc(depthFunc: Function): void;\n setLocked(lock: boolean): void;\n setClear(depth: any): void;\n reset(): void;\n }\n\n export class WebGLStencilBuffer {\n constructor(gl: any, state: any);\n\n setTest(stencilTest: boolean): void;\n sertMask(stencilMask: number): void;\n setFunc(stencilFunc: Function, stencilRef: any, stencilMask: number): void;\n setOp(stencilFail: any, stencilZFail: any, stencilZPass: any): void;\n setLocked(lock: boolean): void;\n setClear(stencil: any): void;\n reset(): void;\n }\n\n // Renderers / WebGL / Plugins /////////////////////////////////////////////////////////////////////\n export class LensFlarePlugin {\n constructor(renderer: WebGLRenderer, flares: any[]);\n\n render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void;\n }\n\n export class SpritePlugin {\n constructor(renderer: WebGLRenderer, sprites: any[]);\n\n render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void;\n }\n\n // Scenes /////////////////////////////////////////////////////////////////////\n\n /**\n * Scenes allow you to set up what and where is to be rendered by three.js. This is where you place objects, lights and cameras.\n */\n export class Scene extends Object3D {\n constructor();\n\n /**\n * A fog instance defining the type of fog that affects everything rendered in the scene. Default is null.\n */\n fog: IFog;\n\n /**\n * If not null, it will force everything in the scene to be rendered with that material. Default is null.\n */\n overrideMaterial: Material;\n autoUpdate: boolean;\n background: any;\n\n copy(source: Scene, recursive?: boolean): Scene;\n toJSON(meta?: any): any;\n }\n\n export interface IFog {\n name: string;\n color: Color;\n clone(): IFog;\n toJSON(): any;\n }\n\n /**\n * This class contains the parameters that define linear fog, i.e., that grows linearly denser with the distance.\n */\n export class Fog implements IFog {\n constructor(hex: number, near?: number, far?: number);\n\n name: string;\n\n /**\n * Fog color.\n */\n color: Color;\n\n /**\n * The minimum distance to start applying fog. Objects that are less than 'near' units from the active camera won't be affected by fog.\n */\n near: number;\n\n /**\n * The maximum distance at which fog stops being calculated and applied. Objects that are more than 'far' units away from the active camera won't be affected by fog.\n * Default is 1000.\n */\n far: number;\n\n clone(): Fog;\n toJSON(): any;\n }\n\n /**\n * This class contains the parameters that define linear fog, i.e., that grows exponentially denser with the distance.\n */\n export class FogExp2 implements IFog {\n constructor(hex: number|string, density?: number);\n\n name: string;\n color: Color;\n\n /**\n * Defines how fast the fog will grow dense.\n * Default is 0.00025.\n */\n density: number;\n\n clone(): FogExp2;\n toJSON(): any;\n }\n\n // Textures /////////////////////////////////////////////////////////////////////\n export let TextureIdCount: number;\n\n export class Texture extends EventDispatcher {\n constructor(\n image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number,\n encoding?: TextureEncoding\n );\n\n id: number;\n uuid: string;\n name: string;\n sourceFile: string;\n image: any; // HTMLImageElement or ImageData or { width: number, height: number } in some children;\n mipmaps: ImageData[];\n mapping: Mapping;\n wrapS: Wrapping;\n wrapT: Wrapping;\n magFilter: TextureFilter;\n minFilter: TextureFilter;\n anisotropy: number;\n format: PixelFormat;\n type: TextureDataType;\n offset: Vector2;\n repeat: Vector2;\n generateMipmaps: boolean;\n premultiplyAlpha: boolean;\n flipY: boolean;\n unpackAlignment: number;\n encoding: TextureEncoding;\n version: number;\n needsUpdate: boolean;\n onUpdate: () => void;\n static DEFAULT_IMAGE: any;\n static DEFAULT_MAPPING: any;\n\n clone(): Texture;\n copy(source: Texture): Texture;\n toJSON(meta: any): any;\n dispose(): void;\n transformUv(uv: Vector): void;\n }\n\n export class DepthTexture extends Texture {\n constructor(\n width: number,\n heighht: number,\n type?: TextureDataType,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n anisotropy?: number\n );\n\n image: { width: number, height: number };\n }\n\n export class CanvasTexture extends Texture {\n constructor(\n canvas: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n\n clone(): CanvasTexture;\n copy(source: CanvasTexture): CanvasTexture;\n }\n\n export class CubeTexture extends Texture {\n constructor(\n images?: any[], // HTMLImageElement or HTMLCanvasElement\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number,\n encoding?: TextureEncoding\n );\n\n images: any; // returns and sets the value of Texture.image in the codde ?\n\n copy(source: CubeTexture): CubeTexture;\n }\n\n export class CompressedTexture extends Texture {\n constructor(\n mipmaps: ImageData[],\n width: number,\n height: number,\n format?: PixelFormat,\n type?: TextureDataType,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n anisotropy?: number,\n encoding?: TextureEncoding\n );\n\n image: { width: number; height: number; };\n\n clone(): CompressedTexture;\n copy(source: CompressedTexture): CompressedTexture;\n }\n\n export class DataTexture extends Texture {\n constructor(\n data: ArrayBuffer | Int8Array | Uint8Array | Uint8ClampedArray | Int16Array | Uint16Array | Int32Array | Uint32Array | Float32Array | Float64Array,\n width: number,\n height: number,\n format: PixelFormat,\n type: TextureDataType,\n mapping: Mapping,\n wrapS: Wrapping,\n wrapT: Wrapping,\n magFilter: TextureFilter,\n minFilter: TextureFilter,\n anisotropy?: number,\n encoding?: TextureEncoding\n );\n\n image: { data: ImageData; width: number; height: number; };\n\n clone(): DataTexture;\n copy(source: DataTexture): DataTexture;\n }\n\n export class VideoTexture extends Texture {\n constructor(\n video: HTMLVideoElement,\n mapping?: Mapping,\n wrapS?: Wrapping,\n wrapT?: Wrapping,\n magFilter?: TextureFilter,\n minFilter?: TextureFilter,\n format?: PixelFormat,\n type?: TextureDataType,\n anisotropy?: number\n );\n\n clone(): VideoTexture;\n copy(source: VideoTexture): VideoTexture;\n }\n\n // Extras /////////////////////////////////////////////////////////////////////\n export namespace CurveUtils {\n export function tangentQuadraticBezier(t: number, p0: number, p1: number, p2: number): number;\n export function tangentCubicBezier(t: number, p0: number, p1: number, p2: number, p3: number): number;\n export function tangentSpline(t: number, p0: number, p1: number, p2: number, p3: number): number;\n export function interpolate(p0: number, p1: number, p2: number, p3: number, t: number): number;\n }\n\n export namespace ImageUtils { // deprecated\n export let crossOrigin: string;\n\n export function loadTexture(url: string, mapping?: Mapping, onLoad?: (texture: Texture) => void, onError?: (message: string) => void): Texture;\n export function loadTextureCube(array: string[], mapping?: Mapping, onLoad?: (texture: Texture) => void , onError?: (message: string) => void ): Texture;\n }\n\n export namespace SceneUtils {\n export function createMultiMaterialObject(geometry: Geometry, materials: Material[]): Object3D;\n export function detach(child: Object3D, parent: Object3D, scene: Scene): void;\n export function attach(child: Object3D, scene: Scene, parent: Object3D): void;\n }\n\n export namespace ShapeUtils {\n export function area(contour: number[]): number;\n export function triangulate(contour: number[], indices: boolean): number[];\n export function triangulateShape(contour: number[], holes: any[]): number[];\n export function isClockWise(pts: number[]): boolean;\n export function b2(t: number, p0: number, p1: number, p2: number): number;\n export function b3(t: number, p0: number, p1: number, p2: number, p3: number): number;\n }\n\n // Extras / Audio /////////////////////////////////////////////////////////////////////\n\n export class Audio extends Object3D {\n constructor(listener: AudioListener);\n\n type: string;\n context: AudioContext;\n source: AudioBufferSourceNode;\n gain: GainNode;\n autoplay: boolean;\n startTime: number;\n playbackRate: number;\n hasPlaybackControl: boolean;\n isPlaying: boolean;\n sourceType: string;\n filters: any[];\n\n getOutput(): GainNode;\n setNodeSource(audioNode: AudioBufferSourceNode): Audio;\n setBuffer(audioBuffer: AudioBuffer): Audio;\n play(): Audio;\n pause(): Audio;\n stop(): Audio;\n connect(): Audio;\n disconnect(): Audio;\n getFilters(): any[];\n setFilter(value: any[]): Audio;\n getFilter(): any;\n setFilter(filter: any): Audio;\n setPlaybackRate(value: number): Audio;\n getPlaybackRate(): number;\n onEnded(): void;\n getLoop(): boolean;\n setLoop(value: boolean): void;\n getVolume(): number;\n setVolume(value: number): Audio;\n load(file: string): Audio; // deprecated, use the AudioLoader class\n }\n\n export class AudioAnalyser {\n constructor(audio: any, fftSize: number);\n\n analyser: any;\n data: Uint8Array;\n\n getFrequencyData(): Uint8Array;\n getAverageFrequency(): number;\n\n // deprecated\n getData(file: any): any;\n }\n\n export const AudioContext: AudioContext;\n\n export class AudioBuffer {\n constructor(context: any);\n\n context: any;\n ready: boolean;\n readyCallbacks: Function[];\n\n load(file: string): AudioBuffer;\n onReady(callback: Function): void;\n }\n\n export class PositionalAudio extends Audio {\n constructor(listener: AudioListener);\n\n panner: PannerNode;\n\n setRefDistance(value: number): void;\n getRefDistance(): number;\n setRolloffFactor(value: number): void;\n getRolloffFactor(): number;\n setDistanceModel(value: number): void;\n getDistanceModel(): number;\n setMaxDistance(value: number): void;\n getMaxDistance(): number;\n }\n\n export class AudioListener extends Object3D {\n constructor();\n\n type: string;\n context: AudioContext;\n gain: GainNode;\n\n getInput(): GainNode;\n removeFilter(): void;\n setFilter(value: any): void;\n getFilter(): any;\n setMasterVolume(value: number): void;\n getMasterVolume(): number;\n }\n\n // Extras / Core /////////////////////////////////////////////////////////////////////\n\n /**\n * An extensible curve object which contains methods for interpolation\n * class Curve<T extends Vector>\n */\n export class Curve {\n /**\n * Returns a vector for point t of the curve where t is between 0 and 1\n * getPoint(t: number): T;\n */\n getPoint(t: number): T;\n\n /**\n * Returns a vector for point at relative position in curve according to arc length\n * getPointAt(u: number): T;\n */\n getPointAt(u: number): T;\n\n /**\n * Get sequence of points using getPoint( t )\n * getPoints(divisions?: number): T[];\n */\n getPoints(divisions?: number): T[];\n\n /**\n * Get sequence of equi-spaced points using getPointAt( u )\n * getSpacedPoints(divisions?: number): T[];\n */\n getSpacedPoints(divisions?: number): T[];\n\n /**\n * Get total curve arc length\n */\n getLength(): number;\n\n /**\n * Get list of cumulative segment lengths\n */\n getLengths(divisions?: number): number[];\n\n /**\n * Update the cumlative segment distance cache\n */\n updateArcLengths(): void;\n\n /**\n * Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equi distance\n */\n getUtoTmapping(u: number, distance: number): number;\n\n /**\n * Returns a unit vector tangent at t. If the subclassed curve do not implement its tangent derivation, 2 points a small delta apart will be used to find its gradient which seems to give a reasonable approximation\n * getTangent(t: number): T;\n */\n getTangent(t: number): T;\n\n /**\n * Returns tangent at equidistance point u on the curve\n * getTangentAt(u: number): T;\n */\n getTangentAt(u: number): T;\n\n static create(constructorFunc: Function, getPointFunc: Function): Function;\n }\n\n export class CurvePath extends Curve {\n constructor();\n\n curves: Curve[];\n autoClose: boolean;\n\n add(curve: Curve): void;\n checkConnection(): boolean;\n closePath(): void;\n getPoint(t: number): T;\n getLength(): number;\n updateArcLengths(): void;\n getCurveLengths(): number[];\n getSpacedPoints(divisions?: number): T[];\n getPoints(divisions?: number): T[];\n createPointsGeometry(divisions: number): Geometry;\n createSpacedPointsGeometry(divisions: number): Geometry;\n createGeometry(points: T[]): Geometry;\n }\n\n export enum PathActions {\n MOVE_TO,\n LINE_TO,\n QUADRATIC_CURVE_TO, // Bezier quadratic curve\n BEZIER_CURVE_TO, // Bezier cubic curve\n CSPLINE_THRU, // Catmull-rom spline\n ARC, // Circle\n ELLIPSE,\n }\n\n export interface PathAction {\n action: PathActions;\n args: any;\n }\n\n /**\n * a 2d path representation, comprising of points, lines, and cubes, similar to the html5 2d canvas api. It extends CurvePath.\n */\n export class Path extends CurvePath {\n constructor(points?: Vector2[]);\n\n currentPoint: Vector2;\n\n fromPoints(vectors: Vector2[]): void;\n moveTo(x: number, y: number): void;\n lineTo(x: number, y: number): void;\n quadraticCurveTo(aCPx: number, aCPy: number, aX: number, aY: number): void;\n bezierCurveTo(aCP1x: number, aCP1y: number, aCP2x: number, aCP2y: number, aX: number, aY: number): void;\n splineThru(pts: Vector2[]): void;\n arc(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean): void;\n absarc(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean): void;\n ellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void;\n absellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void;\n }\n\n export class ShapePath {\n constructor();\n\n subPaths: any[];\n currentPath: any;\n\n moveTo(x: number, y: number): void;\n lineTo(x: number, y: number): void;\n quadraticCurveTo(aCPx: number, aCPy: number, aX: number, aY: number): void;\n bezierCurveTo(aCP1x: number, aCP1y: number, aCP2x: number, aCP2y: number, aX: number, aY: number): void;\n splineThru(pts: Vector2[]): void;\n toShapes(isCCW: boolean, noHoles: any): Shape[];\n }\n\n /**\n * Defines a 2d shape plane using paths.\n */\n export class Shape extends Path {\n constructor(points?: Vector2[]);\n\n holes: Path[];\n\n extrude(options?: any): ExtrudeGeometry;\n makeGeometry(options?: any): ShapeGeometry;\n getPointsHoles(divisions: number): Vector2[][];\n extractAllPoints(divisions: number): {\n shape: Vector2[];\n holes: Vector2[][];\n };\n extractPoints(divisions: number): Vector2[];\n }\n\n // Extras / Curves /////////////////////////////////////////////////////////////////////\n export class CatmullRomCurve3 extends Curve {\n constructor(points?: Vector3[]);\n\n points: Vector3[];\n\n getPoint(t: number): Vector3;\n }\n\n export class ClosedSplineCurve3 extends CatmullRomCurve3 {} // deprecated, use CatmullRomCurve3\n export class SplineCurve3 extends CatmullRomCurve3 {} // will be deprecated, use CatmullRomCurve3\n\n export class CubicBezierCurve extends Curve {\n constructor(v0: Vector2, v1: Vector2, v2: Vector2, v3: Vector2);\n\n v0: Vector2;\n v1: Vector2;\n v2: Vector2;\n v3: Vector2;\n }\n\n export class CubicBezierCurve3 extends Curve {\n constructor(v0: Vector3, v1: Vector3, v2: Vector3, v3: Vector3);\n\n v0: Vector3;\n v1: Vector3;\n v2: Vector3;\n v3: Vector3;\n\n getPoint(t: number): Vector3;\n }\n\n export class EllipseCurve extends Curve {\n constructor(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number);\n\n aX: number;\n aY: number;\n xRadius: number;\n yRadius: number;\n aStartAngle: number;\n aEndAngle: number;\n aClockwise: boolean;\n aRotation: number;\n }\n export class ArcCurve extends EllipseCurve {\n constructor(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean );\n }\n\n export class LineCurve extends Curve {\n constructor( v1: Vector2, v2: Vector2 );\n\n v1: Vector2;\n v2: Vector2;\n }\n\n export class LineCurve3 extends Curve {\n constructor(v1: Vector3, v2: Vector3);\n\n v1: Vector3;\n v2: Vector3;\n\n getPoint(t: number): Vector3;\n }\n\n export class QuadraticBezierCurve extends Curve {\n constructor( v0: Vector2, v1: Vector2, v2: Vector2 );\n\n v0: Vector2;\n v1: Vector2;\n v2: Vector2;\n }\n\n export class QuadraticBezierCurve3 extends Curve {\n constructor(v0: Vector3, v1: Vector3, v2: Vector3);\n\n v0: Vector3;\n v1: Vector3;\n v2: Vector3;\n\n getPoint(t: number): Vector3;\n }\n\n export class SplineCurve extends Curve {\n constructor(points?: Vector2[]);\n\n points: Vector2[];\n }\n\n\n // Extras / Geometries /////////////////////////////////////////////////////////////////////\n export class BoxBufferGeometry extends BufferGeometry {\n constructor(width: number, height: number, depth: number, widthSegments?: number, heightSegments?: number, depthSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n depth: number;\n widthSegments: number;\n heightSegments: number;\n depthSegments: number;\n };\n }\n\n /**\n * BoxGeometry is the quadrilateral primitive geometry class. It is typically used for creating a cube or irregular quadrilateral of the dimensions provided within the (optional) 'width', 'height', & 'depth' constructor arguments.\n */\n export class BoxGeometry extends Geometry {\n /**\n * @param width — Width of the sides on the X axis.\n * @param height — Height of the sides on the Y axis.\n * @param depth — Depth of the sides on the Z axis.\n * @param widthSegments — Number of segmented faces along the width of the sides.\n * @param heightSegments — Number of segmented faces along the height of the sides.\n * @param depthSegments — Number of segmented faces along the depth of the sides.\n */\n constructor(width: number, height: number, depth: number, widthSegments?: number, heightSegments?: number, depthSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n depth: number;\n widthSegments: number;\n heightSegments: number;\n depthSegments: number;\n };\n\n clone(): BoxGeometry;\n }\n\n export class CubeGeometry extends BoxGeometry {} // deprecated, use BoxGeometry\n\n export class CircleBufferGeometry extends BufferGeometry {\n constructor(radius?: number, segments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n segments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class CircleGeometry extends Geometry {\n constructor(radius?: number, segments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n segments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class CylinderBufferGeometry extends BufferGeometry {\n constructor(radiusTop?: number, radiusBottom?: number, height?: number, radialSegments?: number, heightSegments?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radiusTop: number;\n radiusBottom: number;\n height: number;\n radialSegments: number;\n heightSegments: number;\n openEnded: boolean;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class CylinderGeometry extends Geometry {\n /**\n * @param radiusTop — Radius of the cylinder at the top.\n * @param radiusBottom — Radius of the cylinder at the bottom.\n * @param height — Height of the cylinder.\n * @param radiusSegments — Number of segmented faces around the circumference of the cylinder.\n * @param heightSegments — Number of rows of faces along the height of the cylinder.\n * @param openEnded - A Boolean indicating whether or not to cap the ends of the cylinder.\n */\n constructor(radiusTop?: number, radiusBottom?: number, height?: number, radiusSegments?: number, heightSegments?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radiusTop: number;\n radiusBottom: number;\n height: number;\n radialSegments: number;\n heightSegments: number;\n openEnded: boolean;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class ConeBufferGeometry extends BufferGeometry {\n constructor(radius?: number, height?: number, radialSegment?: number, heightSegment?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number);\n }\n\n export class ConeGeometry extends CylinderGeometry {\n constructor(radius?: number, height?: number, radialSegment?: number, heightSegment?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number);\n }\n\n export class DodecahedronGeometry extends Geometry {\n constructor(radius: number, detail: number);\n\n parameters: {\n radius: number;\n detail: number;\n };\n }\n\n export class EdgesGeometry extends BufferGeometry {\n constructor(geometry: BufferGeometry, thresholdAngle: number);\n\n clone(): EdgesGeometry;\n }\n\n export class ExtrudeGeometry extends Geometry {\n constructor(shape?: Shape, options?: any);\n constructor(shapes?: Shape[], options?: any);\n\n static WorldUVGenerator: {\n generateTopUV(geometry: Geometry, indexA: number, indexB: number, indexC: number): Vector2[];\n generateSideWallUV(geometry: Geometry, indexA: number, indexB: number, indexC: number, indexD: number): Vector2[];\n };\n\n addShapeList(shapes: Shape[], options?: any): void;\n addShape(shape: Shape, options?: any): void;\n }\n\n export class IcosahedronGeometry extends PolyhedronGeometry {\n constructor(radius: number, detail: number);\n }\n\n export class LatheBufferGeometry extends BufferGeometry {\n constructor(points: Vector3[], segments?: number, phiStart?: number, phiLength?: number);\n\n parameters: {\n points: Vector3[];\n segments: number;\n phiStart: number;\n phiLength: number;\n };\n }\n\n export class LatheGeometry extends Geometry {\n constructor(points: Vector3[], segments?: number, phiStart?: number, phiLength?: number);\n\n parameters: {\n points: Vector3[];\n segments: number;\n phiStart: number;\n phiLength: number;\n };\n }\n\n export class OctahedronGeometry extends PolyhedronGeometry {\n constructor(radius: number, detail: number);\n }\n\n export class ParametricGeometry extends Geometry {\n constructor(func: (u: number, v: number) => Vector3, slices: number, stacks: number);\n\n parameters: {\n func: (u: number, v: number) => Vector3;\n slices: number;\n stacks: number;\n };\n }\n\n export class PlaneBufferGeometry extends BufferGeometry {\n constructor(width: number, height: number, widthSegments?: number, heightSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n widthSegments: number;\n heightSegments: number;\n };\n }\n\n export class PlaneGeometry extends Geometry {\n constructor(width: number, height: number, widthSegments?: number, heightSegments?: number);\n\n parameters: {\n width: number;\n height: number;\n widthSegments: number;\n heightSegments: number;\n };\n }\n\n export class PolyhedronGeometry extends Geometry {\n constructor(vertices: Vector3[], faces: Face3[], radius?: number, detail?: number);\n\n parameters: {\n vertices: Vector3[];\n faces: Face3[];\n radius: number;\n detail: number;\n };\n boundingSphere: Sphere;\n }\n\n export class RingBufferGeometry extends BufferGeometry {\n constructor(innerRadius?: number, outerRadius?: number, thetaSegments?: number, phiSegments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n innerRadius: number;\n outerRadius: number;\n thetaSegments: number;\n phiSegments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class RingGeometry extends Geometry {\n constructor(innerRadius?: number, outerRadius?: number, thetaSegments?: number, phiSegments?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n innerRadius: number;\n outerRadius: number;\n thetaSegments: number;\n phiSegments: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class ShapeGeometry extends Geometry {\n constructor(shape: Shape, options?: any);\n constructor(shapes: Shape[], options?: any);\n\n addShapeList(shapes: Shape[], options: any): ShapeGeometry;\n addShape(shape: Shape, options?: any): void;\n }\n\n export class SphereBufferGeometry extends BufferGeometry {\n constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n widthSegments: number;\n heightSegments: number;\n phiStart: number;\n phiLength: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n /**\n * A class for generating sphere geometries\n */\n export class SphereGeometry extends Geometry {\n /**\n * The geometry is created by sweeping and calculating vertexes around the Y axis (horizontal sweep) and the Z axis (vertical sweep). Thus, incomplete spheres (akin to 'sphere slices') can be created through the use of different values of phiStart, phiLength, thetaStart and thetaLength, in order to define the points in which we start (or end) calculating those vertices.\n *\n * @param radius — sphere radius. Default is 50.\n * @param widthSegments — number of horizontal segments. Minimum value is 3, and the default is 8.\n * @param heightSegments — number of vertical segments. Minimum value is 2, and the default is 6.\n * @param phiStart — specify horizontal starting angle. Default is 0.\n * @param phiLength — specify horizontal sweep angle size. Default is Math.PI * 2.\n * @param thetaStart — specify vertical starting angle. Default is 0.\n * @param thetaLength — specify vertical sweep angle size. Default is Math.PI.\n */\n constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number);\n\n parameters: {\n radius: number;\n widthSegments: number;\n heightSegments: number;\n phiStart: number;\n phiLength: number;\n thetaStart: number;\n thetaLength: number;\n };\n }\n\n export class TetrahedronGeometry extends PolyhedronGeometry {\n constructor(radius?: number, detail?: number);\n }\n\n export interface TextGeometryParameters {\n font: Font;\n size: number;\n height: number;\n curveSegments: number;\n bevelEnabled: boolean;\n bevelThickness: number;\n bevelSize: number;\n }\n\n export class TextGeometry extends ExtrudeGeometry {\n constructor(text: string, parameters?: TextGeometryParameters);\n\n parameters: {\n font: Font;\n size: number;\n height: number;\n curveSegments: number;\n bevelEnabled: boolean;\n bevelThickness: number;\n bevelSize: number;\n };\n }\n\n export class TorusBufferGeometry extends BufferGeometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, arc?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n arc: number;\n };\n }\n\n export class TorusGeometry extends Geometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, arc?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n arc: number;\n };\n }\n\n export class TorusKnotBufferGeometry extends BufferGeometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, p?: number, q?: number, heightScale?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n p: number;\n q: number;\n heightScale: number;\n };\n }\n\n export class TorusKnotGeometry extends Geometry {\n constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, p?: number, q?: number, heightScale?: number);\n\n parameters: {\n radius: number;\n tube: number;\n radialSegments: number;\n tubularSegments: number;\n p: number;\n q: number;\n heightScale: number;\n };\n }\n\n export class TubeGeometry extends Geometry {\n constructor(path: Path, segments?: number, radius?: number, radiusSegments?: number, closed?: boolean, taper?: (u: number) => number);\n\n parameters: {\n path: Path;\n segments: number;\n radius: number;\n radialSegments: number;\n closed: boolean;\n taper: (u: number) => number; // NoTaper or SinusoidalTaper;\n };\n tangents: Vector3[];\n normals: Vector3[];\n binormals: Vector3[];\n\n static NoTaper(u?: number): number;\n static SinusoidalTaper(u: number): number;\n static FrenetFrames(path: Path, segments: number, closed: boolean): void;\n }\n\n export class WireframeGeometry extends BufferGeometry {\n constructor(geometry: Geometry | BufferGeometry);\n }\n\n // Extras / Helpers /////////////////////////////////////////////////////////////////////\n\n export class ArrowHelper extends Object3D {\n constructor(dir: Vector3, origin?: Vector3, length?: number, hex?: number, headLength?: number, headWidth?: number);\n\n line: Line;\n cone: Mesh;\n\n setDirection(dir: Vector3): void;\n setLength(length: number, headLength?: number, headWidth?: number): void;\n setColor(hex: number): void;\n }\n\n export class AxisHelper extends LineSegments {\n constructor(size?: number);\n }\n\n export class BoundingBoxHelper extends Mesh {\n constructor(object?: Object3D, hex?: number);\n\n object: Object3D;\n box: Box3;\n\n update(): void;\n }\n\n export class BoxHelper extends LineSegments {\n constructor(object?: Object3D, color?: Color);\n\n update(object?: Object3D): void;\n }\n\n export class CameraHelper extends LineSegments {\n constructor(camera: Camera);\n\n camera: Camera;\n pointMap: { [id: string]: number[]; };\n\n update(): void;\n }\n\n export class DirectionalLightHelper extends Object3D {\n constructor(light: Light, size?: number);\n\n light: Light;\n lightPlane: Line;\n\n dispose(): void;\n update(): void;\n }\n\n export class EdgesHelper extends LineSegments {\n constructor(object: Object3D, hex?: number, thresholdAngle?: number);\n }\n\n export class FaceNormalsHelper extends LineSegments {\n constructor(object: Object3D, size?: number, hex?: number, linewidth?: number);\n\n object: Object3D;\n size: number;\n\n update(object?: Object3D): void;\n }\n\n export class GridHelper extends LineSegments {\n constructor(size: number, divisions: number, color1?: Color|number, color2?: Color|number);\n\n setColors(color1?: Color|number, color2?: Color|number): void; // deprecated\n }\n\n export class HemisphereLightHelper extends Object3D {\n constructor(light: Light, sphereSize: number);\n\n light: Light;\n colors: Color[];\n lightSphere: Mesh;\n\n dispose(): void;\n update(): void;\n }\n\n export class PointLightHelper extends Object3D {\n constructor(light: Light, sphereSize: number);\n\n light: Light;\n\n dispose(): void;\n update(): void;\n }\n\n export class SkeletonHelper extends LineSegments {\n constructor(bone: Object3D);\n\n bones: Bone[];\n root: Object3D;\n\n getBoneList(object: Object3D): Bone[];\n update(): void;\n }\n\n export class SpotLightHelper extends Object3D {\n constructor(light: Light);\n\n light: Light;\n\n dispose(): void;\n update(): void;\n }\n\n export class VertexNormalsHelper extends LineSegments {\n constructor(object: Object3D, size?: number, hex?: number, linewidth?: number);\n\n object: Object3D;\n size: number;\n\n update(object?: Object3D): void;\n }\n\n export class WireframeHelper extends LineSegments {\n constructor(object: Object3D, hex?: number);\n }\n\n // Extras / Objects /////////////////////////////////////////////////////////////////////\n\n export class ImmediateRenderObject extends Object3D {\n constructor(material: Material);\n\n material: Material;\n render(renderCallback: Function): void;\n }\n\n export interface MorphBlendMeshAnimation {\n start: number;\n end: number;\n length: number;\n fps: number;\n duration: number;\n lastFrame: number;\n currentFrame: number;\n active: boolean;\n time: number;\n direction: number;\n weight: number;\n directionBackwards: boolean;\n mirroredLoop: boolean;\n }\n\n export class MorphBlendMesh extends Mesh {\n constructor(geometry: Geometry, material: Material);\n\n animationsMap: { [name: string]: MorphBlendMeshAnimation; };\n animationsList: MorphBlendMeshAnimation[];\n\n createAnimation(name: string, start: number, end: number, fps: number): void;\n autoCreateAnimations(fps: number): void;\n setAnimationDirectionForward(name: string): void;\n setAnimationDirectionBackward(name: string): void;\n setAnimationFPS(name: string, fps: number): void;\n setAnimationDuration(name: string, duration: number): void;\n setAnimationWeight(name: string, weight: number): void;\n setAnimationTime(name: string, time: number): void;\n getAnimationTime(name: string): number;\n getAnimationDuration(name: string): number;\n playAnimation(name: string): void;\n stopAnimation(name: string): void;\n update(delta: number): void;\n }\n}\n\ndeclare module \"three\" {\n export = THREE;\n}" }); },{}]},{},[1]); diff --git a/typescriptAPI/main.d.ts b/typescriptAPI/main.d.ts index 0f6730c..fd0cbec 100644 --- a/typescriptAPI/main.d.ts +++ b/typescriptAPI/main.d.ts @@ -5,168 +5,442 @@ declare var SupWebGLRenderer: THREE.WebGLRenderer; declare var SupThreeScene: THREE.Scene; -// below is the content of https://github.com/elisee/DefinitelyTyped/blob/a5264ccb8a0521f704baf8ea91ad46d3f450ff56/threejs/three.d.ts +// below is the content of https://raw.githubusercontent.com/florentpoujol/DefinitelyTyped/a8657deb82bd819a5d041e58463c19398a3163ee/threejs/three.d.ts -// Type definitions for three.js r73 +// Type definitions for three.js r80 // Project: http://mrdoob.github.com/three.js/ -// Definitions by: Kon , Satoru Kimura +// Definitions by: Kon , Satoru Kimura , Florent Poujol , SereznoKot // Definitions: https://github.com/borisyankov/DefinitelyTyped -declare module THREE { - export var REVISION: string; +declare namespace THREE { + export const REVISION: string; // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent.button export enum MOUSE { LEFT, MIDDLE, RIGHT } // GL STATE CONSTANTS export enum CullFace { } - export var CullFaceNone: CullFace; - export var CullFaceBack: CullFace; - export var CullFaceFront: CullFace; - export var CullFaceFrontBack: CullFace; + export const CullFaceNone: CullFace; + export const CullFaceBack: CullFace; + export const CullFaceFront: CullFace; + export const CullFaceFrontBack: CullFace; export enum FrontFaceDirection { } - export var FrontFaceDirectionCW: FrontFaceDirection; - export var FrontFaceDirectionCCW: FrontFaceDirection; + export const FrontFaceDirectionCW: FrontFaceDirection; + export const FrontFaceDirectionCCW: FrontFaceDirection; // Shadowing Type export enum ShadowMapType { } - export var BasicShadowMap: ShadowMapType; - export var PCFShadowMap: ShadowMapType; - export var PCFSoftShadowMap: ShadowMapType; + export const BasicShadowMap: ShadowMapType; + export const PCFShadowMap: ShadowMapType; + export const PCFSoftShadowMap: ShadowMapType; // MATERIAL CONSTANTS // side export enum Side { } - export var FrontSide: Side; - export var BackSide: Side; - export var DoubleSide: Side; + export const FrontSide: Side; + export const BackSide: Side; + export const DoubleSide: Side; // shading export enum Shading { } - export var NoShading: Shading; - export var FlatShading: Shading; - export var SmoothShading: Shading; + export const FlatShading: Shading; + export const SmoothShading: Shading; // colors export enum Colors { } - export var NoColors: Colors; - export var FaceColors: Colors; - export var VertexColors: Colors; + export const NoColors: Colors; + export const FaceColors: Colors; + export const VertexColors: Colors; // blending modes export enum Blending { } - export var NoBlending: Blending; - export var NormalBlending: Blending; - export var AdditiveBlending: Blending; - export var SubtractiveBlending: Blending; - export var MultiplyBlending: Blending; - export var CustomBlending: Blending; + export const NoBlending: Blending; + export const NormalBlending: Blending; + export const AdditiveBlending: Blending; + export const SubtractiveBlending: Blending; + export const MultiplyBlending: Blending; + export const CustomBlending: Blending; // custom blending equations // (numbers start from 100 not to clash with other // mappings to OpenGL constants defined in Texture.js) export enum BlendingEquation { } - export var AddEquation: BlendingEquation; - export var SubtractEquation: BlendingEquation; - export var ReverseSubtractEquation: BlendingEquation; - export var MinEquation: BlendingEquation; - export var MaxEquation: BlendingEquation; + export const AddEquation: BlendingEquation; + export const SubtractEquation: BlendingEquation; + export const ReverseSubtractEquation: BlendingEquation; + export const MinEquation: BlendingEquation; + export const MaxEquation: BlendingEquation; // custom blending destination factors export enum BlendingDstFactor { } - export var ZeroFactor: BlendingDstFactor; - export var OneFactor: BlendingDstFactor; - export var SrcColorFactor: BlendingDstFactor; - export var OneMinusSrcColorFactor: BlendingDstFactor; - export var SrcAlphaFactor: BlendingDstFactor; - export var OneMinusSrcAlphaFactor: BlendingDstFactor; - export var DstAlphaFactor: BlendingDstFactor; - export var OneMinusDstAlphaFactor: BlendingDstFactor; + export const ZeroFactor: BlendingDstFactor; + export const OneFactor: BlendingDstFactor; + export const SrcColorFactor: BlendingDstFactor; + export const OneMinusSrcColorFactor: BlendingDstFactor; + export const SrcAlphaFactor: BlendingDstFactor; + export const OneMinusSrcAlphaFactor: BlendingDstFactor; + export const DstAlphaFactor: BlendingDstFactor; + export const OneMinusDstAlphaFactor: BlendingDstFactor; // custom blending src factors export enum BlendingSrcFactor { } - export var DstColorFactor: BlendingSrcFactor; - export var OneMinusDstColorFactor: BlendingSrcFactor; - export var SrcAlphaSaturateFactor: BlendingSrcFactor; + export const DstColorFactor: BlendingSrcFactor; + export const OneMinusDstColorFactor: BlendingSrcFactor; + export const SrcAlphaSaturateFactor: BlendingSrcFactor; + + // depth modes + export enum DepthModes { } + export const NeverDepth: DepthModes; + export const AlwaysDepth: DepthModes; + export const LessDepth: DepthModes; + export const LessEqualDepth: DepthModes; + export const EqualDepth: DepthModes; + export const GreaterEqualDepth: DepthModes; + export const GreaterDepth: DepthModes; + export const NotEqualDepth: DepthModes; // TEXTURE CONSTANTS // Operations export enum Combine { } - export var MultiplyOperation: Combine; - export var MixOperation: Combine; - export var AddOperation: Combine; + export const MultiplyOperation: Combine; + export const MixOperation: Combine; + export const AddOperation: Combine; + + // Tone Mapping modes + export enum ToneMapping { } + export const NoToneMapping: ToneMapping; + export const LinearToneMapping: ToneMapping; + export const ReinhardToneMapping: ToneMapping; + export const Uncharted2ToneMapping: ToneMapping; + export const CineonToneMapping: ToneMapping; // Mapping modes export enum Mapping { } - export var UVMapping: Mapping; - export var CubeReflectionMapping: Mapping; - export var CubeRefractionMapping: Mapping; - export var EquirectangularReflectionMapping: Mapping; - export var EquirectangularRefractionMapping: Mapping; - export var SphericalReflectionMapping: Mapping; + export const UVMapping: Mapping; + export const CubeReflectionMapping: Mapping; + export const CubeRefractionMapping: Mapping; + export const EquirectangularReflectionMapping: Mapping; + export const EquirectangularRefractionMapping: Mapping; + export const SphericalReflectionMapping: Mapping; + export const CubeUVReflectionMapping: Mapping; + export const CubeUVRefractionMapping: Mapping; // Wrapping modes export enum Wrapping { } - export var RepeatWrapping: Wrapping; - export var ClampToEdgeWrapping: Wrapping; - export var MirroredRepeatWrapping: Wrapping; + export const RepeatWrapping: Wrapping; + export const ClampToEdgeWrapping: Wrapping; + export const MirroredRepeatWrapping: Wrapping; // Filters export enum TextureFilter { } - export var NearestFilter: TextureFilter; - export var NearestMipMapNearestFilter: TextureFilter; - export var NearestMipMapLinearFilter: TextureFilter; - export var LinearFilter: TextureFilter; - export var LinearMipMapNearestFilter: TextureFilter; - export var LinearMipMapLinearFilter: TextureFilter; + export const NearestFilter: TextureFilter; + export const NearestMipMapNearestFilter: TextureFilter; + export const NearestMipMapLinearFilter: TextureFilter; + export const LinearFilter: TextureFilter; + export const LinearMipMapNearestFilter: TextureFilter; + export const LinearMipMapLinearFilter: TextureFilter; // Data types export enum TextureDataType { } - export var UnsignedByteType: TextureDataType; - export var ByteType: TextureDataType; - export var ShortType: TextureDataType; - export var UnsignedShortType: TextureDataType; - export var IntType: TextureDataType; - export var UnsignedIntType: TextureDataType; - export var FloatType: TextureDataType; - export var HalfFloatType: TextureDataType; + export const UnsignedByteType: TextureDataType; + export const ByteType: TextureDataType; + export const ShortType: TextureDataType; + export const UnsignedShortType: TextureDataType; + export const IntType: TextureDataType; + export const UnsignedIntType: TextureDataType; + export const FloatType: TextureDataType; + export const HalfFloatType: TextureDataType; // Pixel types export enum PixelType { } - export var UnsignedShort4444Type: PixelType; - export var UnsignedShort5551Type: PixelType; - export var UnsignedShort565Type: PixelType; + export const UnsignedShort4444Type: PixelType; + export const UnsignedShort5551Type: PixelType; + export const UnsignedShort565Type: PixelType; + export const UnsignedInt248Type: PixelType; // Pixel formats export enum PixelFormat { } - export var AlphaFormat: PixelFormat; - export var RGBFormat: PixelFormat; - export var RGBAFormat: PixelFormat; - export var LuminanceFormat: PixelFormat; - export var LuminanceAlphaFormat: PixelFormat; - export var RGBEFormat: PixelFormat; + export const AlphaFormat: PixelFormat; + export const RGBFormat: PixelFormat; + export const RGBAFormat: PixelFormat; + export const LuminanceFormat: PixelFormat; + export const LuminanceAlphaFormat: PixelFormat; + export const RGBEFormat: PixelFormat; + export const DepthFormat: PixelFormat; + export const DepthStencilFormat: PixelFormat; // Compressed texture formats // DDS / ST3C Compressed texture formats export enum CompressedPixelFormat { } - export var RGB_S3TC_DXT1_Format: CompressedPixelFormat; - export var RGBA_S3TC_DXT1_Format: CompressedPixelFormat; - export var RGBA_S3TC_DXT3_Format: CompressedPixelFormat; - export var RGBA_S3TC_DXT5_Format: CompressedPixelFormat; + export const RGB_S3TC_DXT1_Format: CompressedPixelFormat; + export const RGBA_S3TC_DXT1_Format: CompressedPixelFormat; + export const RGBA_S3TC_DXT3_Format: CompressedPixelFormat; + export const RGBA_S3TC_DXT5_Format: CompressedPixelFormat; // PVRTC compressed texture formats - export var RGB_PVRTC_4BPPV1_Format: CompressedPixelFormat; - export var RGB_PVRTC_2BPPV1_Format: CompressedPixelFormat; - export var RGBA_PVRTC_4BPPV1_Format: CompressedPixelFormat; - export var RGBA_PVRTC_2BPPV1_Format: CompressedPixelFormat; + export const RGB_PVRTC_4BPPV1_Format: CompressedPixelFormat; + export const RGB_PVRTC_2BPPV1_Format: CompressedPixelFormat; + export const RGBA_PVRTC_4BPPV1_Format: CompressedPixelFormat; + export const RGBA_PVRTC_2BPPV1_Format: CompressedPixelFormat; + + // ETC compressed texture formats + export const RGB_ETC1_Format: CompressedPixelFormat; + + // Loop styles for AnimationAction + export enum AnimationActionLoopStyles { } + export const LoopOnce: AnimationActionLoopStyles; + export const LoopRepeat: AnimationActionLoopStyles; + export const LoopPingPong: AnimationActionLoopStyles; + + // Interpolation + export enum InterpolationModes { } + export const InterpolateDiscrete: InterpolationModes; + export const InterpolateLinear: InterpolationModes; + export const InterpolateSmooth: InterpolationModes; + + // Interpolant ending modes + export enum InterpolationEndingModes { } + export const ZeroCurvatureEnding: InterpolationEndingModes; + export const ZeroSlopeEnding: InterpolationEndingModes; + export const WrapAroundEnding: InterpolationEndingModes; + + // Triangle Draw modes + export enum TrianglesDrawModes { } + export const TrianglesDrawModesMode: TrianglesDrawModes; + export const TriangleStripDrawMode: TrianglesDrawModes; + export const TriangleFanDrawMode: TrianglesDrawModes; + + // Texture Encodings + export enum TextureEncoding { } + export const LinearEncoding: TextureEncoding; + export const sRGBEncoding: TextureEncoding; + export const GammaEncoding: TextureEncoding; + export const RGBEEncoding: TextureEncoding; + export const LogLuvEncoding: TextureEncoding; + export const RGBM7Encoding: TextureEncoding; + export const RGBM16Encoding: TextureEncoding; + export const RGBDEncoding: TextureEncoding; + + // Depth packing strategies + export enum DepthPackingStrategies { } + export const BasicDepthPacking: DepthPackingStrategies; + export const RGBADepthPacking: DepthPackingStrategies; // log handlers export function warn(message?: any, ...optionalParams: any[]): void; export function error(message?: any, ...optionalParams: any[]): void; export function log(message?: any, ...optionalParams: any[]): void; + // Animation //////////////////////////////////////////////////////////////////////////////////////// + + export class AnimationAction { + loop: boolean; + time: number; + timeScale: number; + weight: number; + repetitions: number; + paused: boolean; + enabled: boolean; + clampWhenFinished: boolean; + zeroSlopeAtStart: boolean; + zeroSlopeAtEnd: boolean; + + play(): AnimationAction; + stop(): AnimationAction; + reset(): AnimationAction; + isRunning(): boolean; + startAt(time: number): AnimationAction; + setLoop(mode: boolean, repetitions: number): AnimationAction; + setEffectiveWeight(weight: number): AnimationAction; + getEffectiveWeight(): number; + fadeIn(duration: number): AnimationAction; + fadeOut(duration: number): AnimationAction; + crossFadeFrom(fadeOutAction: AnimationAction, duration: number, warp: boolean): AnimationAction; + crossFadeTo(fadeInAction: AnimationAction, duration: number, warp: boolean): AnimationAction; + stopFading(): AnimationAction; + setEffectiveTimeScale(timeScale: number): AnimationAction; + getEffectiveTimeScale(): number; + setDuration(duration: number): AnimationAction; + syncWith(action: AnimationAction): AnimationAction; + halt(duration: number): AnimationAction; + warp(statTimeScale: number, endTimeScale: number, duration: number): AnimationAction; + stopWarping(): AnimationAction; + getMixer(): AnimationMixer; + getClip(): AnimationClip; + getRoot(): any; + } + + export class AnimationClip { + constructor( name?: string, duration?: number, tracks?: KeyframeTrack[] ); + + name: string; + tracks: KeyframeTrack[]; + duration: number; + uuid: string; + results: any[]; + + resetDuration(): void; + trim(): AnimationClip; + optimize(): AnimationClip; + + static CreateFromMorphTargetSequence( name: string, morphTargetSequence: MorphTarget[], fps: number, noLoop: boolean ): AnimationClip; + static findByName( clipArray: AnimationClip, name: string ): AnimationClip; + static CreateClipsFromMorphTargetSequences( morphTargets: MorphTarget[], fps: number, noLoop: boolean ): AnimationClip[]; + static parse( json: any ): AnimationClip; + static parseAnimation( animation: any, bones: Bone[], nodeName: string ): AnimationClip; + static toJSON(): any; + } + + export class AnimationMixer extends EventDispatcher { + constructor(root: any); + + time: number; + timeScale: number; + + clipAction(clip: AnimationClip, root?: any): AnimationAction; + existingAction(clip: AnimationClip, root?: any): AnimationAction; + stopAllAction(clip: AnimationClip, root?: any): AnimationMixer; + update(deltaTime: number): AnimationMixer; + getRoot(): any; + uncacheClip(clip: AnimationClip): void; + uncacheRoot(root: any): void; + uncacheAction(clip: AnimationClip, root?: any): void; + } + + export class AnimationObjectGroup { + constructor(...args: any[]); + + uuid: string; + stats: { + bindingsPerObject: number; + objects: { + total: number; + inUse: number; + } + }; + + add(...args: any[]): void; + remove(...args: any[]): void; + uncache(...args: any[]): void; + } + + export namespace AnimationUtils { + export function arraySlice(array: any, from: number, to: number): any; + export function convertArray(array: any, type: any, forceClone: boolean): any; + export function isTypedArray(object: any): boolean; + export function getKeyFrameOrder(times: number): number[]; + export function sortedArray(values: any[], stride: number, order: number[]): any[]; + export function flattenJSON(jsonKeys: string[], times: any[], values: any[], valuePropertyName: string): void; + } + + export class KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + + name: string; + times: any[]; + values: any[]; + + ValueTypeName: string; + TimeBufferType: Float32Array; + ValueBufferType: Float32Array; + + DefaultInterpolation: InterpolationModes; + + InterpolantFactoryMethodDiscrete(result: any): DiscreteInterpolant; + InterpolantFactoryMethodLinear(result: any): LinearInterpolant; + InterpolantFactoryMethodSmooth(result: any): CubicInterpolant; + + setInterpolation(interpolation: InterpolationModes): void; + getInterpolation(): InterpolationModes; + + getValuesize(): number; + + shift( timeOffset: number ): KeyframeTrack; + scale( timeScale: number ): KeyframeTrack; + trim( startTime: number, endTime: number ): KeyframeTrack; + validate(): boolean; + optimize(): KeyframeTrack; + + static parse(json: any): KeyframeTrack; + static toJSON(track: KeyframeTrack): any; + } + + export class PropertyBinding { + constructor(rootNode: any, path: string, parsedPath?: any); + + path: string; + parsedPath: any; + node: any; + rootNode: any; + + getValue(targetArray: any, offset: number): any; + setValue(sourceArray: any, offset: number): void; + bind(): void; + unbind(): void; + + BindingType: { [bindingType: string]: number }; + Versioning: { [versioning: string]: number }; + + GetterByBindingType: Function[]; + SetterByBindingTypeAndVersioning: Array; + + static create(root: any, path: any, parsedPath?: any): PropertyBinding|PropertyBinding.Composite; + static parseTrackName(trackName: string): any; + static findNode(root: any, nodeName: string): any; + } + + export namespace PropertyBinding { + export class Composite { + constructor(targetGroup: any, path: any, parsedPath?: any); + + getValue(array: any, offset: number): any; + setValue(array: any, offset: number): void; + bind(): void; + unbind(): void; + } + } + + export class PropertyMixer { + constructor(binding: any, typeName: string, valueSize: number); + + binding: any; + valueSize: number; + buffer: any; + cumulativeWeight: number; + useCount: number; + referenceCount: number; + + accumulate(accuIndex: number, weight: number): void; + apply(accuIndex: number): void; + saveOriginalState(): void; + restoreOriginalState(): void; + } + + export class BooleanKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[]); + } + + export class ColorKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + } + + export class NumberKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + } + + export class QuaternionKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + } + + export class StringKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + } + + export class VectorKeyframeTrack extends KeyframeTrack { + constructor(name: string, times: any[], values: any[], interpolation: InterpolationModes); + } // Cameras //////////////////////////////////////////////////////////////////////////////////////// @@ -197,16 +471,16 @@ declare module THREE { */ lookAt(vector: Vector3): void; - clone(camera?: Camera): Camera; + clone(): Camera; + copy(camera?: Camera): Camera; } export class CubeCamera extends Object3D { - constructor( near?: number, far?: number, cubeResolution?: number); + constructor(near?: number, far?: number, cubeResolution?: number); renderTarget: WebGLRenderTargetCube; - updateCubeMap( renderer: Renderer, scene: Scene ): void; - + updateCubeMap(renderer: Renderer, scene: Scene): void; } /** @@ -230,6 +504,14 @@ declare module THREE { constructor(left: number, right: number, top: number, bottom: number, near?: number, far?: number); zoom: number; + view: { + fullWidth: number, + fullHeight: number, + offsetX: number, + offsetY: number, + width: number, + height: number + }; /** * Camera frustum left plane. @@ -265,8 +547,11 @@ declare module THREE { * Updates the camera projection matrix. Must be called after change of parameters. */ updateProjectionMatrix(): void; - + setViewOffset(fullWidth: number, fullHeight: number, offsetX: number, offsetY: number, width: number, height: number): void; + clearViewOffset(): void; clone(): OrthographicCamera; + copy(source: OrthographicCamera): OrthographicCamera; + toJSON(meta?: any): any; } /** @@ -309,14 +594,23 @@ declare module THREE { */ far: number; - /** - * Uses focal length (in mm) to estimate and set FOV 35mm (fullframe) camera is used if frame size is not specified. - * Formula based on http://www.bobatkins.com/photography/technical/field_of_view.html - * @param focalLength focal length - * @param frameHeight frame size. Default value is 24. - */ - setLens(focalLength: number, frameHeight?: number): void; + focus: number; + view: { + fullWidth: number, + fullHeight: number, + offsetX: number, + offsetY: number, + width: number, + height: number + }; + filmGauge: number; + filmOffset: number; + setFocalLength(focalLength: number): void; + getFocalLength(): number; + getEffectiveFOV(): number; + getFilmWidth(): number; + getFilmHeight(): number; /** * Sets an offset in a larger frustum. This is useful for multi-window or multi-monitor/multi-machine setups. * For example, if you have 3x2 monitors and each monitor is 1920x1080 and the monitors are in grid like this: @@ -355,70 +649,57 @@ declare module THREE { * @param height height of subcamera */ setViewOffset(fullWidth: number, fullHeight: number, x: number, y: number, width: number, height: number): void; + clearViewOffset(): void; /** * Updates the camera projection matrix. Must be called after change of parameters. */ updateProjectionMatrix(): void; clone(): PerspectiveCamera; + toJSON(meta?: any): any; + + // deprecated + setLens(focalLength: number, frameHeight?: number): void; } - // Core /////////////////////////////////////////////////////////////////////////////////////////////// + export class StereoCamera extends Camera { + constructor(); - /** - * @see src/core/InterleavedBuffer.js - */ - export class InterleavedBuffer { - constructor(array: ArrayLike, stride: number); - array: ArrayLike; - stride: number; - dynamic: boolean; - updateRange: {offset:number, count:number}; - version: number; - length: number; - count: number; - needsUpdate: boolean; + aspect: number; + cameraL: PerspectiveCamera; + cameraR: PerspectiveCamera; - setDynamic(dynamic: boolean): InterleavedBuffer; - copy(source: InterleavedBuffer): void; - copyAt(index1: number, attribute: InterleavedBufferAttribute, index2: number): InterleavedBuffer; - set(value: ArrayLike, index: number): InterleavedBuffer; - clone(): InterleavedBuffer; + update(camera: PerspectiveCamera): void; } - /** - * @see src/core/InstancedInterleavedBuffer.js - */ - export class InstancedInterleavedBuffer extends InterleavedBuffer { - constructor(array: ArrayLike, stride: number, meshPerAttribute?: number); - meshPerAttribute: number; - copy(source: InstancedInterleavedBuffer): InstancedInterleavedBuffer; - } + // Core /////////////////////////////////////////////////////////////////////////////////////////////// /** * @see src/core/BufferAttribute.js */ export class BufferAttribute { - constructor(array: ArrayLike, itemSize: number); // array parameter should be TypedArray. + constructor(array: ArrayLike, itemSize: number, normalized?: boolean); // array parameter should be TypedArray. + uuid: string; array: ArrayLike; itemSize: number; dynamic: boolean; - updateRange: {offset:number, count:number}; + updateRange: {offset: number, count: number}; + version: number; + normalized: boolean; needsUpdate: boolean; - /** Deprecated, use count instead */ - length: number; count: number; setDynamic(dynamic: boolean): BufferAttribute; + clone(): BufferAttribute; copy(source: BufferAttribute): BufferAttribute; copyAt(index1: number, attribute: BufferAttribute, index2: number): BufferAttribute; copyArray(array: ArrayLike): BufferAttribute; - copyColorArray(colors: {r:number, g:number, b:number}[]): BufferAttribute; - copyIndicesArray(indices: {a:number, b:number, c:number}[]): BufferAttribute; - copyVector2sArray(vectors: {x:number, y:number}[]): BufferAttribute; - copyVector3sArray(vectors: {x:number, y:number, z:number}[]): BufferAttribute; - copyVector4sArray(vectors: {x:number, y:number, z:number, w:number}[]): BufferAttribute; + copyColorsArray(colors: {r: number, g: number, b: number}[]): BufferAttribute; + copyIndicesArray(indices: {a: number, b: number, c: number}[]): BufferAttribute; + copyVector2sArray(vectors: {x: number, y: number}[]): BufferAttribute; + copyVector3sArray(vectors: {x: number, y: number, z: number}[]): BufferAttribute; + copyVector4sArray(vectors: {x: number, y: number, z: number, w: number}[]): BufferAttribute; set(value: ArrayLike, offset?: number): BufferAttribute; getX(index: number): number; setX(index: number, x: number): BufferAttribute; @@ -432,88 +713,48 @@ declare module THREE { setXYZ(index: number, x: number, y: number, z: number): BufferAttribute; setXYZW(index: number, x: number, y: number, z: number, w: number): BufferAttribute; clone(): BufferAttribute; + + length: number; // deprecated, use count } - // deprecated (are these actually deprecated?) - export class Int8Attribute extends BufferAttribute{ - constructor(data: any, itemSize: number); + export class Int8Attribute extends BufferAttribute { + constructor(array: any, itemSize: number); } - // deprecated export class Uint8Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Uint8ClampedAttribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Int16Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Uint16Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Int32Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Uint32Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Float32Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); + constructor(array: any, itemSize: number); } - // deprecated export class Float64Attribute extends BufferAttribute { - constructor(data: any, itemSize: number); - } - - /** - * @see src/core/InstancedBufferAttribute.js - */ - export class InstancedBufferAttribute extends BufferAttribute { - constructor(data: ArrayLike, itemSize: number, meshPerAttribute?: number); - meshPerAttribute: number; - copy(source: InstancedBufferAttribute): InstancedBufferAttribute; + constructor(array: any, itemSize: number); } - /** - * @see src/core/InterleavedBufferAttribute.js - */ - export class InterleavedBufferAttribute { - constructor(interleavedBuffer: InterleavedBuffer, itemSize: number, offset: number); - - uuid: string; - data: InterleavedBuffer; - itemSize: number; - offset: number; - /** Deprecated, use count instead */ - length: number; - count: number; - - getX(index: number): number; - setX(index: number, x: number): InterleavedBufferAttribute; - getY(index: number): number; - setY(index: number, y: number): InterleavedBufferAttribute; - getZ(index: number): number; - setZ(index: number, z: number): InterleavedBufferAttribute; - getW(index: number): number; - setW(index: number, z: number): InterleavedBufferAttribute; - setXY(index: number, x: number, y: number): InterleavedBufferAttribute; - setXYZ(index: number, x: number, y: number, z: number): InterleavedBufferAttribute; - setXYZW(index: number, x: number, y: number, z: number, w: number): InterleavedBufferAttribute; - } + // deprecated, use new THREE.BufferAttribute().setDynamic( true ) + export class DynamicBufferAttribute extends BufferAttribute {} /** * This is a superefficent class for geometries because it saves all data in buffers. @@ -522,7 +763,7 @@ declare module THREE { * * @see src/core/BufferGeometry.js */ - export class BufferGeometry { + export class BufferGeometry extends EventDispatcher { /** * This creates a new BufferGeometry. It also sets several properties to an default value. */ @@ -537,29 +778,22 @@ declare module THREE { uuid: string; name: string; type: string; + index: BufferAttribute; attributes: BufferAttribute|InterleavedBufferAttribute[]; - /** Deprecated. Use groups instead. */ - drawcalls: { start: number; count: number; index: number; }[]; - /** Deprecated. Use groups instead. */ - offsets: { start: number; count: number; index: number; }[]; - groups: { start: number, count: number, materialIndex?: number }[]; + morphAttributes: any; + groups: {start: number, count: number, materialIndex?: number}[]; boundingBox: Box3; - boundingSphere: BoundingSphere; + boundingSphere: Sphere; + drawRange: { start: number, count: number }; + + getIndex(): BufferAttribute; + setIndex( index: BufferAttribute ): void; - addIndex(index: BufferAttribute): void; - setIndex(index: BufferAttribute): void; + addAttribute(name: string, attribute: BufferAttribute|InterleavedBufferAttribute): BufferGeometry; - /** Deprecated. This overloaded method is deprecated. */ - addAttribute(name: string, array: any, itemSize: number): any; - addAttribute(name: string, attribute: BufferAttribute|InterleavedBufferAttribute): void; getAttribute(name: string): BufferAttribute|InterleavedBufferAttribute; - removeAttribute(name: string): void; - - setIndex(index: BufferAttribute): void; - getIndex(): BufferAttribute; + removeAttribute(name: string): BufferGeometry; - /** Deprecated. Use addGroup */ - addDrawCall(start: number, count: number, index: number): void; addGroup(start: number, count: number, materialIndex?: number): void; clearGroups(): void; @@ -568,7 +802,7 @@ declare module THREE { /** * Bakes matrix transform directly into vertex coordinates. */ - applyMatrix(matrix: Matrix4): void; + applyMatrix(matrix: Matrix4): BufferGeometry; rotateX(angle: number): BufferGeometry; rotateY(angle: number): BufferGeometry; @@ -579,11 +813,13 @@ declare module THREE { center(): Vector3; - setFromObject(object: Object3D) : void; - updateFromObject(object: Object3D) : void; + setFromObject(object: Object3D): void; + updateFromObject(object: Object3D): void; fromGeometry(geometry: Geometry, settings?: any): BufferGeometry; + fromDirectGeometry(geometry: DirectGeometry): BufferGeometry; + /** * Computes bounding box of the geometry, updating Geometry.boundingBox attribute. * Bounding boxes aren't computed by default. They need to be explicitly computed, otherwise they are null. @@ -596,17 +832,16 @@ declare module THREE { */ computeBoundingSphere(): void; - // deprecated - computeFaceNormals(): void; - /** * Computes vertex normals by averaging face normals. */ computeVertexNormals(): void; - computeOffsets(size: number): void; merge(geometry: BufferGeometry, offset: number): BufferGeometry; normalizeNormals(): void; + + toNonIndexed(): BufferGeometry; + toJSON(): any; clone(): BufferGeometry; copy(source: BufferGeometry): BufferGeometry; @@ -617,55 +852,14 @@ declare module THREE { */ dispose(): void; + // deprecated + drawcalls: any; + offsets: any; - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; - } - - /** - * @see src/core/InstancedBufferGeometry.js - */ - export class InstancedBufferGeometry extends BufferGeometry { - constructor(); - groups: {start:number, count:number, instances:number}[]; - addGroup(start: number, count: number, instances: number): void; - copy(source: InstancedBufferGeometry): InstancedBufferGeometry; - } - - /** - * @see src/core/DirectGeometry.js - */ - export class DirectGeometry { - constructor(); - id: number; - uuid: string; - name: string; - type: string; - indices: number[]; - vertices: Vector3[]; - normals: Vector3[]; - colors: Color[]; - uvs: Vector2[]; - uvs2: Vector2[]; - groups: {start: number, materialIndex: number}[]; - morphTargets: MorphTarget[]; - skinWeights: number[]; - skinIndices: number[]; - boundingBox: Box3; - boundingSphere: BoundingSphere; - verticesNeedUpdate: boolean; - normalsNeedUpdate: boolean; - colorsNeedUpdate: boolean; - uvsNeedUpdate: boolean; - groupsNeedUpdate: boolean; - computeBoundingBox(): void; - computeBoundingSphere(): void; - computeGroups(geometry: Geometry): void; - fromGeometry(geometry: Geometry): DirectGeometry; - dispose(): void; + addIndex(index: any): void; + addDrawCall(start: any, count: any, indexOffset?: any): void; + clearDrawCalls(): void; + addAttribute(name: any, array: any, itemSize: any): any; } /** @@ -729,19 +923,47 @@ declare module THREE { } /** - * Deprecated. Use new THREE.BufferAttribute().setDynamic(true) instead. + * @see src/core/DirectGeometry.js */ - export class DynamicBufferAttribute extends BufferAttribute { - constructor(array: any, itemSize: number); + export class DirectGeometry extends EventDispatcher { + constructor(); - updateRange: { - offset: number; - count: number; - } + id: number; + uuid: string; + name: string; + type: string; + indices: number[]; + vertices: Vector3[]; + normals: Vector3[]; + colors: Color[]; + uvs: Vector2[]; + uvs2: Vector2[]; + groups: {start: number, materialIndex: number}[]; + morphTargets: MorphTarget[]; + skinWeights: number[]; + skinIndices: number[]; + boundingBox: Box3; + boundingSphere: Sphere; + verticesNeedUpdate: boolean; + normalsNeedUpdate: boolean; + colorsNeedUpdate: boolean; + uvsNeedUpdate: boolean; + groupsNeedUpdate: boolean; + + computeBoundingBox(): void; + computeBoundingSphere(): void; + computeGroups(geometry: Geometry): void; + fromGeometry(geometry: Geometry): DirectGeometry; + dispose(): void; - clone(): DynamicBufferAttribute; + // EventDispatcher mixins + addEventListener(type: string, listener: (event: Event) => void ): void; + hasEventListener(type: string, listener: (event: Event) => void): void; + removeEventListener(type: string, listener: (event: Event) => void): void; + dispatchEvent(event: { type: string; [attachment: string]: any; }): void; } + /** * JavaScript events for custom objects * @@ -778,27 +1000,35 @@ declare module THREE { * @param type The type of the listener that gets removed. * @param listener The listener function that gets removed. */ - addEventListener(type: string, listener: (event: any) => void ): void; + addEventListener(type: string, listener: (event: Event) => void ): void; /** * Adds a listener to an event type. * @param type The type of the listener that gets removed. * @param listener The listener function that gets removed. */ - hasEventListener(type: string, listener: (event: any) => void): void; + hasEventListener(type: string, listener: (event: Event) => void): void; /** * Removes a listener from an event type. * @param type The type of the listener that gets removed. * @param listener The listener function that gets removed. */ - removeEventListener(type: string, listener: (event: any) => void): void; + removeEventListener(type: string, listener: (event: Event) => void): void; /** * Fire an event type. * @param type The type of event that gets fired. */ - dispatchEvent(event: { type: string; target: any; }): void; + dispatchEvent(event: { type: string; [attachment: string]: any; }): void; + + // deprecated + apply(target: any): void; + } + + export interface Event { + type: string; + target: any; } /** @@ -860,19 +1090,17 @@ declare module THREE { */ vertexColors: Color[]; - /** - * Array of 4 vertex tangets. - */ - vertexTangents: number[]; - /** * Material index (points to {@link Geometry.materials}). */ materialIndex: number; clone(): Face3; + copy(source: Face3): Face3; } + export class Face4 extends Face3 {} // deprecated, use Face3 + export interface MorphTarget { name: string; vertices: Vector3[]; @@ -888,10 +1116,7 @@ declare module THREE { normals: Vector3[]; } - export interface BoundingSphere { - radius: number; - } - + export let GeometryIdCount: number; /** * Base class for geometries @@ -906,7 +1131,7 @@ declare module THREE { * * @see https://github.com/mrdoob/three.js/blob/master/src/core/Geometry.js */ - export class Geometry { + export class Geometry extends EventDispatcher { constructor(); /** @@ -990,14 +1215,7 @@ declare module THREE { /** * Bounding sphere. */ - boundingSphere: BoundingSphere; - - /** - * Set to true if attribute buffers will need to change in runtime (using "dirty" flags). - * Unless set to true internal typed arrays corresponding to buffers will be deleted once sent to GPU. - * Defaults to true. - */ - dynamic: boolean; + boundingSphere: Sphere; /** * Set to true if the vertices array has been updated. @@ -1019,11 +1237,6 @@ declare module THREE { */ normalsNeedUpdate: boolean; - /** - * Set to true if the tangents in the faces has been updated. - */ - tangentsNeedUpdate: boolean; - /** * Set to true if the colors array has been updated. */ @@ -1042,15 +1255,22 @@ declare module THREE { /** * Bakes matrix transform directly into vertex coordinates. */ - applyMatrix(matrix: Matrix4): void; + applyMatrix(matrix: Matrix4): Geometry; + + rotateX(angle: number): Geometry; + rotateY(angle: number): Geometry; + rotateZ(angle: number): Geometry; + + translate(x: number, y: number, z: number): Geometry; + scale(x: number, y: number, z: number): Geometry; + lookAt( vector: Vector3 ): void; fromBufferGeometry(geometry: BufferGeometry): Geometry; - /** - * - */ center(): Vector3; + normalize(): Geometry; + /** * Computes face normals. */ @@ -1080,9 +1300,9 @@ declare module THREE { */ computeBoundingSphere(): void; - merge( geometry: Geometry, matrix: Matrix, materialIndexOffset: number): void; + merge(geometry: Geometry, matrix: Matrix, materialIndexOffset?: number): void; - mergeMesh( mesh: Mesh ): void; + mergeMesh(mesh: Mesh): void; /** * Checks for duplicate vertices using hashmap. @@ -1099,6 +1319,8 @@ declare module THREE { */ clone(): Geometry; + copy(source: Geometry): Geometry; + /** * Removes The object from memory. * Don't forget to call this method when you remove an geometry because it can cuase meomory leaks. @@ -1106,22 +1328,119 @@ declare module THREE { dispose(): void; - //These properties do not exist in a normal Geometry class, but if you use the instance that was passed by JSONLoader, it will be added. + // These properties do not exist in a normal Geometry class, but if you use the instance that was passed by JSONLoader, it will be added. bones: Bone[]; - animation: AnimationData; - animations: AnimationData[]; + animation: AnimationClip; + animations: AnimationClip[]; // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; + addEventListener(type: string, listener: (event: Event) => void ): void; + hasEventListener(type: string, listener: (event: Event) => void): void; + removeEventListener(type: string, listener: (event: Event) => void): void; + dispatchEvent(event: { type: string; [attachment: string]: any; }): void; + } + + export namespace GeometryUtils { // deprecated + export function merge(geometry1: any, geometry2: any, materialIndexOffset?: any): any; // deprecated, use geometry.merge( geometry2, matrix, materialIndexOffset ) + export function center(geometry: any): any; // deprecated, use geometry.center() + } + + /** + * @see src/core/InstancedBufferAttribute.js + */ + export class InstancedBufferAttribute extends BufferAttribute { + constructor(data: ArrayLike, itemSize: number, meshPerAttribute?: number); + + meshPerAttribute: number; + + clone(): InstancedBufferAttribute; + copy(source: InstancedBufferAttribute): InstancedBufferAttribute; + } + + /** + * @see src/core/InstancedBufferGeometry.js + */ + export class InstancedBufferGeometry extends BufferGeometry { + constructor(); + + groups: {start: number, count: number, instances: number}[]; + maxInstancedCount: number; + + addGroup(start: number, count: number, instances: number): void; + clone(): InstancedBufferGeometry; + copy(source: InstancedBufferGeometry): InstancedBufferGeometry; + } + + /** + * @see src/core/InterleavedBuffer.js + */ + export class InterleavedBuffer { + constructor(array: ArrayLike, stride: number); + + array: ArrayLike; + stride: number; + dynamic: boolean; + updateRange: { offset: number; count: number }; + version: number; + length: number; + count: number; + needsUpdate: boolean; + + setDynamic(dynamic: boolean): InterleavedBuffer; + clone(): InterleavedBuffer; + copy(source: InterleavedBuffer): InterleavedBuffer; + copyAt(index1: number, attribute: InterleavedBufferAttribute, index2: number): InterleavedBuffer; + set(value: ArrayLike, index: number): InterleavedBuffer; + clone(): InterleavedBuffer; + } + + /** + * @see src/core/InstancedInterleavedBuffer.js + */ + export class InstancedInterleavedBuffer extends InterleavedBuffer { + constructor(array: ArrayLike, stride: number, meshPerAttribute?: number); + + meshPerAttribute: number; + + clone(): InstancedInterleavedBuffer; + copy(source: InstancedInterleavedBuffer): InstancedInterleavedBuffer; + } + + /** + * @see src/core/InterleavedBufferAttribute.js + */ + export class InterleavedBufferAttribute { + constructor(interleavedBuffer: InterleavedBuffer, itemSize: number, offset: number, normalized: boolean); + + uuid: string; + data: InterleavedBuffer; + itemSize: number; + offset: number; + count: number; + normalized: boolean; + array: any[]; + + getX(index: number): number; + setX(index: number, x: number): InterleavedBufferAttribute; + getY(index: number): number; + setY(index: number, y: number): InterleavedBufferAttribute; + getZ(index: number): number; + setZ(index: number, z: number): InterleavedBufferAttribute; + getW(index: number): number; + setW(index: number, z: number): InterleavedBufferAttribute; + setXY(index: number, x: number, y: number): InterleavedBufferAttribute; + setXYZ(index: number, x: number, y: number, z: number): InterleavedBufferAttribute; + setXYZW(index: number, x: number, y: number, z: number, w: number): InterleavedBufferAttribute; + + length: number; // deprecated, use count instead } + export let Object3DIdCount: number; + /** * Base class for scene graph objects */ - export class Object3D { + export class Object3D extends EventDispatcher { constructor(); /** @@ -1176,10 +1495,9 @@ declare module THREE { */ scale: Vector3; - /** - * When this is set, then the rotationMatrix gets calculated every frame. - */ - rotationAutoUpdate: boolean; + modelViewMatrix: Matrix4; + + normalMatrix: Matrix3; /** * Local transform. @@ -1201,6 +1519,7 @@ declare module THREE { */ matrixWorldNeedsUpdate: boolean; + layers: Layers; /** * Object gets rendered if true. */ @@ -1234,13 +1553,6 @@ declare module THREE { static DefaultUp: Vector3; static DefaultMatrixAutoUpdate: boolean; - /** - * Order of axis for Euler angles. - */ - // deprecated - eulerOrder: string; - - /** * This updates the position, rotation and scale with the matrix. */ @@ -1254,7 +1566,7 @@ declare module THREE { /** * */ - setRotationFromEuler(euler: Euler ): void; + setRotationFromEuler(euler: Euler): void; /** * @@ -1264,7 +1576,7 @@ declare module THREE { /** * */ - setRotationFromQuaternion( q: Quaternion ): void; + setRotationFromQuaternion(q: Quaternion): void; /** * Rotate an object along an axis in object space. The axis is assumed to be normalized. @@ -1297,13 +1609,6 @@ declare module THREE { */ translateOnAxis(axis: Vector3, distance: number): Object3D; - /** - * - * @param distance - * @param axis - */ - translate( distance: number, axis: Vector3 ): Object3D; - /** * Translates object along x axis by distance. * @param distance Distance. @@ -1350,9 +1655,6 @@ declare module THREE { */ remove(object: Object3D): void; - /* deprecated */ - getChildByName( name: string ): Object3D; - /** * Searches through the object's children and returns the first with a matching id, optionally recursive. * @param id Unique number of the object instance @@ -1373,11 +1675,8 @@ declare module THREE { getWorldScale(optionalTarget?: Vector3): Vector3; getWorldDirection(optionalTarget?: Vector3): Vector3; - /** - * Translates object along arbitrary axis by distance. - * @param distance Distance. - * @param axis Translation direction. - */ + raycast(raycaster: Raycaster, intersects: any): void; + traverse(callback: (object: Object3D) => any): void; traverseVisible(callback: (object: Object3D) => any): void; @@ -1394,38 +1693,39 @@ declare module THREE { */ updateMatrixWorld(force: boolean): void; - toJSON(): any; + toJSON(meta?: { geometries: any, materials: any, textures: any, images: any }): any; + + clone(recursive?: boolean): Object3D; /** * * @param object * @param recursive */ - clone(object?: Object3D, recursive?: boolean): Object3D; - - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; + copy(source: Object3D, recursive?: boolean): Object3D; + // deprecated + eulerOrder: string; + getChildByName(name: string): Object3D; + translate(distance: number, axis: Vector3): Object3D; } export interface Intersection { distance: number; + distanceToRay: number; point: Vector3; + index: number; face: Face3; + faceIndex: number; object: Object3D; } export interface RaycasterParameters { - Sprite?: any; Mesh?: any; - Points?: any; - /** Deprecated, use Points */ - PointCloud?: any; - LOD?: any; Line?: any; + LOD?: any; + Points?: { threshold: number }; + Sprite?: any; } export class Raycaster { @@ -1437,58 +1737,73 @@ declare module THREE { params: RaycasterParameters; precision: number; linePrecision: number; + set(origin: Vector3, direction: Vector3): void; - setFromCamera(coords: { x: number; y: number;}, camera: Camera ): void; + setFromCamera(coords: { x: number; y: number; }, camera: Camera ): void; intersectObject(object: Object3D, recursive?: boolean): Intersection[]; intersectObjects(objects: Object3D[], recursive?: boolean): Intersection[]; } + export class Layers { + constructor(); + + mask: number; + + set(channel: number): void; + enable(channel: number): void; + toggle(channel: number): void; + disable(channel: number): void; + test(layers: Layers): boolean; + } + + export class Font { + constructor(jsondata: string); + + data: string; + + generateShapes(text: string, size: number, divisions: number): any[]; + } + // Lights ////////////////////////////////////////////////////////////////////////////////// /** * Abstract base class for lights. */ export class Light extends Object3D { - constructor(hex?: number); + constructor(hex?: number|string, intensity?: number); color: Color; - + intensity: number; + receiveShadow: boolean; shadow: LightShadow; + shadowCameraFov: any; // deprecated, use shadow.camera.fov + shadowCameraLeft: any; // deprecated, use shadow.camera.left + shadowCameraRight: any; // deprecated, use shadow.camera.right + shadowCameraTop: any; // deprecated, use shadow.camera.top + shadowCameraBottom: any; // deprecated, use shadow.camera.bottom + shadowCameraNear: any; // deprecated, use shadow.camera.near + shadowCameraFar: any; // deprecated, use shadow.camera.far + shadowBias: any; // deprecated, use shadow.bias + shadowMapWidth: any; // deprecated, use shadow.mapSize.width + shadowMapHeight: any; // deprecated, use shadow.mapSize.height + + copy(source: Light): Light; + clone(recursive?: boolean): Light; + } - /** Deprecated, use shadow */ - shadowCameraFov: number; - shadowCameraNear: number; - shadowCameraFar: number; - shadowCameraLeft: number; - shadowCameraRight: number; - shadowCameraTop: number; - shadowCameraBottom: number; - shadowBias: number; - shadowDarkness: number; - shadowMapWidth: number; - shadowMapHeight: number; - shadowMap: RenderTarget; - shadowMapSize: number; - shadowCamera: Camera; - shadowMatrix: Matrix4; - - clone(light?: Light): Light; - } - export class LightShadow { constructor(camera: Camera); - camera: THREE.Camera; - + camera: Camera; bias: number; - darkness: number; - - mapSize: THREE.Vector2; + radius: number; + mapSize: Vector2; + map: RenderTarget; + matrix: Matrix4; - map: any; - matrix: THREE.Matrix4; - - clone(): LightShadow; + copy(source: LightShadow): LightShadow; + clone(recursive?: boolean): LightShadow; + toJSON(): any; } /** @@ -1505,9 +1820,12 @@ declare module THREE { * This creates a Ambientlight with a color. * @param hex Numeric value of the RGB component of the color. */ - constructor(hex?: number); + constructor(hex?: number|string, intensity?: number); - clone(): AmbientLight; + castShadow: boolean; + + copy(source: AmbientLight): AmbientLight; + clone(recursive?: boolean): AmbientLight; } /** @@ -1522,8 +1840,7 @@ declare module THREE { * @see src/lights/DirectionalLight.js */ export class DirectionalLight extends Light { - - constructor(hex?: number, intensity?: number); + constructor(hex?: number|string, intensity?: number); /** * Target used for shadow camera orientation. @@ -1536,16 +1853,22 @@ declare module THREE { */ intensity: number; - clone(): DirectionalLight; + shadow: LightShadow; + + copy(source: DirectionalLight): DirectionalLight; + clone(recursive?: boolean): HemisphereLight; } + export class DirectionalLightShadow extends LightShadow {} + export class HemisphereLight extends Light { - constructor(skyColorHex?: number, groundColorHex?: number, intensity?: number); + constructor(skyColorHex?: number|string, groundColorHex?: number|string, intensity?: number); groundColor: Color; intensity: number; - clone(): HemisphereLight; + copy(source: HemisphereLight): HemisphereLight; + clone(recursive?: boolean): HemisphereLight; } /** @@ -1557,7 +1880,7 @@ declare module THREE { * scene.add( light ); */ export class PointLight extends Light { - constructor(hex?: number, intensity?: number, distance?: number, decay?: number); + constructor(hex?: number|string, intensity?: number, distance?: number, decay?: number); /* * Light's intensity. @@ -1572,15 +1895,18 @@ declare module THREE { distance: number; decay: number; + shadow: LightShadow; + power: number; - clone(): PointLight; + copy(source: PointLight): PointLight; + clone(recursive?: boolean): PointLight; } /** * A point light that can cast shadow in one direction. */ export class SpotLight extends Light { - constructor(hex?: number, intensity?: number, distance?: number, angle?: number, exponent?: number, decay?: number); + constructor(hex?: number|string, intensity?: number, distance?: number, angle?: number, exponent?: number, decay?: number); /** * Spotlight focus points at target.position. @@ -1613,17 +1939,20 @@ declare module THREE { exponent: number; decay: number; + shadow: SpotLightShadow; + power: number; + penumbra: number; - clone(): SpotLight; + clone(recursive?: boolean): SpotLight; + copy(source: PointLight): SpotLight; } - // Loaders ////////////////////////////////////////////////////////////////////////////////// - - export interface Progress { - total: number; - loaded: number; + export class SpotLightShadow extends LightShadow { + update(light: Light): void; } + // Loaders ////////////////////////////////////////////////////////////////////////////////// + /** * Base class for implementing loaders. * @@ -1640,8 +1969,6 @@ declare module THREE { export class Loader { constructor(); - imageLoader: ImageLoader; - /** * Will be called when load starts. * The default is a function with empty body. @@ -1668,62 +1995,41 @@ declare module THREE { extractUrlBase(url: string): string; initMaterials(materials: Material[], texturePath: string): Material[]; - needsTangents(materials: Material[]): boolean; - createMaterial(m: Material, texturePath: string): boolean; + createMaterial(m: Material, texturePath: string, crossOrigin?: string): boolean; static Handlers: LoaderHandler; } export interface LoaderHandler { - handlers: any[]; - add(regex: string, loader: Loader): void; - get(file: string): Loader; - } - - export class BinaryTextureLoader { - constructor(); + handlers: (RegExp | Loader)[]; - load(url: string, onLoad: (dataTexture: DataTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + add(regex: RegExp, loader: Loader): void; + get(file: string): Loader; } - export class BufferGeometryLoader { + export class XHRLoader { constructor(manager?: LoadingManager); manager: LoadingManager; - load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; - setCrossOrigin(crossOrigin: string): void; - parse(json: any): BufferGeometry; - } - - export interface Cache { - enabled: boolean; - files: any[]; + path: string; + responseType: string; + withCredentials: boolean; - add(key: string, file: any): void; - get(key: string): any; - remove(key: string): void; - clear(): void; + load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): any; + setPath(path: string): XHRLoader; + setResponseType(responseType: string): XHRLoader; + setWithCredentials(withCredentials: boolean): XHRLoader; } - export var Cache: Cache; - export class CompressedTextureLoader { - constructor(); + export class FontLoader { + constructor(manager?: LoadingManager); - load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onError?: (event: any) => void): void; - } + manager: LoadingManager; - export class DataTextureLoader extends BinaryTextureLoader { - // alias for BinaryTextureLoader. + load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + parse(json: string): Font; } - /* - * GeometryLoader class is experimental, and it is not yet included in the compiled source code. - * - export class GeometryLoader { - - } - */ - /** * A loader for loading an image. * Unlike other loaders, this one emits events instead of using predefined callbacks. So if you're interested in getting notified when things happen, you need to add listeners to the object. @@ -1731,36 +2037,32 @@ declare module THREE { export class ImageLoader { constructor(manager?: LoadingManager); - cache: Cache; manager: LoadingManager; crossOrigin: string; + withCredentials: string; + path: string; /** * Begin loading from url * @param url */ load(url: string, onLoad?: (image: HTMLImageElement) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): HTMLImageElement; - - setCrossOrigin(crossOrigin: string): void; + setCrossOrigin(crossOrigin: string): ImageLoader; + setWithCredentials(value: string): ImageLoader; + setPath(value: string): ImageLoader; } /** * A loader for loading objects in JSON format. */ export class JSONLoader extends Loader { - constructor(); + constructor(manager?: LoadingManager); + manager: LoadingManager; withCredentials: boolean; - /** - * @param url - * @param callback. This function will be called with the loaded model as an instance of geometry when the load is completed. - * @param texturePath If not specified, textures will be assumed to be in the same folder as the Javascript model file. - */ - load(url: string, callback: (geometry: Geometry, materials: Material[]) => void , texturePath?: string): void; - - loadAjaxJSON(context: JSONLoader, url: string, callback: (geometry: Geometry, materials: Material[]) => void , texturePath?: string, callbackProgress?: (progress: Progress) => void ): void; - + load(url: string, onLoad?: (geometry: Geometry, materials: Material[]) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + setTexturePath( value: string ): void; parse(json: any, texturePath?: string): { geometry: Geometry; materials?: Material[] }; } @@ -1792,16 +2094,29 @@ declare module THREE { itemStart(url: string): void; itemEnd(url: string): void; + itemError(url: string): void; + } + export const DefaultLoadingManager: LoadingManager; + + export class BufferGeometryLoader { + constructor(manager?: LoadingManager); + + manager: LoadingManager; + + load(url: string, onLoad: (bufferGeometry: BufferGeometry) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + parse(json: any): BufferGeometry; } export class MaterialLoader { constructor(manager?: LoadingManager); manager: LoadingManager; + textures: { [key: string]: Texture }; load(url: string, onLoad: (material: Material) => void): void; - setCrossOrigin(crossOrigin: string): void; + setTextures(textures: { [key: string]: Texture }): void; + getTexture(name: string): Texture; parse(json: any): Material; } @@ -1810,6 +2125,7 @@ declare module THREE { manager: LoadingManager; texturePass: string; + crossOrigin: string; load(url: string, onLoad?: (object: Object3D) => void): void; setTexturePath( value: string ): void; @@ -1817,10 +2133,10 @@ declare module THREE { parse(json: any, onLoad?: (object: Object3D) => void): T; parseGeometries(json: any): any[]; // Array of BufferGeometry or Geometry or Geometry2. parseMaterials(json: any, textures: Texture[]): Material[]; // Array of Classes that inherits from Matrial. - parseImages( json: any, onLoad: () => void ): any[]; - parseTextures( json: any, images: any ): Texture[]; + parseAnimations(json: any): AnimationClip[]; + parseImages(json: any, onLoad: () => void): any[]; + parseTextures(json: any, images: any): Texture[]; parseObject(data: any, geometries: any[], materials: Material[]): T; - } /** @@ -1832,30 +2148,70 @@ declare module THREE { manager: LoadingManager; crossOrigin: string; + withCredentials: string; + path: string; /** * Begin loading from url * * @param url */ - load(url: string, onLoad: (texture: Texture) => void): void; - setCrossOrigin(crossOrigin: string): void; + load(url: string, onLoad?: (texture: Texture) => void): Texture; + setCrossOrigin(crossOrigin: string): TextureLoader; + setWithCredentials(value: string): TextureLoader; + setPath(path: string): TextureLoader; } - export class XHRLoader { + export class CubeTextureLoader { constructor(manager?: LoadingManager); - cache: Cache; manager: LoadingManager; - responseType: string; - crossOrigin: string; + corssOrigin: string; + path: string; - load(url: string, onLoad?: (responseText: string) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; - setResponseType(responseType: string): void; - setCrossOrigin(crossOrigin: string): void; + load(urls: Array, onLoad?: (texture: CubeTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + setCrossOrigin(crossOrigin: string): CubeTextureLoader; + setPath(path: string): CubeTextureLoader; + } + + export class BinaryTextureLoader { + constructor(manager?: LoadingManager); + + manager: LoadingManager; + + load(url: string, onLoad: (dataTexture: DataTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + } + export class DataTextureLoader extends BinaryTextureLoader {} + + export class CompressedTextureLoader { + constructor(manager?: LoadingManager); + + manager: LoadingManager; + path: string; + + load(url: string, onLoad: (texture: CompressedTexture) => void, onProgress?: (event: any) => void, onError?: (event: any) => void): void; + setPath(path: string): CompressedTextureLoader; + } + + export class AudioLoader { + constructor(manager?: LoadingManager); + + load(url: string, onLoad: Function, onPrgress: Function, onError: Function): void; + } + + export namespace Cache { + export let enabled: boolean; + export let files: any; + + export function add(key: string, file: any): void; + export function get(key: string): any; + export function remove(key: string): void; + export function clear(): void; } // Materials ////////////////////////////////////////////////////////////////////////////////// + export let MaterialIdCount: number; + export interface MaterialParameters { name?: string; side?: Side; @@ -1865,21 +2221,31 @@ declare module THREE { blendSrc?: BlendingDstFactor; blendDst?: BlendingSrcFactor; blendEquation?: BlendingEquation; + blendSrcAlpha?: number; + blendDstAlpha?: number; + blendEquationAlpha?: number; + depthFunc?: DepthModes; depthTest?: boolean; depthWrite?: boolean; + colorWrite?: boolean; + precision?: number; polygonOffset?: boolean; polygonOffsetFactor?: number; polygonOffsetUnits?: number; alphaTest?: number; + premultipliedAlpha?: boolean; overdraw?: number; visible?: boolean; - needsUpdate?: boolean; + fog?: boolean; + lights?: boolean; + shading?: Shading; + vertexColors?: Colors; } /** * Materials describe the appearance of objects. They are defined in a (mostly) renderer-independent way, so you don't have to rewrite materials if you decide to use a different renderer. */ - export class Material { + export class Material extends EventDispatcher { constructor(); /** @@ -1937,7 +2303,7 @@ declare module THREE { blendDstAlpha: number; blendEquationAlpha: number; - depthFunc: Function; + depthFunc: DepthModes; /** * Whether to have depth test enabled when rendering this material. Default is true. @@ -1950,8 +2316,13 @@ declare module THREE { */ depthWrite: boolean; + clippingPlanes: any; + clipShadows: boolean; + colorWrite: boolean; + precision: any; + /** * Whether to use polygon offset. Default is false. This corresponds to the POLYGON_OFFSET_FILL WebGL feature. */ @@ -1972,6 +2343,8 @@ declare module THREE { */ alphaTest: number; + premultipliedAlpha: boolean; + /** * Enables/disables overdraw. If greater than zero, polygons are drawn slightly bigger in order to fix antialiasing gaps when using the CanvasRenderer. Default is 0. */ @@ -1988,26 +2361,27 @@ declare module THREE { */ needsUpdate: boolean; - setValues(values: Object): void; - toJSON(): any; - clone(material?:Material): Material; + fog: boolean; + lights: boolean; + shading: Shading; + vertexColors: Colors; + + setValues(parameters: MaterialParameters): void; + toJSON(meta?: any): any; + clone(): Material; + copy(source: Material): Material; update(): void; dispose(): void; - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; + // deprecated + warpRGB: Color; } export interface LineBasicMaterialParameters extends MaterialParameters { - color?: number; + color?: number|string; linewidth?: number; linecap?: string; linejoin?: string; - vertexColors?: Colors; - fog?: boolean; } export class LineBasicMaterial extends Material { @@ -2017,20 +2391,18 @@ declare module THREE { linewidth: number; linecap: string; linejoin: string; - vertexColors: Colors; - fog: boolean; + setValues(parameters: LineBasicMaterialParameters): void; clone(): LineBasicMaterial; + copy(source: LineBasicMaterial): LineBasicMaterial; } export interface LineDashedMaterialParameters extends MaterialParameters { - color?: number; + color?: number|string; linewidth?: number; scale?: number; dashSize?: number; gapSize?: number; - vertexColors?: Colors; - fog?: boolean; } export class LineDashedMaterial extends Material { @@ -2041,17 +2413,18 @@ declare module THREE { scale: number; dashSize: number; gapSize: number; - vertexColors: Colors; - fog: boolean; + setValues(parameters: LineDashedMaterialParameters): void; clone(): LineDashedMaterial; + copy(source: LineDashedMaterial): LineDashedMaterial; } /** * parameters is an object with one or more properties defining the material's appearance. */ - export interface MeshBasicMaterialParameters extends MaterialParameters{ - color?: number; + export interface MeshBasicMaterialParameters extends MaterialParameters { + color?: number|string; + opacity?: number; map?: Texture; aoMap?: Texture; aoMapIntensity?: number; @@ -2061,13 +2434,11 @@ declare module THREE { combine?: Combine; reflectivity?: number; refractionRatio?: number; - fog?: boolean; shading?: Shading; wireframe?: boolean; wireframeLinewidth?: number; wireframeLinecap?: string; wireframeLinejoin?: string; - vertexColors?: Colors; skinning?: boolean; morphTargets?: boolean; } @@ -2085,20 +2456,20 @@ declare module THREE { combine: Combine; reflectivity: number; refractionRatio: number; - fog: boolean; shading: Shading; wireframe: boolean; wireframeLinewidth: number; wireframeLinecap: string; wireframeLinejoin: string; - vertexColors: Colors; skinning: boolean; morphTargets: boolean; + setValues(parameters: MeshBasicMaterialParameters): void; clone(): MeshBasicMaterial; + copy(source: MeshBasicMaterial): MeshBasicMaterial; } - export interface MeshDepthMaterialParameters extends MaterialParameters{ + export interface MeshDepthMaterialParameters extends MaterialParameters { wireframe?: boolean; wireframeLinewidth?: number; } @@ -2109,35 +2480,31 @@ declare module THREE { wireframe: boolean; wireframeLinewidth: number; + setValues(parameters: MeshDepthMaterialParameters): void; clone(): MeshDepthMaterial; + copy(source: MeshDepthMaterial): MeshDepthMaterial; } - // MeshFaceMaterial does not inherit the Material class in the original code. However, it should treat as Material class. - // See tests/canvas/canvas_materials.ts. - export class MeshFaceMaterial extends Material { - constructor(materials?: Material[]); - materials: Material[]; - - toJSON(): any; - clone(): MeshFaceMaterial; - } - - export interface MeshLambertMaterialParameters extends MaterialParameters{ - color?: number; - emissive?: number; + export interface MeshLambertMaterialParameters extends MaterialParameters { + color?: number|string; + emissive?: number|string; + emissiveIntensity?: number; + emissiveMap?: Texture; map?: Texture; + lighhtMap?: Texture; + lightMapIntensity?: number; + aoMap?: Texture; + aoMapIntensity?: number; specularMap?: Texture; alphaMap?: Texture; envMap?: Texture; combine?: Combine; reflectivity?: number; refractionRatio?: number; - fog?: boolean; wireframe?: boolean; wireframeLinewidth?: number; wireframeLinecap?: string; wireframeLinejoin?: string; - vertexColors?: Colors; skinning?: boolean; morphTargets?: boolean; morphNormals?: boolean; @@ -2145,58 +2512,111 @@ declare module THREE { export class MeshLambertMaterial extends Material { constructor(parameters?: MeshLambertMaterialParameters); + color: Color; - emissive: Color; + emissive: number|string; + emissiveIntensity: number; + emissiveMap: Texture; map: Texture; + lighhtMap: Texture; + lightMapIntensity: number; + aoMap: Texture; + aoMapIntensity: number; specularMap: Texture; alphaMap: Texture; envMap: Texture; combine: Combine; reflectivity: number; refractionRatio: number; - fog: boolean; wireframe: boolean; wireframeLinewidth: number; wireframeLinecap: string; wireframeLinejoin: string; - vertexColors: Colors; skinning: boolean; morphTargets: boolean; morphNormals: boolean; + setValues(parameters: MeshLambertMaterialParameters): void; clone(): MeshLambertMaterial; + copy(source: MeshLambertMaterial): MeshLambertMaterial; } - export interface MeshNormalMaterialParameters extends MaterialParameters{ - /** Line color in hexadecimal. Default is 0xffffff. */ - color?: number; - /** Sets the texture map. Default is null */ + export interface MeshStandardMaterialParameters extends MaterialParameters { + color?: number|string; + roughness?: number; + metalness?: number; map?: Texture; - /** Set light map. Default is null. */ - lightMap?: Texture; - /** Set specular map. Default is null. */ - specularMap?: Texture; - /** Set alpha map. Default is null. */ + lighhtMap?: Texture; + lightMapIntensity?: number; + aoMap?: Texture; + aoMapIntensity?: number; + emissive?: Color; + emissiveIntensity?: number; + emissiveMap?: Texture; + bumpMap?: Texture; + bumpScale?: number; + normalMap?: Texture; + normalScale?: number; + displacementMap?: Texture; + displacementScale?: number; + displacementBias?: number; + roughnessMap?: Texture; + metalMap?: Texture; alphaMap?: Texture; - /** Set env map. Default is null. */ envMap?: Texture; - /** Define whether the material color is affected by global fog settings. Default is false. */ - fog?: boolean; - /** How the triangles of a curved surface are rendered. Default is THREE.SmoothShading. */ - shading?: Shading; + envMapIntensity?: number; + refractionRatio?: number; + wireframe?: boolean; + wireframeLinewidth?: number; + skinning?: boolean; + morphTargets?: boolean; + morphNormals?: boolean; + } + + export class MeshStandardMaterial extends Material { + constructor(parameters?: MeshStandardMaterialParameters); + + defines: any; + color: Color; + roughness: number; + metalness: number; + map: Texture; + lighhtMap: Texture; + lightMapIntensity: number; + aoMap: Texture; + aoMapIntensity: number; + emissive: Color; + emissiveIntensity: number; + emissiveMap: Texture; + bumpMap: Texture; + bumpScale: number; + normalMap: Texture; + normalScale: number; + displacementMap: Texture; + displacementScale: number; + displacementBias: number; + roughnessMap: Texture; + metalMap: Texture; + alphaMap: Texture; + envMap: Texture; + envMapIntensity: number; + refractionRatio: number; + wireframe: boolean; + wireframeLinewidth: number; + skinning: boolean; + morphTargets: boolean; + morphNormals: boolean; + + setValues(parameters: MeshStandardMaterialParameters): void; + clone(): MeshStandardMaterial; + copy(source: MeshStandardMaterial): MeshStandardMaterial; + } + + export interface MeshNormalMaterialParameters extends MaterialParameters { /** Render geometry as wireframe. Default is false (i.e. render as smooth shaded). */ wireframe?: boolean; /** Controls wireframe thickness. Default is 1. */ wireframeLinewidth?: number; - /** Define appearance of line ends. Default is 'round'. */ - wireframeLinecap?: string; - /** Define appearance of line joints. Default is 'round'. */ - wireframeLinejoin?: string; - /** Define how the vertices gets colored. Default is THREE.NoColors. */ - vertexColors?: Colors; - /** Define whether the material uses skinning. Default is false. */ - skinning?: boolean; - /** Define whether the material uses morphTargets. Default is false. */ morphTargets?: boolean; } @@ -2207,52 +2627,25 @@ declare module THREE { wireframeLinewidth: number; morphTargets: boolean; + setValues(parameters: MeshNormalMaterialParameters): void; clone(): MeshNormalMaterial; + copy(source: MeshNormalMaterial): MeshNormalMaterial; } export interface MeshPhongMaterialParameters extends MaterialParameters { /** geometry color in hexadecimal. Default is 0xffffff. */ - color?: number; - /** Sets the texture map. Default is null */ + color?: number|string; + specular?: number; + shininess?: number; + opacity?: number; map?: Texture; - /** Set light map. Default is null */ lightMap?: Texture; lightMapIntensity?: number; - aoMap?: Texture; aoMapIntensity?: number; - emissiveMap?: Texture; - - /** Set specular map. Default is null */ - specularMap?: Texture; - /** Set alpha map. Default is null */ - alphaMap?: Texture; - /** Set env map. Default is null */ - envMap?: Texture; - /** Define whether the material color is affected by global fog settings. Default is true */ - fog?: boolean; - /** Define shading type. Default is THREE.SmoothShading */ - shading?: Shading; - /** render geometry as wireframe. Default is false */ - wireframe?: string; - /** Line thickness. Default is 1. */ - wireframeLinewidth?: number; - /** Define appearance of line ends. Default is 'round' */ - wireframeLinecap?: string; - /** Define appearance of line joints. Default is 'round'. */ - wireframeLinejoin?: string; - /** Define how the vertices gets colored. Default is THREE.NoColors. */ - vertexColors?: Colors; - /** Define whether the material uses skinning. Default is false. */ - skinning?: boolean; - - /** Define whether the material uses morphTargets. Default is false. */ - morphTargets?: boolean; - emissive?: number; - specular?: number; - shininess?: number; - metal?: boolean; + emissiveIntensity?: number; + emissiveMap?: Texture; bumpMap?: Texture; bumpScale?: number; normalMap?: Texture; @@ -2260,9 +2653,18 @@ declare module THREE { displacementMap?: Texture; displacementScale?: number; displacementBias?: number; + specularMap?: Texture; + alphaMap?: Texture; + envMap?: Texture; combine?: Combine; reflectivity?: number; refractionRatio?: number; + wireframe?: boolean; + wireframeLinewidth?: number; + wireframeLinecap?: string; + wireframeLinejoin?: string; + skinning?: boolean; + morphTargets?: boolean; morphNormals?: boolean; } @@ -2270,15 +2672,15 @@ declare module THREE { constructor(parameters?: MeshPhongMaterialParameters); color: Color; // diffuse - emissive: Color; specular: Color; shininess: number; - metal: boolean; map: Texture; lightMap: Texture; lightMapIntensity: number; aoMap: Texture; aoMapIntensity: number; + emissive: Color; + emissiveIntensity: number; emissiveMap: Texture; bumpMap: Texture; bumpScale: number; @@ -2293,69 +2695,82 @@ declare module THREE { combine: Combine; reflectivity: number; refractionRatio: number; - fog: boolean; - shading: Shading; wireframe: boolean; wireframeLinewidth: number; wireframeLinecap: string; wireframeLinejoin: string; - vertexColors: Colors; skinning: boolean; morphTargets: boolean; morphNormals: boolean; + metal: boolean; // deprecated + setValues(parameters: MeshPhongMaterialParameters): void; clone(): MeshPhongMaterial; + copy(source: MeshPhongMaterial): MeshPhongMaterial; } - export interface PointCloudMaterialParameters extends MaterialParameters{ - color?: number; - map?: Texture; - size?: number; - sizeAttenuation?: boolean; - vertexColors?: Colors; - fog?: boolean; + export interface MeshPhysicalMaterialParameters extends MeshStandardMaterialParameters { + reflectivity?: number; + clearCoat?: number; + clearCoatRoughness?: number; } - export class PointCloudMaterial extends Material { - constructor(parameters?: PointCloudMaterialParameters); - - color: Color; - map: Texture; - size: number; - sizeAttenuation: boolean; - vertexColors: boolean; - fog: boolean; + export class MeshPhysicalMaterial extends MeshStandardMaterial { + constructor(parameters: MeshPhysicalMaterialParameters); - clone(): PointCloudMaterial; + defines: any; + reflectivity: number; + clearCoat: number; + clearCoatRoughness: number; } - // deprecated - export class ParticleBasicMaterial extends PointCloudMaterial{ + // MultiMaterial does not inherit the Material class in the original code. However, it should treat as Material class. + // See tests/canvas/canvas_materials.ts. + export class MultiMaterial extends Material { + constructor(materials?: Material[]); + + materials: Material[]; + toJSON(meta: any): any; + clone(): MultiMaterial; } - // deprecated - export class ParticleSystemMaterial extends PointCloudMaterial{ + export class MeshFaceMaterial extends MultiMaterial {} // deprecated, use MultiMaterial + export interface PointsMaterialParameters extends MaterialParameters { + color?: number|string; + map?: Texture; + size?: number; + sizeAttenuation?: boolean; } - export class RawShaderMaterial extends ShaderMaterial { - constructor(parameters?: ShaderMaterialParameters); + export class PointsMaterial extends Material { + constructor(parameters?: PointsMaterialParameters); + + color: Color; + map: Texture; + size: number; + sizeAttenuation: boolean; + setValues(parameters: PointsMaterialParameters): void; + clone(): PointsMaterial; + copy(source: PointsMaterial): PointsMaterial; } + export class PointCloudMaterial extends PointsMaterial {} // deprecated + export class ParticleBasicMaterial extends PointsMaterial {} // deprecated + export class ParticleSystemMaterial extends PointsMaterial {} // deprecated + export interface ShaderMaterialParameters extends MaterialParameters { defines?: any; uniforms?: any; vertexShader?: string; fragmentShader?: string; - shading?: Shading; - linewidth?: number; + lineWidth?: number; wireframe?: boolean; wireframeLinewidth?: number; - fog?: boolean; lights?: boolean; - vertexColors?: Colors; + clipping?: boolean; skinning?: boolean; morphTargets?: boolean; morphNormals?: boolean; @@ -2365,28 +2780,36 @@ declare module THREE { constructor(parameters?: ShaderMaterialParameters); defines: any; - uniforms: any; + uniforms: any; // type should be { [uniform: string]: { value: any }; }; but gives "Index signature is missing in type" error during compilation vertexShader: string; fragmentShader: string; - shading: Shading; linewidth: number; wireframe: boolean; wireframeLinewidth: number; - fog: boolean; lights: boolean; - vertexColors: Colors; + clipping: boolean; skinning: boolean; morphTargets: boolean; morphNormals: boolean; + derivatives: any; // deprecated, use extensions.derivatives + extensions: { derivatives: boolean; fragDepth: boolean; drawBuffers: boolean; shaderTextureLOD: boolean }; + defaultAttributeValues: any; + index0AttributeName: string; + setValues(parameters: ShaderMaterialParameters): void; clone(): ShaderMaterial; + copy(source: ShaderMaterial): ShaderMaterial; + toJSON(meta: any): any; + } + + export class RawShaderMaterial extends ShaderMaterial { + constructor(parameters?: ShaderMaterialParameters); } export interface SpriteMaterialParameters extends MaterialParameters { - color?: number; + color?: number|string; map?: Texture; rotation?: number; - fog?: boolean; } export class SpriteMaterial extends Material { @@ -2395,9 +2818,14 @@ declare module THREE { color: Color; map: Texture; rotation: number; - fog: boolean; + setValues(parameters: SpriteMaterialParameters): void; clone(): SpriteMaterial; + copy(source: SpriteMaterial): SpriteMaterial; + } + + export class ShadowMaterial extends ShaderMaterial { + constructor(parameters?: ShaderMaterialParameters); } // Math ////////////////////////////////////////////////////////////////////////////////// @@ -2411,9 +2839,10 @@ declare module THREE { set(min: Vector2, max: Vector2): Box2; setFromPoints(points: Vector2[]): Box2; setFromCenterAndSize(center: Vector2, size: Vector2): Box2; + clone(): Box2; copy(box: Box2): Box2; makeEmpty(): Box2; - empty(): boolean; + isEmpty(): boolean; center(optionalTarget?: Vector2): Vector2; size(optionalTarget?: Vector2): Vector2; expandByPoint(point: Vector2): Box2; @@ -2422,14 +2851,16 @@ declare module THREE { containsPoint(point: Vector2): boolean; containsBox(box: Box2): boolean; getParameter(point: Vector2): Vector2; - isIntersectionBox(box: Box2): boolean; + intersectsBox(box: Box2): boolean; clampPoint(point: Vector2, optionalTarget?: Vector2): Vector2; distanceToPoint(point: Vector2): number; intersect(box: Box2): Box2; union(box: Box2): Box2; translate(offset: Vector2): Box2; equals(box: Box2): boolean; - clone(): Box2; + + empty(): any; // deprecated, use isEmpty() + isIntersectionBox(b: any): any; // deprecated, use intersectsBox() } export class Box3 { @@ -2439,12 +2870,14 @@ declare module THREE { min: Vector3; set(min: Vector3, max: Vector3): Box3; + setFromArray(array: ArrayLike): Box3; setFromPoints(points: Vector3[]): Box3; setFromCenterAndSize(center: Vector3, size: Vector3): Box3; setFromObject(object: Object3D): Box3; + clone(): Box3; copy(box: Box3): Box3; makeEmpty(): Box3; - empty(): boolean; + isEmpty(): boolean; center(optionalTarget?: Vector3): Vector3; size(optionalTarget?: Vector3): Vector3; expandByPoint(point: Vector3): Box3; @@ -2453,7 +2886,9 @@ declare module THREE { containsPoint(point: Vector3): boolean; containsBox(box: Box3): boolean; getParameter(point: Vector3): Vector3; - isIntersectionBox(box: Box3): boolean; + intersectsBox(box: Box3): boolean; + intersectsSphere(sphere: Sphere): boolean; + intersectsPlane(plane: Plane): boolean; clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3; distanceToPoint(point: Vector3): number; getBoundingSphere(optionalTarget?: Sphere): Sphere; @@ -2462,7 +2897,10 @@ declare module THREE { applyMatrix4(matrix: Matrix4): Box3; translate(offset: Vector3): Box3; equals(box: Box3): boolean; - clone(): Box3; + + empty(): any; // deprecated, use isEmpty() + isIntersectionBox(b: any): any; // deprecated, use intersectsBox() + isIntersectionSphere(s: any): any; // deprecated, use intersectsSphere() } export interface HSL { @@ -2503,6 +2941,7 @@ declare module THREE { set(color: Color): Color; set(color: number): Color; set(color: string): Color; + setScalar(scalar: number): Color; setHex(hex: number): Color; /** @@ -2529,6 +2968,11 @@ declare module THREE { */ setStyle(style: string): Color; + /** + * Clones this color. + */ + clone(): Color; + /** * Copies given color. * @param color Color to copy. @@ -2580,167 +3024,163 @@ declare module THREE { add(color: Color): Color; addColors(color1: Color, color2: Color): Color; addScalar(s: number): Color; + sub(color: Color): Color; multiply(color: Color): Color; multiplyScalar(s: number): Color; lerp(color: Color, alpha: number): Color; equals(color: Color): boolean; - fromArray(rgb: number[]): Color; + fromArray(rgb: number[], offset?: number): Color; toArray(array?: number[], offset?: number): number[]; - - /** - * Clones this color. - */ - clone(): Color; } - export class ColorKeywords { - static aliceblue: number; - static antiquewhite: number; - static aqua: number; - static aquamarine: number; - static azure: number; - static beige: number; - static bisque: number; - static black: number; - static blanchedalmond: number; - static blue: number; - static blueviolet: number; - static brown: number; - static burlywood: number; - static cadetblue: number; - static chartreuse: number; - static chocolate: number; - static coral: number; - static cornflowerblue: number; - static cornsilk: number; - static crimson: number; - static cyan: number; - static darkblue: number; - static darkcyan: number; - static darkgoldenrod: number; - static darkgray: number; - static darkgreen: number; - static darkgrey: number; - static darkkhaki: number; - static darkmagenta: number; - static darkolivegreen: number; - static darkorange: number; - static darkorchid: number; - static darkred: number; - static darksalmon: number; - static darkseagreen: number; - static darkslateblue: number; - static darkslategray: number; - static darkslategrey: number; - static darkturquoise: number; - static darkviolet: number; - static deeppink: number; - static deepskyblue: number; - static dimgray: number; - static dimgrey: number; - static dodgerblue: number; - static firebrick: number; - static floralwhite: number; - static forestgreen: number; - static fuchsia: number; - static gainsboro: number; - static ghostwhite: number; - static gold: number; - static goldenrod: number; - static gray: number; - static green: number; - static greenyellow: number; - static grey: number; - static honeydew: number; - static hotpink: number; - static indianred: number; - static indigo: number; - static ivory: number; - static khaki: number; - static lavender: number; - static lavenderblush: number; - static lawngreen: number; - static lemonchiffon: number; - static lightblue: number; - static lightcoral: number; - static lightcyan: number; - static lightgoldenrodyellow: number; - static lightgray: number; - static lightgreen: number; - static lightgrey: number; - static lightpink: number; - static lightsalmon: number; - static lightseagreen: number; - static lightskyblue: number; - static lightslategray: number; - static lightslategrey: number; - static lightsteelblue: number; - static lightyellow: number; - static lime: number; - static limegreen: number; - static linen: number; - static magenta: number; - static maroon: number; - static mediumaquamarine: number; - static mediumblue: number; - static mediumorchid: number; - static mediumpurple: number; - static mediumseagreen: number; - static mediumslateblue: number; - static mediumspringgreen: number; - static mediumturquoise: number; - static mediumvioletred: number; - static midnightblue: number; - static mintcream: number; - static mistyrose: number; - static moccasin: number; - static navajowhite: number; - static navy: number; - static oldlace: number; - static olive: number; - static olivedrab: number; - static orange: number; - static orangered: number; - static orchid: number; - static palegoldenrod: number; - static palegreen: number; - static paleturquoise: number; - static palevioletred: number; - static papayawhip: number; - static peachpuff: number; - static peru: number; - static pink: number; - static plum: number; - static powderblue: number; - static purple: number; - static red: number; - static rosybrown: number; - static royalblue: number; - static saddlebrown: number; - static salmon: number; - static sandybrown: number; - static seagreen: number; - static seashell: number; - static sienna: number; - static silver: number; - static skyblue: number; - static slateblue: number; - static slategray: number; - static slategrey: number; - static snow: number; - static springgreen: number; - static steelblue: number; - static tan: number; - static teal: number; - static thistle: number; - static tomato: number; - static turquoise: number; - static violet: number; - static wheat: number; - static white: number; - static whitesmoke: number; - static yellow: number; - static yellowgreen: number; + export namespace ColorKeywords { + export const aliceblue: number; + export const antiquewhite: number; + export const aqua: number; + export const aquamarine: number; + export const azure: number; + export const beige: number; + export const bisque: number; + export const black: number; + export const blanchedalmond: number; + export const blue: number; + export const blueviolet: number; + export const brown: number; + export const burlywood: number; + export const cadetblue: number; + export const chartreuse: number; + export const chocolate: number; + export const coral: number; + export const cornflowerblue: number; + export const cornsilk: number; + export const crimson: number; + export const cyan: number; + export const darkblue: number; + export const darkcyan: number; + export const darkgoldenrod: number; + export const darkgray: number; + export const darkgreen: number; + export const darkgrey: number; + export const darkkhaki: number; + export const darkmagenta: number; + export const darkolivegreen: number; + export const darkorange: number; + export const darkorchid: number; + export const darkred: number; + export const darksalmon: number; + export const darkseagreen: number; + export const darkslateblue: number; + export const darkslategray: number; + export const darkslategrey: number; + export const darkturquoise: number; + export const darkviolet: number; + export const deeppink: number; + export const deepskyblue: number; + export const dimgray: number; + export const dimgrey: number; + export const dodgerblue: number; + export const firebrick: number; + export const floralwhite: number; + export const forestgreen: number; + export const fuchsia: number; + export const gainsboro: number; + export const ghostwhite: number; + export const gold: number; + export const goldenrod: number; + export const gray: number; + export const green: number; + export const greenyellow: number; + export const grey: number; + export const honeydew: number; + export const hotpink: number; + export const indianred: number; + export const indigo: number; + export const ivory: number; + export const khaki: number; + export const lavender: number; + export const lavenderblush: number; + export const lawngreen: number; + export const lemonchiffon: number; + export const lightblue: number; + export const lightcoral: number; + export const lightcyan: number; + export const lightgoldenrodyellow: number; + export const lightgray: number; + export const lightgreen: number; + export const lightgrey: number; + export const lightpink: number; + export const lightsalmon: number; + export const lightseagreen: number; + export const lightskyblue: number; + export const lightslategray: number; + export const lightslategrey: number; + export const lightsteelblue: number; + export const lightyellow: number; + export const lime: number; + export const limegreen: number; + export const linen: number; + export const magenta: number; + export const maroon: number; + export const mediumaquamarine: number; + export const mediumblue: number; + export const mediumorchid: number; + export const mediumpurple: number; + export const mediumseagreen: number; + export const mediumslateblue: number; + export const mediumspringgreen: number; + export const mediumturquoise: number; + export const mediumvioletred: number; + export const midnightblue: number; + export const mintcream: number; + export const mistyrose: number; + export const moccasin: number; + export const navajowhite: number; + export const navy: number; + export const oldlace: number; + export const olive: number; + export const olivedrab: number; + export const orange: number; + export const orangered: number; + export const orchid: number; + export const palegoldenrod: number; + export const palegreen: number; + export const paleturquoise: number; + export const palevioletred: number; + export const papayawhip: number; + export const peachpuff: number; + export const peru: number; + export const pink: number; + export const plum: number; + export const powderblue: number; + export const purple: number; + export const red: number; + export const rosybrown: number; + export const royalblue: number; + export const saddlebrown: number; + export const salmon: number; + export const sandybrown: number; + export const seagreen: number; + export const seashell: number; + export const sienna: number; + export const silver: number; + export const skyblue: number; + export const slateblue: number; + export const slategray: number; + export const slategrey: number; + export const snow: number; + export const springgreen: number; + export const steelblue: number; + export const tan: number; + export const teal: number; + export const thistle: number; + export const tomato: number; + export const turquoise: number; + export const violet: number; + export const wheat: number; + export const white: number; + export const whitesmoke: number; + export const yellow: number; + export const yellowgreen: number; } export class Euler { @@ -2750,20 +3190,23 @@ declare module THREE { y: number; z: number; order: string; + onChangeCallback: Function; set(x: number, y: number, z: number, order?: string): Euler; + clone(): Euler; copy(euler: Euler): Euler; setFromRotationMatrix(m: Matrix4, order?: string, update?: boolean): Euler; - setFromQuaternion(q:Quaternion, order?: string, update?: boolean): Euler; + setFromQuaternion(q: Quaternion, order?: string, update?: boolean): Euler; setFromVector3( v: Vector3, order?: string ): Euler; reorder(newOrder: string): Euler; equals(euler: Euler): boolean; fromArray(xyzo: any[]): Euler; toArray(array?: number[], offset?: number): number[]; toVector3(optionalResult?: Vector3): Vector3; - onChange: () => void; + onChange(callback: Function): void; - clone(): Euler; + static RotationOrders: string[]; + static DefaultOrder: string; } /** @@ -2778,22 +3221,24 @@ declare module THREE { planes: Plane[]; set(p0?: number, p1?: number, p2?: number, p3?: number, p4?: number, p5?: number): Frustum; + clone(): Frustum; copy(frustum: Frustum): Frustum; setFromMatrix(m: Matrix4): Frustum; intersectsObject(object: Object3D): boolean; + intersectsObject(sprite: Sprite): boolean; intersectsSphere(sphere: Sphere): boolean; intersectsBox(box: Box3): boolean; containsPoint(point: Vector3): boolean; - clone(): Frustum; - } export class Line3 { constructor(start?: Vector3, end?: Vector3); + start: Vector3; end: Vector3; set(start?: Vector3, end?: Vector3): Line3; + clone(): Line3; copy(line: Line3): Line3; center(optionalTarget?: Vector3): Vector3; delta(optionalTarget?: Vector3): Vector3; @@ -2804,21 +3249,27 @@ declare module THREE { closestPointToPoint(point: Vector3, clampToLine?: boolean, optionalTarget?: Vector3): Vector3; applyMatrix4(matrix: Matrix4): Line3; equals(line: Line3): boolean; - clone(): Line3; } - interface Math { - generateUUID(): string; + /** + * + * @see src/math/Math.js + */ + export namespace Math { + export const DEG2RAD: number; + export const RAD2DEG: number; + + export function generateUUID(): string; /** * Clamps the x to be between a and b. * - * @param x Value to be clamped. - * @param a Minimum value - * @param b Maximum value. + * @param value Value to be clamped. + * @param min Minimum value + * @param max Maximum value. */ - clamp(x: number, a: number, b: number): number; - + export function clamp(value: number, min: number, max: number): number; + export function euclideanModulo( n: number, m: number ): number; /** * Linear mapping of x from range [a1, a2] to range [b1, b2]. @@ -2829,47 +3280,43 @@ declare module THREE { * @param b1 Minimum value for range B. * @param b2 Maximum value for range B. */ - mapLinear(x: number, a1: number, a2: number, b1: number, b2: number): number; + export function mapLinear(x: number, a1: number, a2: number, b1: number, b2: number): number; - smoothstep(x: number, min: number, max: number): number; + export function smoothstep(x: number, min: number, max: number): number; - smootherstep(x: number, min: number, max: number): number; + export function smootherstep(x: number, min: number, max: number): number; /** * Random float from 0 to 1 with 16 bits of randomness. * Standard Math.random() creates repetitive patterns when applied over larger space. */ - random16(): number; + export function random16(): number; // deprecated, use Math.random() /** * Random integer from low to high interval. */ - randInt(low: number, high: number): number; + export function randInt(low: number, high: number): number; /** * Random float from low to high interval. */ - randFloat(low: number, high: number): number; + export function randFloat(low: number, high: number): number; /** * Random float from - range / 2 to range / 2 interval. */ - randFloatSpread(range: number): number; + export function randFloatSpread(range: number): number; - degToRad(degrees: number): number; + export function degToRad(degrees: number): number; - radToDeg(radians: number): number; + export function radToDeg(radians: number): number; - isPowerOfTwo(value: number): boolean; + export function isPowerOfTwo(value: number): boolean; - nextPowerOfTwo(value: number): number; - } + export function nearestPowerOfTwo(value: number): number; - /** - * - * @see src/math/Math.js - */ - export var Math: Math; + export function nextPowerOfTwo(value: number): number; + } /** * ( interface Matrix<T> ) @@ -2922,11 +3369,6 @@ declare module THREE { */ constructor(); - /** - * Initialises the matrix with the supplied n11..n33 values. - */ - constructor(n11: number, n12: number, n13: number, n21: number, n22: number, n23: number, n31: number, n32: number, n33: number); - /** * Float32Array with matrix values. */ @@ -2934,19 +3376,20 @@ declare module THREE { set(n11: number, n12: number, n13: number, n21: number, n22: number, n23: number, n31: number, n32: number, n33: number): Matrix3; identity(): Matrix3; + clone(): Matrix3; copy(m: Matrix3): Matrix3; - applyToVector3Array(array: number[], offset?: number, length?: number): number[]; + setFromMatrix4(m: Matrix4): Matrix3; + applyToVector3Array(array: ArrayLike, offset?: number, length?: number): ArrayLike; + applyToBuffer(buffer: BufferAttribute, offset?: number, length?: number): BufferAttribute; multiplyScalar(s: number): Matrix3; determinant(): number; - getInverse(matrix: Matrix3, throwOnInvertible?: boolean): Matrix3; - getInverse(matrix: Matrix4, throwOnInvertible?: boolean): Matrix3; + getInverse(matrix: Matrix3, throwOnDegenerate?: boolean): Matrix3; /** * Transposes this matrix in place. */ transpose(): Matrix3; - flattenToArrayOffset(array: number[], offset: number): number[]; - getNormalMatrix(m: Matrix4): Matrix3; + getNormalMatrix(matrix4: Matrix4): Matrix3; /** * Transposes this matrix into the supplied array r, and returns itself. @@ -2954,7 +3397,12 @@ declare module THREE { transposeIntoArray(r: number[]): number[]; fromArray(array: number[]): Matrix3; toArray(): number[]; - clone(): Matrix3; + + // deprecated + multiplyVector3(vector: Vector3): any; + multiplyVector3Array(a: any): any; + getInverse(matrix: Matrix4, throwOnDegenerate?: boolean): Matrix3; + flattenToArrayOffset(array: number[], offset: number): number[]; } /** @@ -2976,10 +3424,7 @@ declare module THREE { * m.multiply( m3 ); */ export class Matrix4 implements Matrix { - /** - * Initialises the matrix with the supplied n11..n44 values. - */ - constructor(n11?: number, n12?: number, n13?: number, n14?: number, n21?: number, n22?: number, n23?: number, n24?: number, n31?: number, n32?: number, n33?: number, n34?: number, n41?: number, n42?: number, n43?: number, n44?: number); + constructor(); /** * Float32Array with matrix values. @@ -2995,13 +3440,9 @@ declare module THREE { * Resets this matrix to identity. */ identity(): Matrix4; - - /** - * Copies a matrix m into this matrix. - */ + clone(): Matrix4; copy(m: Matrix4): Matrix4; copyPosition(m: Matrix4): Matrix4; - extractBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4; makeBasis( xAxis: Vector3, yAxis: Vector3, zAxis: Vector3): Matrix4; @@ -3021,6 +3462,8 @@ declare module THREE { */ multiply(m: Matrix4): Matrix4; + premultiply(m: Matrix4): Matrix4; + /** * Sets this matrix to a x b. */ @@ -3036,8 +3479,8 @@ declare module THREE { * Multiplies this matrix by s. */ multiplyScalar(s: number): Matrix4; - applyToVector3Array(array: number[], offset?: number, length?: number): number[]; - + applyToVector3Array(array: ArrayLike, offset?: number, length?: number): ArrayLike; + applyToBuffer( buffer: BufferAttribute, offset?: number, length?: number): BufferAttribute; /** * Computes determinant of this matrix. * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm @@ -3049,21 +3492,19 @@ declare module THREE { */ transpose(): Matrix4; - /** - * Flattens this matrix into supplied flat array starting from offset position in the array. - */ - flattenToArrayOffset(array: number[], offset: number): number[]; + /** * Sets the position component for this matrix from vector v. */ - setPosition(v: Vector3): Vector3; + setPosition(v: Vector3): Matrix4; + /** * Sets this matrix to the inverse of matrix m. * Based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm. */ - getInverse(m: Matrix4, throwOnInvertible?: boolean): Matrix4; + getInverse(m: Matrix4, throwOnDegeneratee?: boolean): Matrix4; /** * Multiplies the columns of this matrix by vector v. @@ -3136,12 +3577,19 @@ declare module THREE { * Creates an orthographic projection matrix. */ makeOrthographic(left: number, right: number, top: number, bottom: number, near: number, far: number): Matrix4; + equals( matrix: Matrix4 ): boolean; fromArray(array: number[]): Matrix4; toArray(): number[]; - /** - * Clones this matrix. - */ - clone(): Matrix4; + + // deprecated + extractPosition(m: Matrix4): Matrix4; + setRotationFromQuaternion(q: Quaternion): Matrix4; + multiplyVector3(v: any): any; + multiplyVector4(v: any): any; + multiplyVector3Array(array: number[]): number[]; + rotateAxis(v: any): void; + crossVector(v: any): void; + flattenToArrayOffset(array: number[], offset: number): number[]; } export class Plane { @@ -3154,6 +3602,7 @@ declare module THREE { setComponents(x: number, y: number, z: number, w: number): Plane; setFromNormalAndCoplanarPoint(normal: Vector3, point: Vector3): Plane; setFromCoplanarPoints(a: Vector3, b: Vector3, c: Vector3): Plane; + clone(): Plane; copy(plane: Plane): Plane; normalize(): Plane; negate(): Plane; @@ -3161,13 +3610,26 @@ declare module THREE { distanceToSphere(sphere: Sphere): number; projectPoint(point: Vector3, optionalTarget?: Vector3): Vector3; orthoPoint(point: Vector3, optionalTarget?: Vector3): Vector3; - isIntersectionLine(line: Line3): boolean; intersectLine(line: Line3, optionalTarget?: Vector3): Vector3; + intersectsLine(line: Line3): boolean; + intersectsBox(box: Box3): boolean; coplanarPoint(optionalTarget?: boolean): Vector3; applyMatrix4(matrix: Matrix4, optionalNormalMatrix?: Matrix3): Plane; translate(offset: Vector3): Plane; equals(plane: Plane): boolean; - clone(): Plane; + + // deprecated + isIntersectionLine(l: any): any; + } + + export class Spherical { + constructor(radius?: number, phi?: number, theta?: number); + + set(radius: number, phi: number, theta: number): Spherical; + clone(): Spherical; + copy(other: Spherical): Spherical; + makeSafe(): void; + setFromVector3(vec3: Vector3): Spherical; } /** @@ -3198,6 +3660,11 @@ declare module THREE { */ set(x: number, y: number, z: number, w: number): Quaternion; + /** + * Clones this quaternion. + */ + clone(): Quaternion; + /** * Copies values of q to this quaternion. */ @@ -3243,6 +3710,7 @@ declare module THREE { * Multiplies this quaternion by b. */ multiply(q: Quaternion): Quaternion; + premultiply(q: Quaternion): Quaternion; /** * Sets this quaternion to a x b @@ -3250,10 +3718,7 @@ declare module THREE { */ multiplyQuaternions(a: Quaternion, b: Quaternion): Quaternion; - /** - * Deprecated. Use Vector3.applyQuaternion instead - */ - multiplyVector3(vector: Vector3): Vector3; + slerp(qb: Quaternion, t: number): Quaternion; equals(v: Quaternion): boolean; fromArray(n: number[]): Quaternion; @@ -3262,17 +3727,18 @@ declare module THREE { fromArray(xyzw: number[], offset?: number): Quaternion; toArray(xyzw?: number[], offset?: number): number[]; - onChange: () => void; - - /** - * Clones this quaternion. - */ - clone(): Quaternion; + onChange(callback: Function): Quaternion; + onChangeCallback: Function; /** * Adapted from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/. */ static slerp(qa: Quaternion, qb: Quaternion, qm: Quaternion, t: number): Quaternion; + + static slerpFlat(dst: number[], dstOffset: number, src0: number[], srcOffset: number, src1: number[], stcOffset1: number, t: number): Quaternion; + + // deprecated + multiplyVector3(v: any): any; } export class Ray { @@ -3282,24 +3748,30 @@ declare module THREE { direction: Vector3; set(origin: Vector3, direction: Vector3): Ray; + clone(): Ray; copy(ray: Ray): Ray; at(t: number, optionalTarget?: Vector3): Vector3; + lookAt(v: Vector3): Vector3; recast(t: number): Ray; closestPointToPoint(point: Vector3, optionalTarget?: Vector3): Vector3; distanceToPoint(point: Vector3): number; distanceSqToPoint(point: Vector3): number; distanceSqToSegment(v0: Vector3, v1: Vector3, optionalPointOnRay?: Vector3, optionalPointOnSegment?: Vector3): number; - isIntersectionSphere(sphere: Sphere): boolean; intersectSphere(sphere: Sphere, optionalTarget?: Vector3): Vector3; - isIntersectionPlane(plane: Plane): boolean; + intersectsSphere(sphere: Sphere): boolean; distanceToPlane(plane: Plane): number; intersectPlane(plane: Plane, optionalTarget?: Vector3): Vector3; - isIntersectionBox(box: Box3): boolean; + intersectsPlane(plane: Plane): boolean; intersectBox(box: Box3, optionalTarget?: Vector3): Vector3; + intersectsBox(box: Box3): boolean; intersectTriangle(a: Vector3, b: Vector3, c: Vector3, backfaceCulling: boolean, optionalTarget?: Vector3): Vector3; applyMatrix4(matrix4: Matrix4): Ray; equals(ray: Ray): boolean; - clone(): Ray; + + // deprecated + isIntersectionBox(b: any): any; + isIntersectionPlane(p: any): any; + isIntersectionSphere(s: any): any; } export class Sphere { @@ -3310,18 +3782,19 @@ declare module THREE { set(center: Vector3, radius: number): Sphere; setFromPoints(points: Vector3[], optionalCenter?: Vector3): Sphere; + clone(): Sphere; copy(sphere: Sphere): Sphere; empty(): boolean; containsPoint(point: Vector3): boolean; distanceToPoint(point: Vector3): number; intersectsSphere(sphere: Sphere): boolean; + intersectsBox(box: Box3): boolean; + intersectsPlane(plane: Plane): boolean; clampPoint(point: Vector3, optionalTarget?: Vector3): Vector3; getBoundingBox(optionalTarget?: Box3): Box3; applyMatrix4(matrix: Matrix4): Sphere; translate(offset: Vector3): Sphere; equals(sphere: Sphere): boolean; - - clone(): Sphere; } export interface SplineControlPoint { @@ -3386,6 +3859,7 @@ declare module THREE { set(a: Vector3, b: Vector3, c: Vector3): Triangle; setFromPointsAndIndices(points: Vector3[], i0: number, i1: number, i2: number): Triangle; + clone(): Triangle; copy(triangle: Triangle): Triangle; area(): number; midpoint(optionalTarget?: Vector3): Vector3; @@ -3393,15 +3867,14 @@ declare module THREE { plane(optionalTarget?: Vector3): Plane; barycoordFromPoint(point: Vector3, optionalTarget?: Vector3): Vector3; containsPoint(point: Vector3): boolean; + closestPointToPoint(): Vector3; equals(triangle: Triangle): boolean; - clone(): Triangle; static normal(a: Vector3, b: Vector3, c: Vector3, optionalTarget?: Vector3): Vector3; static barycoordFromPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3, optionalTarget: Vector3): Vector3; static containsPoint(point: Vector3, a: Vector3, b: Vector3, c: Vector3): boolean; } - /** * ( interface Vector<T> ) * @@ -3523,12 +3996,16 @@ declare module THREE { x: number; y: number; + width: number; + height: number; /** * Sets value of this vector. */ set(x: number, y: number): Vector2; + setScalar(scalar: number): Vector2; + /** * Sets X component of this vector. */ @@ -3548,7 +4025,10 @@ declare module THREE { * Gets a component of this vector. */ getComponent(index: number): number; - + /** + * Clones this vector. + */ + clone(): Vector2; /** * Copies value of v to this vector. */ @@ -3564,8 +4044,7 @@ declare module THREE { */ addScalar(s: number): Vector2; addVectors(a: Vector2, b: Vector2): Vector2; - addScaledVector(v: Vector2, s: number): Vector2; - + addScaledVector( v: Vector2, s: number ): Vector2; /** * Subtracts v from this vector. */ @@ -3580,7 +4059,7 @@ declare module THREE { /** * Multiplies this vector by scalar s. */ - multiplyScalar(s: number): Vector2; + multiplyScalar(scalar: number): Vector2; divide(v: Vector2): Vector2; /** @@ -3619,10 +4098,6 @@ declare module THREE { * Computes length of this vector. */ length(): number; - - /** - * Computes Manhattan length of this vector. - */ lengthManhattan(): number; /** @@ -3630,6 +4105,11 @@ declare module THREE { */ normalize(): Vector2; + /** + * computes the angle in radians with respect to the positive x-axis + */ + angle(): number; + /** * Computes distance of this vector to v. */ @@ -3639,11 +4119,12 @@ declare module THREE { * Computes squared distance of this vector to v. */ distanceToSquared(v: Vector2): number; + distanceToManhattan(v: Vector2): number; /** * Normalizes this vector and multiplies it by l. */ - setLength(l: number): Vector2; + setLength(length: number): Vector2; lerp(v: Vector2, alpha: number): Vector2; @@ -3660,12 +4141,7 @@ declare module THREE { fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector2; - rotateAround(center: Vector2, angle: number): Vector2; - - /** - * Clones this vector. - */ - clone(): Vector2; + rotateAround( center: Vector2, angle: number ): Vector2; } /** @@ -3682,7 +4158,6 @@ declare module THREE { * ( class Vector3 implements Vector ) */ export class Vector3 implements Vector { - constructor(x?: number, y?: number, z?: number); x: number; @@ -3694,6 +4169,11 @@ declare module THREE { */ set(x: number, y: number, z: number): Vector3; + /** + * Sets all values of this vector. + */ + setScalar(scalar: number): Vector3; + /** * Sets x value of this vector. */ @@ -3711,7 +4191,10 @@ declare module THREE { setComponent(index: number, value: number): void; getComponent(index: number): number; - + /** + * Clones this vector. + */ + clone(): Vector3; /** * Copies value of v to this vector. */ @@ -3835,10 +4318,12 @@ declare module THREE { * Computes squared distance of this vector to v. */ distanceToSquared(v: Vector3): number; + distanceToManhattan(v: Vector3): number; + setFromSpherical(s: Spherical): Matrix3; setFromMatrixPosition(m: Matrix4): Vector3; setFromMatrixScale(m: Matrix4): Vector3; - setFromMatrixColumn(index: number, matrix: Matrix4): Vector3; + setFromMatrixColumn(matrix: Matrix4, index: number): Vector3; /** * Checks for strict equality of this vector and v. @@ -3846,17 +4331,17 @@ declare module THREE { equals(v: Vector3): boolean; fromArray(xyz: number[], offset?: number): Vector3; - toArray(xyz?: number[], offset?: number): number[]; - fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector3; - /** - * Clones this vector. - */ - clone(): Vector3; + // deprecated + getPositionFromMatrix(m: Matrix4): Vector3; + getScaleFromMatrix(m: Matrix4): Vector3; + getColumnFromMatrix(index: number, matrix: Matrix4): Vector3; } + export class Vertex extends Vector3 {} // deprecated + /** * 4D vector. * @@ -3864,6 +4349,7 @@ declare module THREE { */ export class Vector4 implements Vector { constructor(x?: number, y?: number, z?: number, w?: number); + x: number; y: number; z: number; @@ -3874,6 +4360,11 @@ declare module THREE { */ set(x: number, y: number, z: number, w: number): Vector4; + /** + * Sets all values of this vector. + */ + setScalar(scalar: number): Vector4; + /** * Sets X component of this vector. */ @@ -3896,7 +4387,10 @@ declare module THREE { setComponent(index: number, value: number): void; getComponent(index: number): number; - + /** + * Clones this vector. + */ + clone(): Vector4; /** * Copies value of v to this vector. */ @@ -3912,8 +4406,7 @@ declare module THREE { * Sets this vector to a + b. */ addVectors(a: Vector4, b: Vector4): Vector4; - addScaledVector(v: Vector4, s: number): Vector4; - + addScaledVector( v: Vector4, s: number ): Vector4; /** * Subtracts v from this vector. */ @@ -3987,7 +4480,7 @@ declare module THREE { /** * Normalizes this vector and multiplies it by l. */ - setLength(l: number): Vector4; + setLength(length: number): Vector4; /** * Linearly interpolate between this vector and v with alpha factor. @@ -4006,11 +4499,41 @@ declare module THREE { toArray(xyzw?: number[], offset?: number): number[]; fromAttribute( attribute: BufferAttribute, index: number, offset?: number): Vector4; + } - /** - * Clones this vector. - */ - clone(): Vector4; + export abstract class Interpolant { + constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any); + + parameterPositions: any; + samplesValues: any; + valueSize: number; + resultBuffer: any; + + evaluate(time: number): any; + } + + export class CubicInterpolant extends Interpolant { + constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any); + + interpolate_(i1: number, t0: number, t: number, t1: number): any; + } + + export class DiscreteInterpolant extends Interpolant { + constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any); + + interpolate_(i1: number, t0: number, t: number, t1: number): any; + } + + export class LinearInterpolant extends Interpolant { + constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any); + + interpolate_(i1: number, t0: number, t: number, t1: number): any; + } + + export class QuaternionLinearInterpolant extends Interpolant { + constructor(parameterPositions: any, samplesValues: any, sampleSize: number, resultBuffer?: any); + + interpolate_(i1: number, t0: number, t: number, t1: number): any; } // Objects ////////////////////////////////////////////////////////////////////////////////// @@ -4019,12 +4542,32 @@ declare module THREE { constructor(skin: SkinnedMesh); skin: SkinnedMesh; + + clone(): Bone; + copy(source: Bone): Bone; } export class Group extends Object3D { constructor(); } + export class LOD extends Object3D { + constructor(); + + levels: any[]; + + addLevel(object: Object3D, distance?: number): void; + getObjectForDistance(distance: number): Object3D; + raycast(raycaster: Raycaster, intersects: any): void; + update(camera: Camera): void; + clone(): LOD; + copy(source: LOD): LOD; + toJSON(meta: any): any; + + // deprecated + objects: any[]; + } + export interface LensFlareProperty { texture: Texture; // Texture size: number; // size in pixels (-1 = use texture.width) @@ -4046,60 +4589,43 @@ declare module THREE { positionScreen: Vector3; customUpdateCallback: (object: LensFlare) => void; + add(object: Object3D): void; add(texture: Texture, size?: number, distance?: number, blending?: Blending, color?: Color): void; - add(obj: Object3D): void; - - updateLensFlares(): void; + clone(): LensFlare; + copy(source: LensFlare): LensFlare; } export class Line extends Object3D { - constructor(geometry?: Geometry, material?: LineDashedMaterial, mode?: number); - constructor(geometry?: Geometry, material?: LineBasicMaterial, mode?: number); - constructor(geometry?: Geometry, material?: ShaderMaterial, mode?: number); - constructor(geometry?: BufferGeometry, material?: LineDashedMaterial, mode?: number); - constructor(geometry?: BufferGeometry, material?: LineBasicMaterial, mode?: number); - constructor(geometry?: BufferGeometry, material?: ShaderMaterial, mode?: number); + constructor( + geometry?: Geometry | BufferGeometry, + material?: LineDashedMaterial | LineBasicMaterial | ShaderMaterial, + mode?: number + ); geometry: Geometry|BufferGeometry; material: Material; // LineDashedMaterial or LineBasicMaterial or ShaderMaterial raycast(raycaster: Raycaster, intersects: any): void; - clone(object?: Line): Line; + clone(): Line; + copy(source: Line): Line; } - export class LineSegments extends Line { - constructor(geometry?: Geometry, material?: LineDashedMaterial); - constructor(geometry?: Geometry, material?: LineBasicMaterial); - constructor(geometry?: Geometry, material?: ShaderMaterial); - constructor(geometry?: BufferGeometry, material?: LineDashedMaterial); - constructor(geometry?: BufferGeometry, material?: LineBasicMaterial); - constructor(geometry?: BufferGeometry, material?: ShaderMaterial); + export const LineStrip: number; // deprecated + export const LinePieces: number; // deprecated - geometry: Geometry|BufferGeometry; - material: Material; // LineDashedMaterial or LineBasicMaterial or ShaderMaterial + export class LineSegments extends Line { + constructor( + geometry?: Geometry | BufferGeometry, + material?: LineDashedMaterial | LineBasicMaterial | ShaderMaterial, + mode?: number + ); - raycast(raycaster: Raycaster, intersects: any): void; - clone(object?: LineSegments): LineSegments; + clone(): LineSegments; + copy(source: LineSegments): LineSegments; } - enum LineMode{} - var LineStrip: LineMode; - var LinePieces: LineMode; - - export class LOD extends Object3D { - constructor(); - - levels: any[]; - /** Deprecated, use levels instead */ - objects: any[]; - - addLevel(object: Object3D, distance?: number): void; - getObjectForDistance(distance: number): Object3D; - raycast(raycaster: Raycaster, intersects: any): void; - update(camera: Camera): void; - clone(object?: LOD): LOD; - } + enum LineMode {} export class Mesh extends Object3D { constructor(geometry?: Geometry, material?: Material); @@ -4107,43 +4633,14 @@ declare module THREE { geometry: Geometry|BufferGeometry; material: Material; + drawMode: TrianglesDrawModes; + setDrawMode(drawMode: TrianglesDrawModes): void; updateMorphTargets(): void; getMorphTargetIndexByName(name: string): number; raycast(raycaster: Raycaster, intersects: any): void; - clone(object?: Mesh): Mesh; - } - - export class MorphAnimMesh extends Mesh { - constructor(geometry?: Geometry, material?: MeshBasicMaterial); - constructor(geometry?: Geometry, material?: MeshDepthMaterial); - constructor(geometry?: Geometry, material?: MeshFaceMaterial); - constructor(geometry?: Geometry, material?: MeshLambertMaterial); - constructor(geometry?: Geometry, material?: MeshNormalMaterial); - constructor(geometry?: Geometry, material?: MeshPhongMaterial); - constructor(geometry?: Geometry, material?: ShaderMaterial); - - duration: number; // milliseconds - mirroredLoop: boolean; - time: number; - lastKeyframe: number; - currentKeyframe: number; - direction: number; - directionBackwards: boolean; - - startKeyframe: number; - endKeyframe: number; - length: number; - - setFrameRange(start: number, end: number): void; - setDirectionForward(): void; - setDirectionBackward(): void; - parseAnimations(): void; - setAnimationLabel(label: string, start: number, end: number): void; - playAnimation(label: string, fps: number): void; - updateAnimation(delta: number): void; - interpolateTargets( a: number, b: number, t: number ): void; - clone(object?: MorphAnimMesh): MorphAnimMesh; + clone(): Mesh; + copy(source: Mesh): Mesh; } /** @@ -4151,31 +4648,35 @@ declare module THREE { * * @see src/objects/ParticleSystem.js */ - export class PointCloud extends Object3D { + export class Points extends Object3D { /** - * @param geometry An instance of Geometry. + * @param geometry An instance of Geometry or BufferGeometry. * @param material An instance of Material (optional). */ - constructor(geometry: Geometry, material?: PointCloudMaterial); - constructor(geometry: Geometry, material?: ShaderMaterial); - constructor(geometry: BufferGeometry, material?: PointCloudMaterial); - constructor(geometry: BufferGeometry, material?: ShaderMaterial); + constructor( + geometry?: Geometry | BufferGeometry, + material?: Material + ); /** - * An instance of Geometry, where each vertex designates the position of a particle in the system. + * An instance of Geometry or BufferGeometry, where each vertex designates the position of a particle in the system. */ - geometry: Geometry; + geometry: Geometry | BufferGeometry; /** - * An instance of Material, defining the object's appearance. Default is a ParticleBasicMaterial with randomised colour. + * An instance of Material, defining the object's appearance. Default is a PointsMaterial with randomised colour. */ material: Material; raycast(raycaster: Raycaster, intersects: any): void; - clone(object?: PointCloud): PointCloud; + clone(): Points; + copy(source: Points): Points; } + export class PointCloud extends Points {} // deprecated + export class ParticleSystem extends Points {} // deprecated + export class Skeleton { constructor(bones: Bone[], boneInverses?: Matrix4[], useVertexTexture?: boolean); @@ -4197,7 +4698,7 @@ declare module THREE { export class SkinnedMesh extends Mesh { constructor(geometry?: Geometry|BufferGeometry, material?: MeshBasicMaterial, useVertexTexture?: boolean); constructor(geometry?: Geometry|BufferGeometry, material?: MeshDepthMaterial, useVertexTexture?: boolean); - constructor(geometry?: Geometry|BufferGeometry, material?: MeshFaceMaterial, useVertexTexture?: boolean); + constructor(geometry?: Geometry|BufferGeometry, material?: MultiMaterial, useVertexTexture?: boolean); constructor(geometry?: Geometry|BufferGeometry, material?: MeshLambertMaterial, useVertexTexture?: boolean); constructor(geometry?: Geometry|BufferGeometry, material?: MeshNormalMaterial, useVertexTexture?: boolean); constructor(geometry?: Geometry|BufferGeometry, material?: MeshPhongMaterial, useVertexTexture?: boolean); @@ -4206,14 +4707,14 @@ declare module THREE { bindMode: string; bindMatrix: Matrix4; bindMatrixInverse: Matrix4; + skeleton: Skeleton; bind( skeleton: Skeleton, bindMatrix?: Matrix4 ): void; pose(): void; normalizeSkinWeights(): void; updateMatrixWorld(force?: boolean): void; - clone(object?: SkinnedMesh): SkinnedMesh; - - skeleton: Skeleton; + clone(): SkinnedMesh; + copy(source: SkinnedMesh): SkinnedMesh; } export class Sprite extends Object3D { @@ -4223,16 +4724,20 @@ declare module THREE { material: SpriteMaterial; raycast(raycaster: Raycaster, intersects: any): void; - clone(object?: Sprite): Sprite; + clone(): Sprite; + copy(source: Sprite): Sprite; } + export class Particle extends Sprite {} // deprecated + // Renderers ////////////////////////////////////////////////////////////////////////////////// export interface Renderer { - render(scene: Scene, camera: Camera): void; - setSize(width:number, height:number, updateStyle?:boolean): void; domElement: HTMLCanvasElement; + + render(scene: Scene, camera: Camera): void; + setSize(width: number, height: number, updateStyle?: boolean): void; } export interface WebGLRendererParameters { @@ -4282,6 +4787,11 @@ declare module THREE { clearAlpha?: number; devicePixelRatio?: number; + + /** + * default is false. + */ + logarithmicDepthBuffer?: boolean; } @@ -4333,9 +4843,10 @@ declare module THREE { */ sortObjects: boolean; - extensions: WebGLExtensions; + clippingPlanes: any[]; + localClippingEnabled: boolean; - gammaFactor: number; + extensions: WebGLExtensions; /** * Default is false. @@ -4347,21 +4858,10 @@ declare module THREE { */ gammaOutput: boolean; - /** - * Default is false. - */ - shadowMapEnabled: boolean; - - /** - * Defines shadow map type (unfiltered, percentage close filtering, percentage close filtering with bilinear filtering in shader) - * Options are THREE.BasicShadowMap, THREE.PCFShadowMap, THREE.PCFSoftShadowMap. Default is THREE.PCFShadowMap. - */ - shadowMapType: ShadowMapType; - - /** - * Default is true - */ - shadowMapCullFace: CullFace; + physicallyCorrectLights: boolean; + toneMapping: ToneMapping; + toneMappingExposure: number; + toneMappingWhitePoint: number; /** * Default is false. @@ -4378,17 +4878,11 @@ declare module THREE { */ maxMorphNormals: number; - /** - * Default is true. - */ - autoScaleCubemaps: boolean; - /** * An object with a series of statistical information about the graphics board memory and the rendering process. Useful for debugging or just for the sake of curiosity. The object contains the following fields: */ info: { memory: { - programs: number; geometries: number; textures: number; }; @@ -4398,32 +4892,30 @@ declare module THREE { faces: number; points: number; }; + programs: number; }; shadowMap: WebGLShadowMap; + pixelRation: number; + + capabilities: WebGLCapabilities; + properties: WebGLProperties; + state: WebGLState; + allocTextureUnit: any; + /** * Return the WebGL context. */ getContext(): WebGLRenderingContext; - + getContextAttributes(): any; forceContextLoss(): void; - capabilities: WebGLCapabilities; - - /** Deprecated, use capabilities instead */ - supportsVertexTextures(): boolean; - supportsFloatTextures(): boolean; - supportsStandardDerivatives(): boolean; - supportsCompressedTextureS3TC(): boolean; - supportsCompressedTexturePVRTC(): boolean; - supportsBlendMinMax(): boolean; - getPrecision(): string; - getMaxAnisotropy(): number; + getPrecision(): string; getPixelRatio(): number; setPixelRatio(value: number): void; - + getSize(): { width: number; height: number; }; /** @@ -4444,7 +4936,12 @@ declare module THREE { /** * Enable the scissor test. When this is enabled, only the pixels within the defined scissor area will be affected by further renderer actions. */ - enableScissorTest(enable: boolean): void; + setScissorTest(enable: boolean): void; + + /** + * Returns a THREE.Color instance with the current clear color. + */ + getClearColor(): Color; /** * Sets the clear color, using color for the color and alpha for the opacity. @@ -4453,39 +4950,23 @@ declare module THREE { setClearColor(color: string, alpha?: number): void; setClearColor(color: number, alpha?: number): void; - setClearAlpha(alpha: number): void; - - /** - * Sets the clear color, using hex for the color and alpha for the opacity. - * - * @example - * // Creates a renderer with black background - * var renderer = new THREE.WebGLRenderer(); - * renderer.setSize(200, 100); - * renderer.setClearColorHex(0x000000, 1); - */ - setClearColorHex(hex: number, alpha: number): void; - - /** - * Returns a THREE.Color instance with the current clear color. - */ - getClearColor(): Color; - /** * Returns a float with the current clear alpha. Ranges from 0 to 1. */ getClearAlpha(): number; + setClearAlpha(alpha: number): void; + /** * Tells the renderer to clear its color, depth or stencil drawing buffer(s). - * If no parameters are passed, no buffer will be cleared. + * Arguments default to true */ clear(color?: boolean, depth?: boolean, stencil?: boolean): void; clearColor(): void; clearDepth(): void; clearStencil(): void; - clearTarget(renderTarget:WebGLRenderTarget, color: boolean, depth: boolean, stencil: boolean): void; + clearTarget(renderTarget: WebGLRenderTarget, color: boolean, depth: boolean, stencil: boolean): void; resetGLState(): void; dispose(): void; @@ -4495,13 +4976,9 @@ declare module THREE { * @param scene an instance of Scene * @param camera — an instance of Camera */ - updateShadowMap(scene: Scene, camera: Camera): void; - renderBufferImmediate(object: Object3D, program: Object, material: Material): void; - renderBufferDirect(camera: Camera, lights: Light[], fog: Fog, material: Material, geometryGroup: any, object: Object3D): void; - - renderBuffer(camera: Camera, lights: Light[], fog: Fog, material: Material, geometryGroup: any, object: Object3D): void; + renderBufferDirect(camera: Camera, fog: Fog, material: Material, geometryGroup: any, object: Object3D): void; /** * Render a scene using a camera. @@ -4509,7 +4986,6 @@ declare module THREE { * If forceClear is true, the canvas will be cleared before rendering, even if the renderer's autoClear property is false. */ render(scene: Scene, camera: Camera, renderTarget?: RenderTarget, forceClear?: boolean): void; - renderImmediateObject(camera: Camera, lights: Light[], fog: Fog, material: Material, object: Object3D): void; /** * Used for setting the gl frontFace, cullFace states in the GPU, thus enabling/disabling face culling when rendering. @@ -4518,200 +4994,429 @@ declare module THREE { * @param frontFace "ccw" or "cw */ setFaceCulling(cullFace?: CullFace, frontFace?: FrontFaceDirection): void; - setMaterialFaces(material: Material): void; - setDepthTest(depthTest: boolean): void; - setDepthWrite(depthWrite: boolean): void; - setBlending(blending: Blending, blendEquation: BlendingEquation, blendSrc: BlendingSrcFactor, blendDst: BlendingDstFactor): void; - uploadTexture(texture: Texture): void; - setTexture(texture: Texture, slot: number): void; + setTexture(texture: Texture, slot: number): void; // deprecated + setTexture2D(texture: Texture, slot: number): void; + setTextureCube(texture: Texture, slot: number): void; + getCurrentRenderTarget(): RenderTarget; setRenderTarget(renderTarget: RenderTarget): void; readRenderTargetPixels( renderTarget: RenderTarget, x: number, y: number, width: number, height: number, buffer: any ): void; + + // deprecated + gammaFactor: number; + shadowMapEnabled: boolean; + shadowMapType: ShadowMapType; + shadowMapCullFace: CullFace; + + supportsFloatTextures(): any; + supportsHalfFloatTextures(): any; + supportsStandardDerivatives(): any; + supportsCompressedTextureS3TC(): any; + supportsCompressedTexturePVRTC(): any; + supportsBlendMinMax(): any; + supportsVertexTextures(): any; + supportsInstancedArrays(): any; + enableScissorTest(boolean: any): any; } - - export interface WebGLCapabilities { - getMaxPrecision(precision: string): string; - precision: string; - logarithmicDepthBuffer: boolean; - maxTextures: number; - maxVertexTextures: number; - maxTextureSize: number; - maxCubemapSize: number; - maxAttributes: number; - maxVertexUniforms: number; - maxVaryings: number; - maxFragmentUniforms: number; - vertexTextures: boolean; - floatFragmentTextures: boolean; - floatVertexTextures: boolean; - } - - export interface RenderTarget { - } + + export interface RenderTarget {} // not defined in the code, used in LightShadow and WebGRenderer classes export interface WebGLRenderTargetOptions { wrapS?: Wrapping; wrapT?: Wrapping; magFilter?: TextureFilter; minFilter?: TextureFilter; - anisotropy?: number; // 1; format?: number; // RGBAFormat; type?: TextureDataType; // UnsignedByteType; + anisotropy?: number; // 1; depthBuffer?: boolean; // true; stencilBuffer?: boolean; // true; } - export class WebGLRenderTarget implements RenderTarget { + export class WebGLRenderTarget extends EventDispatcher { constructor(width: number, height: number, options?: WebGLRenderTargetOptions); + uuid: string; width: number; height: number; - wrapS: Wrapping; - wrapT: Wrapping; - magFilter: TextureFilter; - minFilter: TextureFilter; - anisotropy: number; - offset: Vector2; - repeat: Vector2; - format: number; - type: number; + scissor: Vector4; + scissorTest: boolean; + viewpport: Vector4; + texture: Texture; depthBuffer: boolean; stencilBuffer: boolean; - generateMipmaps: boolean; - shareDepthFrom: any; + depthTexture: Texture; + wrapS: any; // deprecated, use texture.wrapS + wrapT: any; // deprecated, use texture.wrapT + magFilter: any; // deprecated, use texture.magFilter + minFilter: any; // deprecated, use texture.minFilter + anisotropy: any; // deprecated, use texture.anisotropy + offset: any; // deprecated, use texture.offset + repeat: any; // deprecated, use texture.repeat + format: any; // deprecated, use texture.format + type: any; // deprecated, use texture.type + generateMipmaps: any; // deprecated, use texture.generateMipmaps setSize(width: number, height: number): void; clone(): WebGLRenderTarget; + copy(source: WebGLRenderTarget): WebGLRenderTarget; dispose(): void; - - - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; } export class WebGLRenderTargetCube extends WebGLRenderTarget { constructor(width: number, height: number, options?: WebGLRenderTargetOptions); activeCubeFace: number; // PX 0, NX 1, PY 2, NY 3, PZ 4, NZ 5 + activeMipMapLevel: number; } // Renderers / Shaders ///////////////////////////////////////////////////////////////////// - export interface ShaderChunk { + export let ShaderChunk: { [name: string]: string; - common: string; alphamap_fragment: string; alphamap_pars_fragment: string; alphatest_fragment: string; + aomap_fragment: string; + aomap_pars_fragment: string; + begin_vertex: string; + beginnormal_vertex: string; + bsdfs: string; bumpmap_pars_fragment: string; + clipping_planes_fragment: string; + clipping_planes_pars_fragment: string; + clipping_planes_pars_vertex: string; + clipping_planes_vertex: string; color_fragment: string; color_pars_fragment: string; color_pars_vertex: string; color_vertex: string; - default_vertex: string; + common: string; + cube_frag: string; + cube_vert: string; + cube_uv_reflection_fragment: string; defaultnormal_vertex: string; + depth_frag: string; + depth_vert: string; + distanceRGBA_frag: string; + distanceRGBA_vert: string; + displacementmap_vertex: string; + displacementmap_pars_vertex: string; + emissivemap_fragment: string; + emissivemap_pars_fragment: string; + encodings_pars_fragment: string; + encodings_fragment: string; envmap_fragment: string; envmap_pars_fragment: string; envmap_pars_vertex: string; envmap_vertex: string; + equirect_frag: string; + equirect_vert: string; fog_fragment: string; fog_pars_fragment: string; - + linedashed_frag: string; + linedashed_vert: string; lightmap_fragment: string; lightmap_pars_fragment: string; - lightmap_pars_vertex: string; - lightmap_vertex: string; - lights_lambert_pars_vertex: string; lights_lambert_vertex: string; + lights_pars: string; lights_phong_fragment: string; lights_phong_pars_fragment: string; - lights_phong_pars_vertex: string; - lights_phong_vertex: string; - linear_to_gamma_fragment: string; + lights_physical_fragment: string; + lights_physical_pars_fragment: string; + lights_template: string; logdepthbuf_fragment: string; logdepthbuf_pars_fragment: string; logdepthbuf_pars_vertex: string; logdepthbuf_vertex: string; map_fragment: string; map_pars_fragment: string; - map_pars_vertex: string; map_particle_fragment: string; map_particle_pars_fragment: string; - map_vertex: string; + meshbasic_frag: string; + meshbasic_vert: string; + meshlambert_frag: string; + meshlambert_vert: string; + meshphong_frag: string; + meshphong_vert: string; + meshphysical_frag: string; + meshphysical_vert: string; + metalnessmap_fragment: string; + metalnessmap_pars_fragment: string; morphnormal_vertex: string; morphtarget_pars_vertex: string; morphtarget_vertex: string; + normal_flip: string; + normal_frag: string; + normal_fragment: string; + normal_vert: string; normalmap_pars_fragment: string; - shadowmap_fragment: string; + packing: string; + points_frag: string; + points_vert: string; + shadow_frag: string; + shadow_vert: string; + + premultiplied_alpha_fragment: string; + project_vertex: string; + roughnessmap_fragment: string; + roughnessmap_pars_fragment: string; shadowmap_pars_fragment: string; shadowmap_pars_vertex: string; shadowmap_vertex: string; + shadowmask_pars_fragment: string; skinbase_vertex: string; skinning_pars_vertex: string; skinning_vertex: string; skinnormal_vertex: string; specularmap_fragment: string; specularmap_pars_fragment: string; + tonemapping_fragment: string; + tonemapping_pars_fragment: string; + uv2_pars_fragment: string; + uv2_pars_vertex: string; + uv2_vertex: string; + uv_pars_fragment: string; + uv_pars_vertex: string; + uv_vertex: string; worldpos_vertex: string; - } - - export var ShaderChunk: ShaderChunk; + }; export interface Shader { - uniforms: any; + uniforms: IUniform; vertexShader: string; fragmentShader: string; } - export var ShaderLib: { + export let ShaderLib: { [name: string]: Shader; basic: Shader; lambert: Shader; phong: Shader; - particle_basic: Shader; + standard: Shader; + points: Shader; dashed: Shader; depth: Shader; normal: Shader; - normalmap: Shader; cube: Shader; equirect: Shader; depthRGBA: Shader; + distanceRGBA: Shader; + physical: Shader; }; - export var UniformsLib: { - common: any; - bump: any; - normalmap: any; - fog: any; - lights: any; - particle: any; - shadowmap: any; + export interface IUniform { + value: any; + } + + export let UniformsLib: { + common: { + diffuse: IUniform; + opacity: IUniform; + map: IUniform; + offsetRepeat: IUniform; + specularMap: IUniform; + alphaMap: IUniform; + envMap: IUniform; + flipEnvMap: IUniform; + reflectivity: IUniform; + refractionRation: IUniform; + }; + aomap: { + aoMap: IUniform; + aoMapIntensity: IUniform; + }; + lightmap: { + lightMap: IUniform; + lightMapIntensity: IUniform; + }; + emissivemap: { emissiveMap: IUniform }; + bumpmap: { + bumpMap: IUniform; + bumpScale: IUniform; + }; + normalmap: { + normalMap: IUniform; + normalScale: IUniform; + }; + displacementmap: { + displacementMap: IUniform; + displacementScale: IUniform; + displacementBias: IUniform; + }; + roughnessmap: { roughnessMap: IUniform }; + metalnessmap: { metalnessMap: IUniform }; + fog: { + fogDensity: IUniform; + fogNear: IUniform; + fogFar: IUniform; + fogColor: IUniform; + }; + lights: { + ambientLightColor: IUniform + directionalLights: { + value: any[]; + properties: { + direction: {}; + color: {}; + shadow: {}; + shadowBias: {}; + shadowRadius: {}; + shadowMapSize: {}; + }; + }; + directionalShadowMap: IUniform; + directionalShadowMatrix: IUniform; + spotLights: { + value: any[]; + properties: { + color: {}; + position: {}; + direction: {}; + distance: {}; + coneCos: {}; + penumbraCos: {}; + decay: {}; + shadow: {}; + shadowBias: {}; + shadowRadius: {}; + shadowMapSize: {}; + }; + }; + spotShadowMap: IUniform; + spotShadowMatrix: IUniform; + pointLights: { + value: any[]; + properties: { + color: {}; + position: {}; + decay: {}; + distance: {}; + shadow: {}; + shadowBias: {}; + shadowRadius: {}; + shadowMapSize: {}; + }; + }; + pointShadowMap: IUniform; + pointShadowMatrix: IUniform; + hemisphereLigtts: { + value: any[]; + properties: { + direction: {}; + skycolor: {}; + groundColor: {}; + }; + }; + }; + points: { + diffuse: IUniform; + opacity: IUniform; + size: IUniform; + scale: IUniform; + map: IUniform; + offsetRepeat: IUniform; + }; }; - export var UniformsUtils: { - merge(uniforms: any[]): any; - clone(uniforms_src: any): any; - }; + export namespace UniformsUtils { + export function merge(uniforms: any[]): any; + export function clone(uniforms_src: any): any; + } + + export class Uniform { + constructor(value: any); + constructor(type: string, value: any); // deprecated + + type: string; // deprecated + value: any; + dynamic: boolean; + onUpdateCallback: Function; + + onUpdate(callback: Function): Uniform; + } // Renderers / WebGL ///////////////////////////////////////////////////////////////////// + export class WebGLBufferRenderer { + constructor(_gl: WebGLRenderingContext, extensions: any, _infoRender: any); + + setMode(value: any): void; + render(start: any, count: number): void; + renderInstances(geometry: any): void; + } + + export class WebGLClipping { + uniform: { value: any, needsUpdate: boolean }; + numPlanes: number; + + init(planes: any[], enableLocalClipping: boolean, camera: Camera): boolean; + beginShadows(): void; + endShadows(): void; + setState(planes: any[], clipShadows: boolean, camera: Camera, cache: boolean, fromCache: boolean): void; + } + + export interface WebGLCapabilitiesParameters { + precision?: any; + logarithmicDepthBuffer?: any; + } + + export class WebGLCapabilities { + constructor(gl: WebGLRenderingContext, extensions: any, parameters: WebGLCapabilitiesParameters); + + precision: any; + logarithmicDepthBuffer: any; + maxTextures: any; + maxVertexTextures: any; + maxTextureSize: any; + maxCubemapSize: any; + maxAttributes: any; + maxVertexUniforms: any; + maxVaryings: any; + maxFragmentUniforms: any; + vertexTextures: any; + floatFragmentTextures: any; + floatVertexTextures: any; + + getMaxAnisotropy(): number; + getMaxPrecision(precision: string): string; + } + export class WebGLExtensions { constructor(gl: WebGLRenderingContext); get(name: string): any; } + export class WebGLGeometries { + constructor(gl: WebGLRenderingContext, extensions: any, _infoRender: any); + + get(object: any): any; + } + + export class WebGLLights { + constructor(gl: WebGLRenderingContext, properties: any, info: any); + + get(light: any): any; + } + + export class WebGLIndexedBufferRenderer { + constructor(gl: WebGLRenderingContext, properties: any, info: any); + + setMode(value: any): void; + setIndex(index: any): void; + render(start: any, count: number): void; + renderInstances(geometry: any, start: any, count: number): void; + } + + export class WebGLObjects { + constructor(gl: WebGLRenderingContext, properties: any, info: any); + + getAttributeBuffer(attribute: any): any; + getWireframeAttribute(geometry: any): any; + update(object: any): void; + } + export class WebGLProgram { constructor(renderer: WebGLRenderer, code: string, material: ShaderMaterial, parameters: WebGLRendererParameters); - - getUniforms(): any; - getAttributes(): any; - - /** Deprecated, use getUniforms */ - uniforms: any; - /** Deprecated, use getAttributes */ - attributes: any; id: number; code: string; @@ -4719,94 +5424,205 @@ declare module THREE { program: any; vertexShader: WebGLShader; fragmentShader: WebGLShader; + uniforms: any; // deprecated, use getUniforms() + attributes: any; // deprecated, use getAttributes() + + getUniforms(): WebGLUniforms; + getAttributes(): any; + destroy(): void; + } + + export class WebGLPrograms { + constructor(renderer: WebGLRenderer, capabilities: any); + + programs: any[]; + + getParameters(material: ShaderMaterial, lights: any, fog: any, nClipPlanes: number, object: any): any; + getProgramCode(material: ShaderMaterial, parameters: any): string; + acquireProgram(material: ShaderMaterial, parameters: any, code: string): WebGLProgram; + releaseProgram(program: WebGLProgram): void; + } + + export class WebGLTextures { + constructor(gl: any, extensions: any, state: any, properties: any, capabilities: any, paramThreeToGL: Function, info: any); + + setTexture2D(texture: any, slot: number): void; + setTextureCube(texture: any, slot: number): void; + setTextureCubeDynamic(texture: any, slot: number): void; + setupRenderTarget(renderTarget: any): void; + updateRenderTargetMipmap(renderTarget: any): void; + } + + export class WebGLUniforms { + constructor(gl: any, program: WebGLProgram, renderer: WebGLRenderer); + + renderer: WebGLRenderer; + + setValue(gl: any, value: any, renderer?: any): void; + set(gl: any, object: any, name: string): void; + setOptional(gl: any, object: any, name: string): void; + + static upload(gl: any, seq: any, values: any[], renderer: any): void; + static seqWithValue(seq: any, values: any[]): any[]; + static splitDynamic(seq: any, values: any[]): any[]; + static evalDynamic(seq: any, values: any[], object: any, camera: any): any[]; + } + + export class WebGLProperties { + constructor(); + + get(object: any): any; + delete(object: any): void; + clear(): void; } export class WebGLShader { - constructor(gl: WebGLRenderingContext, type: string, string: string); + constructor(gl: any, type: string, string: string); } - interface WebGLStateInstance { - new(gl: WebGLRenderingContext, paramThreeToGL: Function): void; + export class WebGLShadowMap { + constructor(_renderer: Renderer, _lights: any[], _objects: any[], capabilities: any); + + enabled: boolean; + autoUpdate: boolean; + needsUpdate: boolean; + type: ShadowMapType; + renderReverseSided: boolean; + renderSingleSided: boolean; + + render(scene: Scene, camera: Camera): void; + + // deprecated + cullFace: any; + } + + export class WebGLState { + constructor(gl: any, extensions: any, paramThreeToGL: Function); + + buffers: { + color: WebGLColorBuffer, + depth: WebGLDepthBuffer, + stencil: WebGLStencilBuffer, + }; + + init(): void; initAttributes(): void; enableAttribute(attribute: string): void; + enableAttributeAndDivisor(attribute: string, meshPerAttribute: any, extension: any): void; disableUnusedAttributes(): void; + enable(id: string): void; + disable(id: string): void; + getCompressedTextureFormats(): any[]; setBlending(blending: number, blendEquation: number, blendSrc: number, blendDst: number, blendEquationAlpha: number, blendSrcAlpha: number, blendDstAlpha: number): void; + setColorWrite(colorWrite: number): void; setDepthTest(depthTest: number): void; setDepthWrite(depthWrite: number): void; - setColorWrite(colorWrite: number): void; - setDoubleSided(doubleSided: number): void; + setDepthFunc(depthFunc: Function): void; + setStencilTest(stencilTest: boolean): void; + setStencilWrite(stencilWrite: any): void; + setStencilFunc(stencilFunc: Function, stencilRef: any, stencilMask: number): void; + setStencilOp(stencilFail: any, stencilZFail: any, stencilZPass: any): void; setFlipSided(flipSided: number): void; + setCullFace(cullFace: CullFace): void; setLineWidth(width: number): void; setPolygonOffset(polygonoffset: number, factor: number, units: number): void; + setScissorTest(scissorTest: boolean): void; + getScissorTest(): boolean; + activeTexture(webglSlot: any): void; + bindTexture(webglType: any, webglTexture: any): void; + compressedTexImage2D(): void; + texImage2D(): void; + clearColor(r: number, g: number, b: number, a: number): void; + clearDepth(depth: number): void; + clearStencil(stencil: any): void; + scissor(scissor: any): void; + viewport(viewport: any): void; reset(): void; } - interface WebGLStateStatic { - (gl: WebGLRenderingContext, paramThreeToGL: Function): WebGLStateInstance; - } - export var WebGLState: WebGLStateStatic; + export class WebGLColorBuffer { + constructor(gl: any, state: any); - interface WebGLTexturesInstance{ - new (webgglcontext: any): WebGLTexturesInstance; - - get(texture: Texture): any; // it will return result of gl.createTexture(). - create(texture: Texture): any; // it will return result of gl.createTexture(). - delete(texture: Texture): void; - } - interface WebGLTexturesStatic{ - (webgglcontext: any): WebGLTexturesInstance; + setMask(colorMask: number): void; + setLocked(lock: boolean): void; + setClear(r: number, g: number, b: number, a: number): void; + reset(): void; } - export var WebGLTextures: WebGLTexturesStatic; + export class WebGLDepthBuffer { + constructor(gl: any, state: any); - // Renderers / WebGL / Plugins ///////////////////////////////////////////////////////////////////// - export interface RendererPlugin { - init(renderer: WebGLRenderer): void; - render(scene: Scene, camera: Camera, currentWidth: number, currentHeight: number): void; + setTest(depthTest: boolean): void; + sertMask(depthMask: number): void; + setFunc(depthFunc: Function): void; + setLocked(lock: boolean): void; + setClear(depth: any): void; + reset(): void; } - export class LensFlarePlugin implements RendererPlugin { - constructor(); + export class WebGLStencilBuffer { + constructor(gl: any, state: any); - init(renderer: Renderer): void; - render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void; + setTest(stencilTest: boolean): void; + sertMask(stencilMask: number): void; + setFunc(stencilFunc: Function, stencilRef: any, stencilMask: number): void; + setOp(stencilFail: any, stencilZFail: any, stencilZPass: any): void; + setLocked(lock: boolean): void; + setClear(stencil: any): void; + reset(): void; } - export class WebGLShadowMap implements RendererPlugin { - constructor(); - - enabled: boolean; - type: ShadowMapType; - cullFace: CullFace; + // Renderers / WebGL / Plugins ///////////////////////////////////////////////////////////////////// + export class LensFlarePlugin { + constructor(renderer: WebGLRenderer, flares: any[]); - init(renderer: Renderer): void; - render(scene: Scene, camera: Camera): void; - update(scene: Scene, camera: Camera): void; + render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void; } - export class SpritePlugin implements RendererPlugin { - constructor(); + export class SpritePlugin { + constructor(renderer: WebGLRenderer, sprites: any[]); - init(renderer: Renderer): void; render(scene: Scene, camera: Camera, viewportWidth: number, viewportHeight: number): void; } // Scenes ///////////////////////////////////////////////////////////////////// + /** + * Scenes allow you to set up what and where is to be rendered by three.js. This is where you place objects, lights and cameras. + */ + export class Scene extends Object3D { + constructor(); + + /** + * A fog instance defining the type of fog that affects everything rendered in the scene. Default is null. + */ + fog: IFog; + + /** + * If not null, it will force everything in the scene to be rendered with that material. Default is null. + */ + overrideMaterial: Material; + autoUpdate: boolean; + background: any; + + copy(source: Scene, recursive?: boolean): Scene; + toJSON(meta?: any): any; + } + export interface IFog { - name:string; + name: string; color: Color; - clone():IFog; + clone(): IFog; + toJSON(): any; } - /** * This class contains the parameters that define linear fog, i.e., that grows linearly denser with the distance. */ export class Fog implements IFog { constructor(hex: number, near?: number, far?: number); - name:string; + name: string; /** * Fog color. @@ -4825,13 +5641,14 @@ declare module THREE { far: number; clone(): Fog; + toJSON(): any; } /** * This class contains the parameters that define linear fog, i.e., that grows exponentially denser with the distance. */ export class FogExp2 implements IFog { - constructor(hex: number, density?: number); + constructor(hex: number|string, density?: number); name: string; color: Color; @@ -4843,32 +5660,15 @@ declare module THREE { density: number; clone(): FogExp2; - } - - /** - * Scenes allow you to set up what and where is to be rendered by three.js. This is where you place objects, lights and cameras. - */ - export class Scene extends Object3D { - constructor(); - - /** - * A fog instance defining the type of fog that affects everything rendered in the scene. Default is null. - */ - fog: IFog; - - /** - * If not null, it will force everything in the scene to be rendered with that material. Default is null. - */ - overrideMaterial: Material; - autoUpdate: boolean; - - clone(): Scene; + toJSON(): any; } // Textures ///////////////////////////////////////////////////////////////////// - export class CanvasTexture extends Texture { + export let TextureIdCount: number; + + export class Texture extends EventDispatcher { constructor( - canvas?: HTMLCanvasElement, + image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, mapping?: Mapping, wrapS?: Wrapping, wrapT?: Wrapping, @@ -4876,16 +5676,48 @@ declare module THREE { minFilter?: TextureFilter, format?: PixelFormat, type?: TextureDataType, - anisotropy?: number - ); + anisotropy?: number, + encoding?: TextureEncoding + ); + + id: number; + uuid: string; + name: string; + sourceFile: string; + image: any; // HTMLImageElement or ImageData or { width: number, height: number } in some children; + mipmaps: ImageData[]; + mapping: Mapping; + wrapS: Wrapping; + wrapT: Wrapping; + magFilter: TextureFilter; + minFilter: TextureFilter; + anisotropy: number; + format: PixelFormat; + type: TextureDataType; + offset: Vector2; + repeat: Vector2; + generateMipmaps: boolean; + premultiplyAlpha: boolean; + flipY: boolean; + unpackAlignment: number; + encoding: TextureEncoding; + version: number; + needsUpdate: boolean; + onUpdate: () => void; + static DEFAULT_IMAGE: any; + static DEFAULT_MAPPING: any; + + clone(): Texture; + copy(source: Texture): Texture; + toJSON(meta: any): any; + dispose(): void; + transformUv(uv: Vector): void; } - export class CompressedTexture extends Texture { + export class DepthTexture extends Texture { constructor( - mipmaps: ImageData[], width: number, - height: number, - format?: PixelFormat, + heighht: number, type?: TextureDataType, mapping?: Mapping, wrapS?: Wrapping, @@ -4895,17 +5727,12 @@ declare module THREE { anisotropy?: number ); - image: { width: number; height: number; }; - mipmaps: ImageData[]; - flipY: boolean; - generateMipmaps: boolean; - - clone(): CompressedTexture; + image: { width: number, height: number }; } - export class CubeTexture extends Texture { + export class CanvasTexture extends Texture { constructor( - images: any[], // HTMLImageElement or HTMLCanvasElement + canvas: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, mapping?: Mapping, wrapS?: Wrapping, wrapT?: Wrapping, @@ -4916,82 +5743,74 @@ declare module THREE { anisotropy?: number ); - images: any[]; - - clone(texture?: CubeTexture): CubeTexture; + clone(): CanvasTexture; + copy(source: CanvasTexture): CanvasTexture; } - export class DataTexture extends Texture { + export class CubeTexture extends Texture { constructor( - data: ImageData, - width: number, - height: number, - format: PixelFormat, - type: TextureDataType, - mapping: Mapping, - wrapS: Wrapping, - wrapT: Wrapping, - magFilter: TextureFilter, - minFilter: TextureFilter, - anisotropy?: number + images?: any[], // HTMLImageElement or HTMLCanvasElement + mapping?: Mapping, + wrapS?: Wrapping, + wrapT?: Wrapping, + magFilter?: TextureFilter, + minFilter?: TextureFilter, + format?: PixelFormat, + type?: TextureDataType, + anisotropy?: number, + encoding?: TextureEncoding ); - image: { data: ImageData; width: number; height: number; }; + images: any; // returns and sets the value of Texture.image in the codde ? - clone(): DataTexture; + copy(source: CubeTexture): CubeTexture; } - export class Texture { + export class CompressedTexture extends Texture { constructor( - image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, + mipmaps: ImageData[], + width: number, + height: number, + format?: PixelFormat, + type?: TextureDataType, mapping?: Mapping, wrapS?: Wrapping, wrapT?: Wrapping, magFilter?: TextureFilter, minFilter?: TextureFilter, - format?: PixelFormat, - type?: TextureDataType, - anisotropy?: number - ); + anisotropy?: number, + encoding?: TextureEncoding + ); - id: number; - uuid: string; - name: string; - sourceFile: string; - image: any; // HTMLImageElement or ImageData ; - mipmaps: ImageData[]; - mapping: Mapping; - wrapS: Wrapping; - wrapT: Wrapping; - magFilter: TextureFilter; - minFilter: TextureFilter; - anisotropy: number; - format: PixelFormat; - type: TextureDataType; - offset: Vector2; - repeat: Vector2; - generateMipmaps: boolean; - premultiplyAlpha: boolean; - flipY: boolean; - unpackAlignment: number; - needsUpdate: boolean; - onUpdate: () => void; - static DEFAULT_IMAGE: any; - static DEFAULT_MAPPING: any; + image: { width: number; height: number; }; + + clone(): CompressedTexture; + copy(source: CompressedTexture): CompressedTexture; + } + + export class DataTexture extends Texture { + constructor( + data: ArrayBuffer | Int8Array | Uint8Array | Uint8ClampedArray | Int16Array | Uint16Array | Int32Array | Uint32Array | Float32Array | Float64Array, + width: number, + height: number, + format: PixelFormat, + type: TextureDataType, + mapping: Mapping, + wrapS: Wrapping, + wrapT: Wrapping, + magFilter: TextureFilter, + minFilter: TextureFilter, + anisotropy?: number, + encoding?: TextureEncoding + ); - clone(): Texture; - update(): void; - toJSON(): any; - dispose(): void; + image: { data: ImageData; width: number; height: number; }; - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void ): void; - hasEventListener(type: string, listener: (event: any) => void): void; - removeEventListener(type: string, listener: (event: any) => void): void; - dispatchEvent(event: { type: string; target: any; }): void; + clone(): DataTexture; + copy(source: DataTexture): DataTexture; } - class VideoTexture extends Texture { + export class VideoTexture extends Texture { constructor( video: HTMLVideoElement, mapping?: Mapping, @@ -5004,179 +5823,118 @@ declare module THREE { anisotropy?: number ); - generateMipmaps: boolean; + clone(): VideoTexture; + copy(source: VideoTexture): VideoTexture; } // Extras ///////////////////////////////////////////////////////////////////// - - export interface TypefaceData { - familyName: string; - cssFontWeight: string; - cssFontStyle: string; + export namespace CurveUtils { + export function tangentQuadraticBezier(t: number, p0: number, p1: number, p2: number): number; + export function tangentCubicBezier(t: number, p0: number, p1: number, p2: number, p3: number): number; + export function tangentSpline(t: number, p0: number, p1: number, p2: number, p3: number): number; + export function interpolate(p0: number, p1: number, p2: number, p3: number, t: number): number; } - export var FontUtils: { - faces: { [weight: string]: { [style: string]: Face3; }; }; - face: string; - weight: string; - style: string; - size: number; - divisions: number; - - getFace(): Face3; - loadFace(data: TypefaceData): TypefaceData; - drawText(text: string): { paths: Path[]; offset: number; }; - extractGlyphPoints(c: string, face: Face3, scale: number, offset: number, path: Path): { offset: number; path: Path; }; - - generateShapes(text: string, parameters?: { size?: number; curveSegments?: number; font?: string; weight?: string; style?: string; }): Shape[]; - Triangulate: { - (contour: Vector2[], indices: boolean): Vector2[]; - area(contour: Vector2[]): number; - }; - }; - - export var GeometryUtils: { - // DEPRECATED - merge(geometry1: Geometry, object2: Mesh, materialIndexOffset?: number): void; - - // DEPRECATED - merge(geometry1: Geometry, object2: Geometry, materialIndexOffset?: number): void; - - // DEPRECATED - center(geometry: Geometry): Vector3; - }; - - export var ImageUtils: { - crossOrigin: string; - - loadTexture(url: string, mapping?: Mapping, onLoad?: (texture: Texture) => void, onError?: (message: string) => void): Texture; - loadTextureCube(array: string[], mapping?: Mapping, onLoad?: (texture: Texture) => void , onError?: (message: string) => void ): Texture; - getNormalMap(image: HTMLImageElement, depth?: number): HTMLCanvasElement; - generateDataTexture(width: number, height: number, color: Color): DataTexture; - }; - - export var SceneUtils: { - createMultiMaterialObject(geometry: Geometry, materials: Material[]): Object3D; - detach(child: Object3D, parent: Object3D, scene: Scene): void; - attach(child: Object3D, scene: Scene, parent: Object3D): void; - }; - - // Extras / Animation ///////////////////////////////////////////////////////////////////// + export namespace ImageUtils { // deprecated + export let crossOrigin: string; - export interface KeyFrame { - pos: number[]; - rot: number[]; - scl: number[]; - time: number; + export function loadTexture(url: string, mapping?: Mapping, onLoad?: (texture: Texture) => void, onError?: (message: string) => void): Texture; + export function loadTextureCube(array: string[], mapping?: Mapping, onLoad?: (texture: Texture) => void , onError?: (message: string) => void ): Texture; } - export interface KeyFrames { - keys: KeyFrame[]; - parent: number; + export namespace SceneUtils { + export function createMultiMaterialObject(geometry: Geometry, materials: Material[]): Object3D; + export function detach(child: Object3D, parent: Object3D, scene: Scene): void; + export function attach(child: Object3D, scene: Scene, parent: Object3D): void; } - export interface AnimationData { - JIT: number; - fps: number; - hierarchy: KeyFrames[]; - length: number; - name: string; + export namespace ShapeUtils { + export function area(contour: number[]): number; + export function triangulate(contour: number[], indices: boolean): number[]; + export function triangulateShape(contour: number[], holes: any[]): number[]; + export function isClockWise(pts: number[]): boolean; + export function b2(t: number, p0: number, p1: number, p2: number): number; + export function b3(t: number, p0: number, p1: number, p2: number, p3: number): number; } - export class Animation { - constructor(root: Mesh, data: AnimationData); + // Extras / Audio ///////////////////////////////////////////////////////////////////// - root: Mesh; - data: AnimationData; - hierarchy: Bone[]; - currentTime: number; - timeScale: number; - isPlaying: boolean; - loop: boolean; - weight: number; - interpolationType: number; + export class Audio extends Object3D { + constructor(listener: AudioListener); - play(startTime?: number, weight?: number): void; - stop(): void; - reset(): void; - resetBlendWeights(): void; - update(delta: number): void; - getNextKeyWith(type: string, h: number, key: number): KeyFrame; - getPrevKeyWith(type: string, h: number, key: number): KeyFrame; + type: string; + context: AudioContext; + source: AudioBufferSourceNode; + gain: GainNode; + autoplay: boolean; + startTime: number; + playbackRate: number; + hasPlaybackControl: boolean; + isPlaying: boolean; + sourceType: string; + filters: any[]; + + getOutput(): GainNode; + setNodeSource(audioNode: AudioBufferSourceNode): Audio; + setBuffer(audioBuffer: AudioBuffer): Audio; + play(): Audio; + pause(): Audio; + stop(): Audio; + connect(): Audio; + disconnect(): Audio; + getFilters(): any[]; + setFilter(value: any[]): Audio; + getFilter(): any; + setFilter(filter: any): Audio; + setPlaybackRate(value: number): Audio; + getPlaybackRate(): number; + onEnded(): void; + getLoop(): boolean; + setLoop(value: boolean): void; + getVolume(): number; + setVolume(value: number): Audio; + load(file: string): Audio; // deprecated, use the AudioLoader class } - export var AnimationHandler: { - LINEAR: number; - CATMULLROM: number; - CATMULLROM_FORWARD: number; - - animations: any[]; - - init(data: AnimationData): AnimationData; - parse(root: Mesh): Object3D[]; - play(animation: Animation): void; - stop(animation: Animation): void; - update(deltaTimeMS: number): void; - }; + export class AudioAnalyser { + constructor(audio: any, fftSize: number); - export class KeyFrameAnimation { - constructor(data: any); + analyser: any; + data: Uint8Array; - root: Mesh; - data: AnimationData; - hierarchy: KeyFrames[]; - currentTime: number; - timeScale: number; - isPlaying: boolean; - isPaused: boolean; - loop: boolean; + getFrequencyData(): Uint8Array; + getAverageFrequency(): number; - play(startTime?: number): void; - stop(): void; - update(delta: number): void; - getNextKeyWith(type: string, h: number, key: number): KeyFrame; - getPrevKeyWith(type: string, h: number, key: number): KeyFrame; + // deprecated + getData(file: any): any; } - export class MorphAnimation { - constructor(mesh: Mesh); + export const AudioContext: AudioContext; - mesh: Mesh; - frames: number; - currentTime: number; - duration: number; - loop: boolean; - lastFrame: number; - currentFrame: number; - isPlaying: boolean; + export class AudioBuffer { + constructor(context: any); - play(): void; - pause(): void; - update(delta: number): void; - } + context: any; + ready: boolean; + readyCallbacks: Function[]; - // Extras / Audio ///////////////////////////////////////////////////////////////////// + load(file: string): AudioBuffer; + onReady(callback: Function): void; + } - export class Audio extends Object3D { + export class PositionalAudio extends Audio { constructor(listener: AudioListener); - type: string; - context: AudioContext; - source: AudioBufferSourceNode; - gain: GainNode; + panner: PannerNode; - autoplay: boolean; - startTime: number; - isPlaying: boolean; - load(file: string): Audio; - play(): void; - pause(): void; - stop(): void; - setLoop(value: boolean): void; setRefDistance(value: number): void; + getRefDistance(): number; setRolloffFactor(value: number): void; - setVolume(value: number): void; - updateMatrixWorld(force?: boolean): void; + getRolloffFactor(): number; + setDistanceModel(value: number): void; + getDistanceModel(): number; + setMaxDistance(value: number): void; + getMaxDistance(): number; } export class AudioListener extends Object3D { @@ -5184,8 +5942,14 @@ declare module THREE { type: string; context: AudioContext; + gain: GainNode; - updateMatrixWorld(force?: boolean): void; + getInput(): GainNode; + removeFilter(): void; + setFilter(value: any): void; + getFilter(): any; + setMasterVolume(value: number): void; + getMasterVolume(): number; } // Extras / Core ///////////////////////////////////////////////////////////////////// @@ -5205,7 +5969,7 @@ declare module THREE { * Returns a vector for point at relative position in curve according to arc length * getPointAt(u: number): T; */ - getPointAt(u: number):T; + getPointAt(u: number): T; /** * Get sequence of points using getPoint( t ) @@ -5254,48 +6018,24 @@ declare module THREE { static create(constructorFunc: Function, getPointFunc: Function): Function; } - export var CurveUtils: { - tangentQuadraticBezier(t: number, p0: number, p1: number, p2: number): number; - tangentCubicBezier(t: number, p0: number, p1: number, p2: number, p3: number): number; - tangentSpline(t: number, p0: number, p1: number, p2: number, p3: number): number; - interpolate(p0: number, p1: number, p2: number, p3: number, t: number): number; - }; - - export interface BoundingBox { - minX: number; - minY: number; - minZ?: number; - maxX: number; - maxY: number; - maxZ?: number; - } - export class CurvePath extends Curve { constructor(); curves: Curve[]; - bends: Path[]; autoClose: boolean; add(curve: Curve): void; checkConnection(): boolean; closePath(): void; + getPoint(t: number): T; getLength(): number; + updateArcLengths(): void; getCurveLengths(): number[]; - getBoundingBox(): BoundingBox; + getSpacedPoints(divisions?: number): T[]; + getPoints(divisions?: number): T[]; createPointsGeometry(divisions: number): Geometry; createSpacedPointsGeometry(divisions: number): Geometry; createGeometry(points: T[]): Geometry; - addWrapPath(bendpath: Path): void; - getTransformedPoints(segments: number, bends?: Path[]): T[]; - getTransformedSpacedPoints(segments: number, bends?: Path[]): T[]; - getWrapPoints(oldPts: T[], path: Path): T[]; - } - - export class Gyroscope extends Object3D { - constructor(); - - updateMatrixWorld(force?: boolean): void; } export enum PathActions { @@ -5319,7 +6059,7 @@ declare module THREE { export class Path extends CurvePath { constructor(points?: Vector2[]); - actions: PathAction[]; + currentPoint: Vector2; fromPoints(vectors: Vector2[]): void; moveTo(x: number, y: number): void; @@ -5331,9 +6071,20 @@ declare module THREE { absarc(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean): void; ellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void; absellipse(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number): void; - getSpacedPoints(divisions?: number, closedPath?: boolean): Vector2[]; - getPoints(divisions?: number, closedPath?: boolean): Vector2[]; - toShapes(): Shape[]; + } + + export class ShapePath { + constructor(); + + subPaths: any[]; + currentPath: any; + + moveTo(x: number, y: number): void; + lineTo(x: number, y: number): void; + quadraticCurveTo(aCPx: number, aCPy: number, aX: number, aY: number): void; + bezierCurveTo(aCP1x: number, aCP1y: number, aCP2x: number, aCP2y: number, aX: number, aY: number): void; + splineThru(pts: Vector2[]): void; + toShapes(isCCW: boolean, noHoles: any): Shape[]; } /** @@ -5347,36 +6098,25 @@ declare module THREE { extrude(options?: any): ExtrudeGeometry; makeGeometry(options?: any): ShapeGeometry; getPointsHoles(divisions: number): Vector2[][]; - getSpacedPointsHoles(divisions: number): Vector2[][]; extractAllPoints(divisions: number): { shape: Vector2[]; holes: Vector2[][]; }; extractPoints(divisions: number): Vector2[]; - extractAllSpacedPoints(divisions: Vector2): { - shape: Vector2[]; - holes: Vector2[][]; - }; - } // Extras / Curves ///////////////////////////////////////////////////////////////////// - export class ArcCurve extends EllipseCurve { - constructor(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number); - } - export class CatmullRomCurve3 extends Curve { constructor(points?: Vector3[]); points: Vector3[]; - } - export class ClosedSplineCurve3 extends Curve { - constructor(points?: Vector3[]); - - points: Vector3[]; + getPoint(t: number): Vector3; } + export class ClosedSplineCurve3 extends CatmullRomCurve3 {} // deprecated, use CatmullRomCurve3 + export class SplineCurve3 extends CatmullRomCurve3 {} // will be deprecated, use CatmullRomCurve3 + export class CubicBezierCurve extends Curve { constructor(v0: Vector2, v1: Vector2, v2: Vector2, v3: Vector2); @@ -5385,6 +6125,7 @@ declare module THREE { v2: Vector2; v3: Vector2; } + export class CubicBezierCurve3 extends Curve { constructor(v0: Vector3, v1: Vector3, v2: Vector3, v3: Vector3); @@ -5392,7 +6133,10 @@ declare module THREE { v1: Vector3; v2: Vector3; v3: Vector3; + + getPoint(t: number): Vector3; } + export class EllipseCurve extends Curve { constructor(aX: number, aY: number, xRadius: number, yRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean, aRotation: number); @@ -5405,19 +6149,26 @@ declare module THREE { aClockwise: boolean; aRotation: number; } + export class ArcCurve extends EllipseCurve { + constructor(aX: number, aY: number, aRadius: number, aStartAngle: number, aEndAngle: number, aClockwise: boolean ); + } + export class LineCurve extends Curve { constructor( v1: Vector2, v2: Vector2 ); v1: Vector2; v2: Vector2; - } + export class LineCurve3 extends Curve { - constructor( v1: Vector3, v2: Vector3 ); + constructor(v1: Vector3, v2: Vector3); v1: Vector3; v2: Vector3; + + getPoint(t: number): Vector3; } + export class QuadraticBezierCurve extends Curve { constructor( v0: Vector2, v1: Vector2, v2: Vector2 ); @@ -5425,25 +6176,38 @@ declare module THREE { v1: Vector2; v2: Vector2; } + export class QuadraticBezierCurve3 extends Curve { - constructor( v0: Vector3, v1: Vector3, v2: Vector3 ); + constructor(v0: Vector3, v1: Vector3, v2: Vector3); v0: Vector3; v1: Vector3; v2: Vector3; + + getPoint(t: number): Vector3; } + export class SplineCurve extends Curve { - constructor( points?: Vector2[] ); + constructor(points?: Vector2[]); - points:Vector2[]; + points: Vector2[]; } - export class SplineCurve3 extends Curve { - constructor( points?: Vector3[] ); - points:Vector3[]; + + // Extras / Geometries ///////////////////////////////////////////////////////////////////// + export class BoxBufferGeometry extends BufferGeometry { + constructor(width: number, height: number, depth: number, widthSegments?: number, heightSegments?: number, depthSegments?: number); + + parameters: { + width: number; + height: number; + depth: number; + widthSegments: number; + heightSegments: number; + depthSegments: number; + }; } - // Extras / Geomerties ///////////////////////////////////////////////////////////////////// /** * BoxGeometry is the quadrilateral primitive geometry class. It is typically used for creating a cube or irregular quadrilateral of the dimensions provided within the (optional) 'width', 'height', & 'depth' constructor arguments. */ @@ -5466,8 +6230,12 @@ declare module THREE { heightSegments: number; depthSegments: number; }; + + clone(): BoxGeometry; } + export class CubeGeometry extends BoxGeometry {} // deprecated, use BoxGeometry + export class CircleBufferGeometry extends BufferGeometry { constructor(radius?: number, segments?: number, thetaStart?: number, thetaLength?: number); @@ -5490,8 +6258,19 @@ declare module THREE { }; } - // deprecated - export class CubeGeometry extends BoxGeometry { + export class CylinderBufferGeometry extends BufferGeometry { + constructor(radiusTop?: number, radiusBottom?: number, height?: number, radialSegments?: number, heightSegments?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number); + + parameters: { + radiusTop: number; + radiusBottom: number; + height: number; + radialSegments: number; + heightSegments: number; + openEnded: boolean; + thetaStart: number; + thetaLength: number; + }; } export class CylinderGeometry extends Geometry { @@ -5517,6 +6296,14 @@ declare module THREE { }; } + export class ConeBufferGeometry extends BufferGeometry { + constructor(radius?: number, height?: number, radialSegment?: number, heightSegment?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number); + } + + export class ConeGeometry extends CylinderGeometry { + constructor(radius?: number, height?: number, radialSegment?: number, heightSegment?: number, openEnded?: boolean, thetaStart?: number, thetaLength?: number); + } + export class DodecahedronGeometry extends Geometry { constructor(radius: number, detail: number); @@ -5527,14 +6314,16 @@ declare module THREE { } export class EdgesGeometry extends BufferGeometry { - constructor(geometry: Geometry|BufferGeometry, thresholdAngle?: number); + constructor(geometry: BufferGeometry, thresholdAngle: number); + + clone(): EdgesGeometry; } export class ExtrudeGeometry extends Geometry { constructor(shape?: Shape, options?: any); constructor(shapes?: Shape[], options?: any); - WorldUVGenerator: { + static WorldUVGenerator: { generateTopUV(geometry: Geometry, indexA: number, indexB: number, indexC: number): Vector2[]; generateSideWallUV(geometry: Geometry, indexA: number, indexB: number, indexC: number, indexD: number): Vector2[]; }; @@ -5547,6 +6336,17 @@ declare module THREE { constructor(radius: number, detail: number); } + export class LatheBufferGeometry extends BufferGeometry { + constructor(points: Vector3[], segments?: number, phiStart?: number, phiLength?: number); + + parameters: { + points: Vector3[]; + segments: number; + phiStart: number; + phiLength: number; + }; + } + export class LatheGeometry extends Geometry { constructor(points: Vector3[], segments?: number, phiStart?: number, phiLength?: number); @@ -5603,6 +6403,20 @@ declare module THREE { radius: number; detail: number; }; + boundingSphere: Sphere; + } + + export class RingBufferGeometry extends BufferGeometry { + constructor(innerRadius?: number, outerRadius?: number, thetaSegments?: number, phiSegments?: number, thetaStart?: number, thetaLength?: number); + + parameters: { + innerRadius: number; + outerRadius: number; + thetaSegments: number; + phiSegments: number; + thetaStart: number; + thetaLength: number; + }; } export class RingGeometry extends Geometry { @@ -5622,26 +6436,22 @@ declare module THREE { constructor(shape: Shape, options?: any); constructor(shapes: Shape[], options?: any); - addShapeList(shapes: Shape[], options: any): ShapeGeometry; addShape(shape: Shape, options?: any): void; } - interface SphereParameters { - radius: number; - widthSegments: number; - heightSegments: number; - phiStart: number; - phiLength: number; - thetaStart: number; - thetaLength: number; - } - export class SphereBufferGeometry extends BufferGeometry { constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number); - parameters: SphereParameters; - + parameters: { + radius: number; + widthSegments: number; + heightSegments: number; + phiStart: number; + phiLength: number; + thetaStart: number; + thetaLength: number; + }; } /** @@ -5661,7 +6471,15 @@ declare module THREE { */ constructor(radius: number, widthSegments?: number, heightSegments?: number, phiStart?: number, phiLength?: number, thetaStart?: number, thetaLength?: number); - parameters: SphereParameters; + parameters: { + radius: number; + widthSegments: number; + heightSegments: number; + phiStart: number; + phiLength: number; + thetaStart: number; + thetaLength: number; + }; } export class TetrahedronGeometry extends PolyhedronGeometry { @@ -5669,19 +6487,39 @@ declare module THREE { } export interface TextGeometryParameters { - size?: number; // size of the text - height?: number; // thickness to extrude text - curveSegments?: number; // number of points on the curves - font?: string; // font name - weight?: string; // font weight (normal, bold) - style?: string; // font style (normal, italics) - bevelEnabled?: boolean; // turn on bevel - bevelThickness?: number; // how deep into text bevel goes - bevelSize?: number; // how far from text outline is bevel + font: Font; + size: number; + height: number; + curveSegments: number; + bevelEnabled: boolean; + bevelThickness: number; + bevelSize: number; } export class TextGeometry extends ExtrudeGeometry { - constructor(text: string, TextGeometryParameters?: TextGeometryParameters); + constructor(text: string, parameters?: TextGeometryParameters); + + parameters: { + font: Font; + size: number; + height: number; + curveSegments: number; + bevelEnabled: boolean; + bevelThickness: number; + bevelSize: number; + }; + } + + export class TorusBufferGeometry extends BufferGeometry { + constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, arc?: number); + + parameters: { + radius: number; + tube: number; + radialSegments: number; + tubularSegments: number; + arc: number; + }; } export class TorusGeometry extends Geometry { @@ -5696,7 +6534,7 @@ declare module THREE { }; } - export class TorusKnotGeometry extends Geometry { + export class TorusKnotBufferGeometry extends BufferGeometry { constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, p?: number, q?: number, heightScale?: number); parameters: { @@ -5710,6 +6548,19 @@ declare module THREE { }; } + export class TorusKnotGeometry extends Geometry { + constructor(radius?: number, tube?: number, radialSegments?: number, tubularSegments?: number, p?: number, q?: number, heightScale?: number); + + parameters: { + radius: number; + tube: number; + radialSegments: number; + tubularSegments: number; + p: number; + q: number; + heightScale: number; + }; + } export class TubeGeometry extends Geometry { constructor(path: Path, segments?: number, radius?: number, radiusSegments?: number, closed?: boolean, taper?: (u: number) => number); @@ -5728,10 +6579,11 @@ declare module THREE { static NoTaper(u?: number): number; static SinusoidalTaper(u: number): number; + static FrenetFrames(path: Path, segments: number, closed: boolean): void; } export class WireframeGeometry extends BufferGeometry { - constructor(geometry: Geometry|BufferGeometry); + constructor(geometry: Geometry | BufferGeometry); } // Extras / Helpers ///////////////////////////////////////////////////////////////////// @@ -5747,7 +6599,7 @@ declare module THREE { setColor(hex: number): void; } - export class AxisHelper extends Line { + export class AxisHelper extends LineSegments { constructor(size?: number); } @@ -5760,13 +6612,13 @@ declare module THREE { update(): void; } - export class BoxHelper extends Line { - constructor(object?: Object3D); + export class BoxHelper extends LineSegments { + constructor(object?: Object3D, color?: Color); update(object?: Object3D): void; } - export class CameraHelper extends Line { + export class CameraHelper extends LineSegments { constructor(camera: Camera); camera: Camera; @@ -5780,35 +6632,30 @@ declare module THREE { light: Light; lightPlane: Line; - targetLine: Line; dispose(): void; update(): void; } - export class EdgesHelper extends Line { + export class EdgesHelper extends LineSegments { constructor(object: Object3D, hex?: number, thresholdAngle?: number); - } - export class FaceNormalsHelper extends Line { + export class FaceNormalsHelper extends LineSegments { constructor(object: Object3D, size?: number, hex?: number, linewidth?: number); object: Object3D; size: number; - normalMatrix: Matrix3; update(object?: Object3D): void; } - export class GridHelper extends Line { - constructor(size: number, step: number); - - color1: Color; - color2: Color; + export class GridHelper extends LineSegments { + constructor(size: number, divisions: number, color1?: Color|number, color2?: Color|number); - setColors(colorCenterLine: number, colorGrid: number): void; + setColors(color1?: Color|number, color2?: Color|number): void; // deprecated } + export class HemisphereLightHelper extends Object3D { constructor(light: Light, sphereSize: number); @@ -5829,7 +6676,7 @@ declare module THREE { update(): void; } - export class SkeletonHelper extends Line { + export class SkeletonHelper extends LineSegments { constructor(bone: Object3D); bones: Bone[]; @@ -5840,26 +6687,15 @@ declare module THREE { } export class SpotLightHelper extends Object3D { - constructor(light: Light, sphereSize: number, arrowLength: number); + constructor(light: Light); light: Light; - cone: Mesh; dispose(): void; update(): void; } - export class VertexNormalsHelper extends Line { - constructor(object: Object3D, size?: number, hex?: number, linewidth?: number); - - object: Object3D; - size: number; - normalMatrix: Matrix3; - - update(object?: Object3D): void; - } - - export class VertexTangentsHelper extends Line { + export class VertexNormalsHelper extends LineSegments { constructor(object: Object3D, size?: number, hex?: number, linewidth?: number); object: Object3D; @@ -5868,9 +6704,8 @@ declare module THREE { update(object?: Object3D): void; } - export class WireframeHelper extends Line { + export class WireframeHelper extends LineSegments { constructor(object: Object3D, hex?: number); - } // Extras / Objects ///////////////////////////////////////////////////////////////////// @@ -5879,13 +6714,12 @@ declare module THREE { constructor(material: Material); material: Material; - render(renderCallback: Function): void; } export interface MorphBlendMeshAnimation { - startFrame: number; - endFrame: number; + start: number; + end: number; length: number; fps: number; duration: number; @@ -5921,6 +6755,6 @@ declare module THREE { } } -declare module 'three' { +declare module "three" { export = THREE; -} +} \ No newline at end of file