From bd32ebe9c35c6ba711c15a7d5f978bd415bf3261 Mon Sep 17 00:00:00 2001 From: Palash Bansal Date: Thu, 25 May 2023 22:21:33 +0530 Subject: [PATCH 1/3] Add missing functions and properties in: OrbitControls, GLTFExporter, GLTFWriter, ObjectLoader, Material, Matrix3, Matrix4, WebGLMultipleRenderTargets --- .../examples/jsm/controls/OrbitControls.d.ts | 12 +---- .../examples/jsm/exporters/GLTFExporter.d.ts | 54 ++++++++++++++++++- .../examples/jsm/loaders/GLTFLoader.d.ts | 1 + types/three/src/loaders/ObjectLoader.d.ts | 24 +++++---- types/three/src/materials/Material.d.ts | 6 +++ types/three/src/math/Matrix3.d.ts | 2 + types/three/src/math/Matrix4.d.ts | 2 + .../renderers/WebGLMultipleRenderTargets.d.ts | 6 +++ 8 files changed, 86 insertions(+), 21 deletions(-) diff --git a/types/three/examples/jsm/controls/OrbitControls.d.ts b/types/three/examples/jsm/controls/OrbitControls.d.ts index 6940be487..53379a137 100644 --- a/types/three/examples/jsm/controls/OrbitControls.d.ts +++ b/types/three/examples/jsm/controls/OrbitControls.d.ts @@ -1,4 +1,4 @@ -import { Camera, MOUSE, TOUCH, Vector3 } from '../../../src/Three'; +import { Camera, MOUSE, TOUCH, Vector3, EventDispatcher, Event } from '../../../src/Three'; /** * Orbit controls allow the camera to orbit around a target. @@ -7,7 +7,7 @@ import { Camera, MOUSE, TOUCH, Vector3 } from '../../../src/Three'; * @param domElement - The HTML element used for * event listeners. */ -export class OrbitControls { +export class OrbitControls extends EventDispatcher { constructor(object: Camera, domElement?: HTMLElement); /** @@ -267,12 +267,4 @@ export class OrbitControls { */ getDistance(): number; - // EventDispatcher mixins - addEventListener(type: string, listener: (event: any) => void): void; - - hasEventListener(type: string, listener: (event: any) => void): boolean; - - removeEventListener(type: string, listener: (event: any) => void): void; - - dispatchEvent(event: { type: string; target: any }): void; } diff --git a/types/three/examples/jsm/exporters/GLTFExporter.d.ts b/types/three/examples/jsm/exporters/GLTFExporter.d.ts index d478b1fdd..d8e15f88d 100644 --- a/types/three/examples/jsm/exporters/GLTFExporter.d.ts +++ b/types/three/examples/jsm/exporters/GLTFExporter.d.ts @@ -1,4 +1,4 @@ -import { Object3D, AnimationClip, Texture, Material, Mesh } from '../../../src/Three'; +import {Object3D, AnimationClip, Texture, Material, Mesh, BufferGeometry, PixelFormat} from '../../../src/Three'; export interface GLTFExporterOptions { /** @@ -86,9 +86,13 @@ export class GLTFExporter { input: Object3D | Object3D[], options?: GLTFExporterOptions, ): Promise; + + static Utils: { + GLTFWriter: typeof GLTFWriter; + } } -export class GLTFWriter { +declare class GLTFWriter { constructor(); setPlugins(plugins: GLTFExporterPlugin[]): void; @@ -105,6 +109,52 @@ export class GLTFWriter { onDone: (gltf: ArrayBuffer | { [key: string]: any }) => void, options?: GLTFExporterOptions, ): Promise; + + serializeUserData( object: Object3D | Material | BufferGeometry, objectDef: { [key: string]: any } ): void; + + processObjects(objects: Object3D[]): void; + processScene(scene: Object3D): void; + processMaterial(material: Material): number|null; + processImage(image: any, format: PixelFormat, flipY: boolean, mimeType?: string ): number; + processBufferViewImage( blob: Blob ): Promise; + processSampler(map: Texture): number; + processTexture(map: Texture): number; + applyTextureTransform( mapDef: {[key: string]: any}, texture: Texture): void; + cache: { + textures: Map; + materials: Map; + meshes: Map; + attributes: Map; + attributesNormalized: Map; + images: Map; + } + json: { + asset: { [key: string]: any }; + scenes: { [key: string]: any }[]; + scene: number; + nodes: { [key: string]: any }[]; + materials: { [key: string]: any }[]; + meshes: { [key: string]: any }[]; + cameras: { [key: string]: any }[]; + skins: { [key: string]: any }[]; + animations: { [key: string]: any }[]; + images: { [key: string]: any }[]; + textures: { [key: string]: any }[]; + samplers: { [key: string]: any }[]; + accessors: { [key: string]: any }[]; + bufferViews: { [key: string]: any }[]; + buffers: { [key: string]: any }[]; + extensions: { [key: string]: any }; + extensionsUsed: string[]; + extensionsRequired: string[]; + } + options: any; + pending: Promise[]; + plugins: GLTFExporterPlugin[]; + extensionsUsed: { [key: string]: boolean }; + processBufferViewImageBuffer( buffer: ArrayBuffer ): number; + + _invokeAll( func: (plugin: GLTFExporterPlugin)=>void ): void; } export interface GLTFExporterPlugin { diff --git a/types/three/examples/jsm/loaders/GLTFLoader.d.ts b/types/three/examples/jsm/loaders/GLTFLoader.d.ts index 556c30728..52e62dac9 100644 --- a/types/three/examples/jsm/loaders/GLTFLoader.d.ts +++ b/types/three/examples/jsm/loaders/GLTFLoader.d.ts @@ -139,6 +139,7 @@ export class GLTFParser { } export interface GLTFLoaderPlugin { + name: string; beforeRoot?: (() => Promise | null) | undefined; afterRoot?: ((result: GLTF) => Promise | null) | undefined; loadNode?: ((nodeIndex: number) => Promise | null) | undefined; diff --git a/types/three/src/loaders/ObjectLoader.d.ts b/types/three/src/loaders/ObjectLoader.d.ts index 0cdec6abd..9a2fcc282 100644 --- a/types/three/src/loaders/ObjectLoader.d.ts +++ b/types/three/src/loaders/ObjectLoader.d.ts @@ -1,12 +1,14 @@ import { Loader } from './Loader'; import { LoadingManager } from './LoadingManager'; import { Object3D } from './../core/Object3D'; +import { Shape } from './../extras/core/Shape'; import { Texture } from './../textures/Texture'; import { Material } from './../materials/Material'; import { AnimationClip } from './../animation/AnimationClip'; import { InstancedBufferGeometry } from '../core/InstancedBufferGeometry'; import { BufferGeometry } from '../core/BufferGeometry'; import { Source } from '../textures/Source'; +import { Skeleton } from '../objects/Skeleton' export class ObjectLoader extends Loader { constructor(manager?: LoadingManager); @@ -26,17 +28,21 @@ export class ObjectLoader extends Loader { parse(json: any, onLoad?: (object: Object3D) => void): T; // tslint:disable-next-line:no-unnecessary-generics parseAsync(json: any): Promise; - parseGeometries(json: any): { [key: string]: InstancedBufferGeometry | BufferGeometry }; // Array of BufferGeometry or Geometry or Geometry2. - parseMaterials(json: any, textures: { [key: string]: Texture }): Material[]; // Array of Classes that inherits from Matrial. - parseAnimations(json: any): AnimationClip[]; - parseImages(json: any, onLoad?: () => void): { [key: string]: Source }; - parseImagesAsync(json: any): Promise<{ [key: string]: Source }>; - parseTextures(json: any, images: any): Texture[]; + parseGeometries(json: any[], shapes: Shape[]): { [key: string]: InstancedBufferGeometry | BufferGeometry }; // Array of BufferGeometry or Geometry or Geometry2. + parseMaterials(json: any[], textures: { [key: string]: Texture }): { [key: string]: Material }; // Array of Classes that inherits from Matrial. + parseAnimations(json: any[]): { [key: string]: AnimationClip }; + parseShapes(json: any[]): { [key: string]: Shape }; + parseImages(json: any[], onLoad?: () => void): { [key: string]: Source }; + parseImagesAsync(json: any[]): Promise<{ [key: string]: Source }>; + parseTextures(json: any[], images: any): { [key: string]: Texture }; + parseSkeletons(json: any[], object: Object3D): { [key: string]: Skeleton }; + bindSkeletons(object: Object3D, skeletons: Record): void; parseObject( data: any, - geometries: any[], - materials: Material[], - animations: AnimationClip[], + geometries: Record, + materials: Record, + textures: Record, + animations: Record, ): // tslint:disable-next-line:no-unnecessary-generics T; } diff --git a/types/three/src/materials/Material.d.ts b/types/three/src/materials/Material.d.ts index 938679ac5..321d1752a 100644 --- a/types/three/src/materials/Material.d.ts +++ b/types/three/src/materials/Material.d.ts @@ -13,6 +13,10 @@ import { StencilOp, PixelFormat, } from '../constants'; +import {Scene} from '../scenes/Scene' +import {Camera} from '../cameras/Camera' +import {BufferGeometry} from '../core/BufferGeometry' +import {Object3D} from '../core/Object3D' export interface MaterialParameters { alphaTest?: number | undefined; @@ -385,6 +389,8 @@ export class Material extends EventDispatcher { */ onBeforeCompile(shader: Shader, renderer: WebGLRenderer): void; + onBeforeRender(renderer: WebGLRenderer, scene: Scene, camera: Camera, geometry: BufferGeometry, object: Object3D): void + /** * In case onBeforeCompile is used, this callback can be used to identify values of settings used in onBeforeCompile, so three.js can reuse a cached shader or recompile the shader as needed. */ diff --git a/types/three/src/math/Matrix3.d.ts b/types/three/src/math/Matrix3.d.ts index b5f47ddad..0a0ac2c0e 100644 --- a/types/three/src/math/Matrix3.d.ts +++ b/types/three/src/math/Matrix3.d.ts @@ -56,6 +56,8 @@ export class Matrix3 implements Matrix { */ constructor(); + readonly isMatrix3: true; + /** * Array with matrix values. * @default [1, 0, 0, 0, 1, 0, 0, 0, 1] diff --git a/types/three/src/math/Matrix4.d.ts b/types/three/src/math/Matrix4.d.ts index 4c40010e7..98e9f6b0b 100644 --- a/types/three/src/math/Matrix4.d.ts +++ b/types/three/src/math/Matrix4.d.ts @@ -43,6 +43,8 @@ export type Matrix4Tuple = [ export class Matrix4 implements Matrix { constructor(); + readonly isMatrix4: true; + /** * Array with matrix values. * @default [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1] diff --git a/types/three/src/renderers/WebGLMultipleRenderTargets.d.ts b/types/three/src/renderers/WebGLMultipleRenderTargets.d.ts index e2afa2610..4d6885383 100644 --- a/types/three/src/renderers/WebGLMultipleRenderTargets.d.ts +++ b/types/three/src/renderers/WebGLMultipleRenderTargets.d.ts @@ -26,4 +26,10 @@ export class WebGLMultipleRenderTargets extends EventDispatcher { dispose(): void; // This is an available method, however it will break the code see https://github.com/mrdoob/three.js/issues/21930 setTexture(texture: Texture): void; + + /** + * Defines the count of MSAA samples. Can only be used with WebGL 2. Default is **0**. + * @default 0 + */ + samples: number; } From 3236037d844c2313bef46ae9f9b9819881c2a678 Mon Sep 17 00:00:00 2001 From: Palash Bansal Date: Thu, 25 May 2023 23:05:04 +0530 Subject: [PATCH 2/3] Run prettier --- .../examples/jsm/controls/OrbitControls.d.ts | 1 - .../examples/jsm/exporters/GLTFExporter.d.ts | 22 +++++++++---------- types/three/src/loaders/ObjectLoader.d.ts | 2 +- types/three/src/materials/Material.d.ts | 16 +++++++++----- 4 files changed, 23 insertions(+), 18 deletions(-) diff --git a/types/three/examples/jsm/controls/OrbitControls.d.ts b/types/three/examples/jsm/controls/OrbitControls.d.ts index 53379a137..568148ce6 100644 --- a/types/three/examples/jsm/controls/OrbitControls.d.ts +++ b/types/three/examples/jsm/controls/OrbitControls.d.ts @@ -266,5 +266,4 @@ export class OrbitControls extends EventDispatcher { * Returns the distance from the camera to the target. */ getDistance(): number; - } diff --git a/types/three/examples/jsm/exporters/GLTFExporter.d.ts b/types/three/examples/jsm/exporters/GLTFExporter.d.ts index d8e15f88d..a644cbbe4 100644 --- a/types/three/examples/jsm/exporters/GLTFExporter.d.ts +++ b/types/three/examples/jsm/exporters/GLTFExporter.d.ts @@ -1,4 +1,4 @@ -import {Object3D, AnimationClip, Texture, Material, Mesh, BufferGeometry, PixelFormat} from '../../../src/Three'; +import { Object3D, AnimationClip, Texture, Material, Mesh, BufferGeometry, PixelFormat } from '../../../src/Three'; export interface GLTFExporterOptions { /** @@ -89,7 +89,7 @@ export class GLTFExporter { static Utils: { GLTFWriter: typeof GLTFWriter; - } + }; } declare class GLTFWriter { @@ -110,16 +110,16 @@ declare class GLTFWriter { options?: GLTFExporterOptions, ): Promise; - serializeUserData( object: Object3D | Material | BufferGeometry, objectDef: { [key: string]: any } ): void; + serializeUserData(object: Object3D | Material | BufferGeometry, objectDef: { [key: string]: any }): void; processObjects(objects: Object3D[]): void; processScene(scene: Object3D): void; - processMaterial(material: Material): number|null; - processImage(image: any, format: PixelFormat, flipY: boolean, mimeType?: string ): number; - processBufferViewImage( blob: Blob ): Promise; + processMaterial(material: Material): number | null; + processImage(image: any, format: PixelFormat, flipY: boolean, mimeType?: string): number; + processBufferViewImage(blob: Blob): Promise; processSampler(map: Texture): number; processTexture(map: Texture): number; - applyTextureTransform( mapDef: {[key: string]: any}, texture: Texture): void; + applyTextureTransform(mapDef: { [key: string]: any }, texture: Texture): void; cache: { textures: Map; materials: Map; @@ -127,7 +127,7 @@ declare class GLTFWriter { attributes: Map; attributesNormalized: Map; images: Map; - } + }; json: { asset: { [key: string]: any }; scenes: { [key: string]: any }[]; @@ -147,14 +147,14 @@ declare class GLTFWriter { extensions: { [key: string]: any }; extensionsUsed: string[]; extensionsRequired: string[]; - } + }; options: any; pending: Promise[]; plugins: GLTFExporterPlugin[]; extensionsUsed: { [key: string]: boolean }; - processBufferViewImageBuffer( buffer: ArrayBuffer ): number; + processBufferViewImageBuffer(buffer: ArrayBuffer): number; - _invokeAll( func: (plugin: GLTFExporterPlugin)=>void ): void; + _invokeAll(func: (plugin: GLTFExporterPlugin) => void): void; } export interface GLTFExporterPlugin { diff --git a/types/three/src/loaders/ObjectLoader.d.ts b/types/three/src/loaders/ObjectLoader.d.ts index 9a2fcc282..aed465bcb 100644 --- a/types/three/src/loaders/ObjectLoader.d.ts +++ b/types/three/src/loaders/ObjectLoader.d.ts @@ -8,7 +8,7 @@ import { AnimationClip } from './../animation/AnimationClip'; import { InstancedBufferGeometry } from '../core/InstancedBufferGeometry'; import { BufferGeometry } from '../core/BufferGeometry'; import { Source } from '../textures/Source'; -import { Skeleton } from '../objects/Skeleton' +import { Skeleton } from '../objects/Skeleton'; export class ObjectLoader extends Loader { constructor(manager?: LoadingManager); diff --git a/types/three/src/materials/Material.d.ts b/types/three/src/materials/Material.d.ts index 321d1752a..db4e548f3 100644 --- a/types/three/src/materials/Material.d.ts +++ b/types/three/src/materials/Material.d.ts @@ -13,10 +13,10 @@ import { StencilOp, PixelFormat, } from '../constants'; -import {Scene} from '../scenes/Scene' -import {Camera} from '../cameras/Camera' -import {BufferGeometry} from '../core/BufferGeometry' -import {Object3D} from '../core/Object3D' +import { Scene } from '../scenes/Scene'; +import { Camera } from '../cameras/Camera'; +import { BufferGeometry } from '../core/BufferGeometry'; +import { Object3D } from '../core/Object3D'; export interface MaterialParameters { alphaTest?: number | undefined; @@ -389,7 +389,13 @@ export class Material extends EventDispatcher { */ onBeforeCompile(shader: Shader, renderer: WebGLRenderer): void; - onBeforeRender(renderer: WebGLRenderer, scene: Scene, camera: Camera, geometry: BufferGeometry, object: Object3D): void + onBeforeRender( + renderer: WebGLRenderer, + scene: Scene, + camera: Camera, + geometry: BufferGeometry, + object: Object3D, + ): void; /** * In case onBeforeCompile is used, this callback can be used to identify values of settings used in onBeforeCompile, so three.js can reuse a cached shader or recompile the shader as needed. From 9d5baec29f1b962510697342b3368c37e54e872d Mon Sep 17 00:00:00 2001 From: Palash Bansal Date: Thu, 25 May 2023 23:18:55 +0530 Subject: [PATCH 3/3] Add name to ExamplePlugin test, remove ts-expect-error from NodeObjectLoader --- types/three/examples/jsm/nodes/loaders/NodeObjectLoader.d.ts | 2 -- types/three/test/integration/loaders-gltfloader-plugin.ts | 1 + 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/types/three/examples/jsm/nodes/loaders/NodeObjectLoader.d.ts b/types/three/examples/jsm/nodes/loaders/NodeObjectLoader.d.ts index af2d15dae..f56588224 100644 --- a/types/three/examples/jsm/nodes/loaders/NodeObjectLoader.d.ts +++ b/types/three/examples/jsm/nodes/loaders/NodeObjectLoader.d.ts @@ -5,7 +5,5 @@ import { AnyJson } from '../core/constants'; export default class NodeObjectLoader extends ObjectLoader { parseNodes(json: AnyJson, textures: { [key: string]: Texture }): NodeLoaderResult; - // tslint:disable-next-line:comment-format - //@ts-expect-error parseMaterials(json: AnyJson, textures: { [key: string]: Texture }): { [key: string]: Material }; } diff --git a/types/three/test/integration/loaders-gltfloader-plugin.ts b/types/three/test/integration/loaders-gltfloader-plugin.ts index c3b725eac..7a3c94eb7 100644 --- a/types/three/test/integration/loaders-gltfloader-plugin.ts +++ b/types/three/test/integration/loaders-gltfloader-plugin.ts @@ -19,6 +19,7 @@ init().then(() => { class ExamplePlugin implements GLTFLoaderPlugin { parser: GLTFParser; + name = 'ExamplePlugin'; constructor(parser: GLTFParser) { this.parser = parser;