UNPKG

playcanvas

Version:

PlayCanvas WebGL game engine

76 lines (73 loc) 3.05 kB
import { BINDGROUP_VIEW } from './constants.js'; /** * @import { BindGroupFormat } from './bind-group-format.js' * @import { GraphicsDevice } from './graphics-device.js' * @import { UniformBufferFormat } from './uniform-buffer-format.js' * @import { VertexFormat } from './vertex-format.js' */ /** * Options to drive shader processing to add support for bind groups and uniform buffers. * * @ignore */ class ShaderProcessorOptions { /** * Constructs shader processing options, used to process the shader for uniform buffer support. * * @param {UniformBufferFormat} [viewUniformFormat] - Format of the uniform buffer. * @param {BindGroupFormat} [viewBindGroupFormat] - Format of the bind group. * @param {VertexFormat} [vertexFormat] - Format of the vertex buffer. */ constructor(viewUniformFormat, viewBindGroupFormat, vertexFormat){ /** @type {UniformBufferFormat[]} */ this.uniformFormats = []; /** @type {BindGroupFormat[]} */ this.bindGroupFormats = []; // construct a sparse array this.uniformFormats[BINDGROUP_VIEW] = viewUniformFormat; this.bindGroupFormats[BINDGROUP_VIEW] = viewBindGroupFormat; this.vertexFormat = vertexFormat; } /** * Get the bind group index for the uniform name. * * @param {string} name - The name of the uniform. * @returns {boolean} - Returns true if the uniform exists, false otherwise. */ hasUniform(name) { for(let i = 0; i < this.uniformFormats.length; i++){ const uniformFormat = this.uniformFormats[i]; if (uniformFormat?.get(name)) { return true; } } return false; } /** * Get the bind group texture slot for the texture uniform name. * * @param {string} name - The name of the texture uniform. * @returns {boolean} - Returns true if the texture uniform exists, false otherwise. */ hasTexture(name) { for(let i = 0; i < this.bindGroupFormats.length; i++){ const groupFormat = this.bindGroupFormats[i]; if (groupFormat?.getTexture(name)) { return true; } } return false; } getVertexElement(semantic) { return this.vertexFormat?.elements.find((element)=>element.name === semantic); } /** * Generate unique key representing the processing options. * * @param {GraphicsDevice} device - The device. * @returns {string} - Returns the key. */ generateKey(device) { // TODO: Optimize. Uniform and BindGroup formats should have their keys evaluated in their // constructors, and here we should simply concatenate those. let key = JSON.stringify(this.uniformFormats) + JSON.stringify(this.bindGroupFormats); // WebGPU shaders are processed per vertex format if (device.isWebGPU) { key += this.vertexFormat?.shaderProcessingHashString; } return key; } } export { ShaderProcessorOptions };