@animech-public/playcanvas
Version:
PlayCanvas WebGL game engine
87 lines (85 loc) • 2.5 kB
JavaScript
class FrameGraph {
constructor() {
this.renderPasses = [];
this.renderTargetMap = new Map();
}
addRenderPass(renderPass) {
renderPass.frameUpdate();
const beforePasses = renderPass.beforePasses;
for (let i = 0; i < beforePasses.length; i++) {
const pass = beforePasses[i];
if (pass.enabled) {
this.addRenderPass(pass);
}
}
if (renderPass.enabled) {
this.renderPasses.push(renderPass);
}
const afterPasses = renderPass.afterPasses;
for (let i = 0; i < afterPasses.length; i++) {
const pass = afterPasses[i];
if (pass.enabled) {
this.addRenderPass(pass);
}
}
}
reset() {
this.renderPasses.length = 0;
}
compile() {
const renderTargetMap = this.renderTargetMap;
const renderPasses = this.renderPasses;
for (let i = 0; i < renderPasses.length; i++) {
const renderPass = renderPasses[i];
const renderTarget = renderPass.renderTarget;
if (renderTarget !== undefined) {
const prevPass = renderTargetMap.get(renderTarget);
if (prevPass) {
const count = renderPass.colorArrayOps.length;
for (let j = 0; j < count; j++) {
const colorOps = renderPass.colorArrayOps[j];
if (!colorOps.clear) {
prevPass.colorArrayOps[j].store = true;
}
}
if (!renderPass.depthStencilOps.clearDepth) {
prevPass.depthStencilOps.storeDepth = true;
}
if (!renderPass.depthStencilOps.clearStencil) {
prevPass.depthStencilOps.storeStencil = true;
}
}
renderTargetMap.set(renderTarget, renderPass);
}
}
let lastCubeTexture = null;
let lastCubeRenderPass = null;
for (let i = 0; i < renderPasses.length; i++) {
const renderPass = renderPasses[i];
const renderTarget = renderPass.renderTarget;
const thisTexture = renderTarget == null ? void 0 : renderTarget.colorBuffer;
if (thisTexture != null && thisTexture.cubemap) {
if (lastCubeTexture === thisTexture) {
const count = lastCubeRenderPass.colorArrayOps.length;
for (let j = 0; j < count; j++) {
lastCubeRenderPass.colorArrayOps[j].mipmaps = false;
}
}
lastCubeTexture = renderTarget.colorBuffer;
lastCubeRenderPass = renderPass;
} else if (renderPass.requiresCubemaps) {
lastCubeTexture = null;
lastCubeRenderPass = null;
}
}
renderTargetMap.clear();
}
render(device) {
this.compile();
const renderPasses = this.renderPasses;
for (let i = 0; i < renderPasses.length; i++) {
renderPasses[i].render();
}
}
}
export { FrameGraph };