UNPKG

react-native-filament

Version:

A real-time physically based 3D rendering engine for React Native

146 lines (132 loc) 6.38 kB
import { RNFCamera } from './Camera' import { SurfaceProvider } from '../native/FilamentViewTypes' import { Renderer } from './Renderer' import { Scene } from './Scene' import { View } from './View' import { FilamentBuffer } from '../native/FilamentBuffer' import { FilamentAsset } from './FilamentAsset' import { TransformManager } from './TransformManager' import { RenderableManager } from './RenderableManager' import { Material } from './Material' import { LightManager } from './LightManager' import { PointerHolder } from './PointerHolder' import { TFilamentRecorder } from './FilamentRecorder' import { SwapChain } from './SwapChain' import { NameComponentManager } from './NameComponentManager' import { CameraManipulator, OrbitCameraManipulatorConfig } from './CameraManipulator' export interface Engine extends PointerHolder { setSurfaceProvider(surfaceProvider: SurfaceProvider): void // TODO: Document createSwapChainForSurface(surface: SurfaceProvider, enableTransparentRendering: boolean): SwapChain // TODO: Document createSwapChainForRecorder(recorder: TFilamentRecorder): SwapChain setSwapChain(swapChain: SwapChain): void /** * Given a {@linkcode FilamentBuffer} (e.g. from a .glb file), load the asset into the engine. */ loadAsset(buffer: FilamentBuffer): FilamentAsset /** * Given a @see FilamentBuffer (e.g. from a .glb file), load the asset into the engine. * It will create multiple instances of the asset. */ loadInstancedAsset(buffer: FilamentBuffer, instanceCount: number): FilamentAsset /** * Set the indirect light for the scene. * @param iblBuffer A buffer containing the IBL data (e.g. from a .ktx file) * @param intensity The intensity of the indirect light. Default: 30_000 * @param irradianceBands Number of spherical harmonics bands. Must be 1, 2 or 3. Default: 3 */ setIndirectLight(iblBuffer: FilamentBuffer, intensity: number | undefined, irradianceBands: number | undefined): void /** * Given a @see FilamentBuffer (e.g. from a .glb file), load the asset into the engine. * This will by default add all entities from the asset to the attached default scene. * @worklet */ loadAsset(buffer: FilamentBuffer): FilamentAsset createRenderer(): Renderer getScene(): Scene getCamera(): RNFCamera getView(): View createOrbitCameraManipulator(config: OrbitCameraManipulatorConfig): CameraManipulator /** * @private */ createNameComponentManager(): NameComponentManager /** * Per engine instance you only need one {@linkcode TransformManager}. * You should never need to call this manually, use instead from `useFilamentContext()`. */ createTransformManager(): TransformManager /** * Per engine instance you only need one {@linkcode RenderableManager}. * You should never need to call this manually, use instead from `useFilamentContext()`. */ createRenderableManager(): RenderableManager /** * Per engine instance you only need one {@linkcode LightManager}. * You should never need to call this manually, use instead from `useFilamentContext()`. */ createLightManager(): LightManager /** * Creates a new material from the given FilamentBuffer. * @worklet */ createMaterial(matcBuffer: FilamentBuffer): Material /** * Skybox * * When added to a Scene, the Skybox fills all untouched pixels. * By default the scene has no skybox and will be rendered as translucent. * When using a skybox make sure to pass {@linkcode enableTransparentRendering} as false. * * @param showSun Indicates whether the sun should be rendered. The sun can only be * rendered if there is at least one light of type SUN in the scene. * Default: false * @param envIntensity Skybox intensity when no IndirectLight is set on the Scene. * This call is ignored when an IndirectLight is set on the Scene, and the intensity * of the IndirectLight is used instead. * Scale factor applied to the skybox texel values such that * the result is in lux, or lumen/m^2 (default = 30000) **/ createAndSetSkyboxByColor: (colorInHex: string, showSun: boolean | undefined, envIntensity: number | undefined) => void /** * Skybox * * When added to a Scene, the Skybox fills all untouched pixels. * By default the scene has no skybox and will be rendered as translucent. * When using a skybox make sure to pass {@linkcode enableTransparentRendering} as false. * * @param showSun Indicates whether the sun should be rendered. The sun can only be * rendered if there is at least one light of type SUN in the scene. * Default: false * @param envIntensity Skybox intensity when no IndirectLight is set on the Scene. * This call is ignored when an IndirectLight is set on the Scene, and the intensity * of the IndirectLight is used instead. * Scale factor applied to the skybox texel values such that * the result is in lux, or lumen/m^2 (default = 30000) **/ createAndSetSkyboxByTexture: (buffer: FilamentBuffer, showSun: boolean | undefined, envIntensity: number | undefined) => void /** * Removed the skybox from the scene. */ clearSkybox: () => void /** * Enables or disables automatic instancing of render primitives. Instancing of render * primitives can greatly reduce CPU overhead but requires the instanced primitives to be * identical (i.e. use the same geometry) and use the same MaterialInstance. If it is known * that the scene doesn't contain any identical primitives, automatic instancing can have some * overhead and it is then best to disable it. * * Disabled by default. * * @param enable true to enable, false to disable automatic instancing. */ setAutomaticInstancingEnabled(enabled: boolean): void /** * Kicks the hardware thread (e.g. the OpenGL, Vulkan or Metal thread) and blocks until * all commands to this point are executed. Note that does guarantee that the * hardware is actually finished. * Note: during on screen rendering this is handled automatically, typically used for offscreen rendering (recording). */ flushAndWait(): void }