matrix-engine-wgpu
Version:
obj sequence anim +HOTFIX raycast, webGPU powered pwa application. Crazy fast rendering with AmmoJS physics support. Simple raycaster hit object added.
51 lines (42 loc) • 1.63 kB
JavaScript
export let fragmentVideoWGSL = `override shadowDepthTextureSize: f32 = 1024.0;
struct Scene {
lightViewProjMatrix : mat4x4f,
cameraViewProjMatrix : mat4x4f,
lightPos : vec3f,
}
var<uniform> scene : Scene;
var shadowMap: texture_depth_2d;
var shadowSampler: sampler_comparison;
var meshTexture: texture_external;
var meshSampler: sampler;
// ❌ No binding(4) here!
struct FragmentInput {
shadowPos : vec3f,
fragPos : vec3f,
fragNorm : vec3f,
uv : vec2f,
}
const albedo = vec3f(0.9);
const ambientFactor = 0.7;
fn main(input : FragmentInput) -> vec4f {
// Shadow filtering
var visibility = 0.0;
let oneOverShadowDepthTextureSize = 1.0 / shadowDepthTextureSize;
for (var y = -1; y <= 1; y++) {
for (var x = -1; x <= 1; x++) {
let offset = vec2f(vec2(x, y)) * oneOverShadowDepthTextureSize;
visibility += textureSampleCompare(
shadowMap, shadowSampler,
input.shadowPos.xy + offset, input.shadowPos.z - 0.007
);
}
}
visibility /= 9.0;
let lambertFactor = max(dot(normalize(scene.lightPos - input.fragPos), normalize(input.fragNorm)), 0.0);
let lightingFactor = min(ambientFactor + visibility * lambertFactor, 1.0);
// ✅ Correct way to sample video texture
let textureColor = textureSampleBaseClampToEdge(meshTexture, meshSampler, input.uv);
return vec4(textureColor.rgb * lightingFactor * albedo, 1.0);
}
`;