UNPKG

@babylonjs/core

Version:

Getting started? Play directly with the Babylon.js API using our [playground](https://playground.babylonjs.com/). It also contains a lot of samples to learn how to use it.

37 lines (36 loc) 1.69 kB
import type { VertexBuffer, Buffer } from "../Buffers/buffer"; import type { ThinEngine } from "../Engines/thinEngine"; import type { Effect } from "../Materials/effect"; import type { IGPUParticleSystemPlatform } from "./IGPUParticleSystemPlatform"; import type { GPUParticleSystem } from "./gpuParticleSystem"; import type { DataArray, Nullable } from "../types"; import type { DataBuffer } from "../Buffers/dataBuffer"; import { UniformBufferEffectCommonAccessor } from "../Materials/uniformBufferEffectCommonAccessor"; import "../Shaders/gpuUpdateParticles.fragment"; import "../Shaders/gpuUpdateParticles.vertex"; /** @internal */ export declare class WebGL2ParticleSystem implements IGPUParticleSystemPlatform { private _parent; private _engine; private _updateEffect; private _updateEffectOptions; private _renderVAO; private _updateVAO; private _renderVertexBuffers; readonly alignDataInBuffer = false; constructor(parent: GPUParticleSystem, engine: ThinEngine); contextLost(): void; isUpdateBufferCreated(): boolean; isUpdateBufferReady(): boolean; createUpdateBuffer(defines: string): UniformBufferEffectCommonAccessor; createVertexBuffers(updateBuffer: Buffer, renderVertexBuffers: { [key: string]: VertexBuffer; }): void; createParticleBuffer(data: number[]): DataArray | DataBuffer; bindDrawBuffers(index: number, effect: Effect, indexBuffer: Nullable<DataBuffer>): void; preUpdateParticleBuffer(): void; updateParticleBuffer(index: number, targetBuffer: Buffer, currentActiveCount: number): void; releaseBuffers(): void; releaseVertexBuffers(): void; private _createUpdateVAO; }