Skip to content

Commit

Permalink
feat: udpate code
Browse files Browse the repository at this point in the history
  • Loading branch information
cptbtptpbcptdtptp committed Jan 8, 2025
2 parents 1196bae + dcdfc1a commit 11e51cb
Show file tree
Hide file tree
Showing 11 changed files with 141 additions and 7 deletions.
55 changes: 55 additions & 0 deletions e2e/case/material-LUT.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
/**
* @title LUT Test
* @category Material
*/
import { Camera, Material, MeshRenderer, PrimitiveMesh, Shader, Vector3, WebGLEngine } from "@galacean/engine";
import { initScreenshot, updateForE2E } from "./.mockForE2E";

// Create engine
WebGLEngine.create({ canvas: "canvas" })
.then((engine) => {
engine.canvas.resizeByClientSize(2);

const scene = engine.sceneManager.activeScene;
const rootEntity = scene.createRootEntity();
// engine.run();

// Create camera
const cameraEntity = rootEntity.createChild("Camera");
cameraEntity.transform.position = new Vector3(0, 0, 3);
const camera = cameraEntity.addComponent(Camera);

const entity = rootEntity.createChild("Entity");
entity.transform.setRotation(90, 0, 0);
const renderer = entity.addComponent(MeshRenderer);
renderer.mesh = PrimitiveMesh.createPlane(engine, 1, 1);

const shader = Shader.create(
"LUT-test",
`
attribute vec3 POSITION;
attribute vec2 TEXCOORD_0;
uniform mat4 renderer_MVPMat;
varying vec2 v_uv;
void main(){
gl_Position = renderer_MVPMat * vec4(POSITION, 1.0);
v_uv = TEXCOORD_0;
}`,
`
varying vec2 v_uv;
uniform sampler2D scene_PrefilteredDFG;
void main(){
gl_FragColor = texture2D(scene_PrefilteredDFG, v_uv);
}
`
);
const material = new Material(engine, shader);
renderer.setMaterial(material);
updateForE2E(engine);
initScreenshot(engine, camera);
})
.catch((e) => {
console.log(e);
});
5 changes: 5 additions & 0 deletions e2e/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,11 @@ export const E2E_CONFIG = {
category: "Material",
caseFileName: "shaderLab-renderState",
threshold: 0.2
},
LUT: {
category: "Material",
caseFileName: "material-LUT",
threshold: 0.2
}
},
Shadow: {
Expand Down
3 changes: 3 additions & 0 deletions e2e/fixtures/originImage/Material_material-LUT.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
23 changes: 22 additions & 1 deletion packages/core/src/BasicResources.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { BufferUsage } from "./graphic/enums/BufferUsage";
import { MeshTopology } from "./graphic/enums/MeshTopology";
import { VertexElementFormat } from "./graphic/enums/VertexElementFormat";
import { Material } from "./material";
import { PrefilteredDFG } from "./material/utils/PrefilteredDFG";
import { ModelMesh } from "./mesh";
import { Shader } from "./shader/Shader";
import { BlendFactor } from "./shader/enums/BlendFactor";
Expand Down Expand Up @@ -116,7 +117,13 @@ export class BasicResources {
readonly textDefaultMaterial: Material;
readonly spriteMaskDefaultMaterial: Material;

constructor(engine: Engine) {
private _prefilteredDFGTexture: Texture2D;

get prefilteredDFGTexture(): Texture2D {
return this._prefilteredDFGTexture;
}

constructor(public engine: Engine) {
// prettier-ignore
const vertices = new Float32Array([
-1, -1, 0, 1, // left-bottom
Expand Down Expand Up @@ -167,6 +174,20 @@ export class BasicResources {
this.spriteMaskDefaultMaterial = this._createSpriteMaskMaterial(engine);
}

/**
* @internal
*/
_initialize(): Promise<BasicResources> {
return new Promise((resolve, reject) => {
PrefilteredDFG.create(this.engine)
.then((texture) => {
this._prefilteredDFGTexture = texture;
resolve(this);
})
.catch(reject);
});
}

private _createBlitMesh(engine: Engine, vertices: Float32Array): ModelMesh {
const mesh = new ModelMesh(engine);
mesh._addReferCount(1);
Expand Down
2 changes: 2 additions & 0 deletions packages/core/src/Engine.ts
Original file line number Diff line number Diff line change
Expand Up @@ -644,6 +644,8 @@ export class Engine extends EventDispatcher {
const loader = loaders[key];
if (loader.initialize) initializePromises.push(loader.initialize(this, configuration));
}

initializePromises.push(this._basicResources._initialize());
return Promise.all(initializePromises).then(() => this);
}

Expand Down
2 changes: 2 additions & 0 deletions packages/core/src/Scene.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import { ShadowType } from "./shadow/enum/ShadowType";
export class Scene extends EngineObject {
private static _fogColorProperty = ShaderProperty.getByName("scene_FogColor");
private static _fogParamsProperty = ShaderProperty.getByName("scene_FogParams");
private static _prefilterdDFGProperty = ShaderProperty.getByName("scene_PrefilteredDFG");

/** Scene name. */
name: string;
Expand Down Expand Up @@ -285,6 +286,7 @@ export class Scene extends EngineObject {
shaderData.enableMacro("SCENE_SHADOW_CASCADED_COUNT", this.shadowCascades.toString());
shaderData.setColor(Scene._fogColorProperty, this._fogColor);
shaderData.setVector4(Scene._fogParamsProperty, this._fogParams);
shaderData.setTexture(Scene._prefilterdDFGProperty, engine._basicResources.prefilteredDFGTexture);

this._computeLinearFogParams(this._fogStart, this._fogEnd);
this._computeExponentialFogParams(this._fogDensity);
Expand Down
46 changes: 46 additions & 0 deletions packages/core/src/material/utils/PrefilteredDFG.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import { ContentRestorer } from "../../asset/ContentRestorer";
import { Logger } from "../../base";
import { Engine } from "../../Engine";
import { TextureFormat, TextureWrapMode } from "../../texture";
import { Texture2D } from "../../texture/Texture2D";

export class PrefilteredDFG {
private static _size = 256;
private static _base64 = ``;

static create(engine: Engine): Promise<Texture2D> {
return new Promise((resolve, reject) => {
const texture = new Texture2D(engine, PrefilteredDFG._size, PrefilteredDFG._size, TextureFormat.R8G8B8, false);
texture.wrapModeU = texture.wrapModeV = TextureWrapMode.Clamp;
texture.isGCIgnored = true;

const image = new Image();

image.onload = () => {
texture.setImageSource(image);
resolve(texture);
};

image.onerror = image.onabort = () => {
const message = "Failed to load prefiltered LUT image.";
Logger.error(message);
reject(message);
};

image.src = PrefilteredDFG._base64;

engine.resourceManager.addContentRestorer(
new (class extends ContentRestorer<Texture2D> {
constructor() {
super(texture);
}
restoreContent() {
texture.setImageSource(image);
}
})()
);

return texture;
});
}
}
2 changes: 1 addition & 1 deletion packages/physics-physx/libs/physx.release.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion packages/physics-physx/src/PhysXPhysics.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ export class PhysXPhysics implements IPhysics {
if (runtimeMode == PhysXRuntimeMode.JavaScript) {
script.src = `https://mdn.alipayobjects.com/rms/afts/file/A*CfV8RrDQk5oAAAAAAAAAAAAAARQnAQ/physx.release.downgrade.js`;
} else if (runtimeMode == PhysXRuntimeMode.WebAssembly) {
script.src = `https://mdn.alipayobjects.com/rms/afts/file/A*LRfCQ4VcCFQAAAAAAAAAAAAAARQnAQ/physx.release.js`;
script.src = `https://mdn.alipayobjects.com/rms/afts/file/A*ZDDgR4ERdfwAAAAAAAAAAAAAARQnAQ/physx.release.js`;
}
});

Expand Down
6 changes: 3 additions & 3 deletions packages/shader-shaderlab/src/shaders/shadingPBR/BRDF.glsl
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
#endif

#ifdef MATERIAL_ENABLE_SHEEN
sampler2D scene_prefilteredLUT;
sampler2D scene_PrefilteredDFG;
#endif

struct SurfaceData{
Expand Down Expand Up @@ -353,9 +353,9 @@ vec3 BRDF_Diffuse_Lambert(vec3 diffuseColor) {

float prefilteredSheenDFG(float dotNV, float sheenRoughness) {
#ifdef HAS_TEX_LOD
return texture2DLodEXT(scene_prefilteredLUT, vec2(dotNV, sheenRoughness), 0.0).b;
return texture2DLodEXT(scene_PrefilteredDFG, vec2(dotNV, sheenRoughness), 0.0).b;
#else
return texture2D(scene_prefilteredLUT, vec2(dotNV, sheenRoughness),0.0).b;
return texture2D(scene_PrefilteredDFG, vec2(dotNV, sheenRoughness),0.0).b;
#endif
}
#endif
Expand Down
Loading

0 comments on commit 11e51cb

Please sign in to comment.