Skip to content

Commit

Permalink
Ibl / environment map support
Browse files Browse the repository at this point in the history
  • Loading branch information
4eb0da authored Aug 21, 2024
1 parent b7d7b65 commit 6f500ec
Show file tree
Hide file tree
Showing 5 changed files with 1,074 additions and 63 deletions.
1 change: 1 addition & 0 deletions docs/preview/preview.html
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
<label>Skeleton nodes <select id="skeleton" disabled><option value="*">All</option></select></label>
</fieldset>
<label>Shadow <input type="checkbox" id="shadow" checked></label>
<label>IBL <input type="checkbox" id="ibl" checked></label>
</div>
</div>
<script src="dist/main.js"></script>
Expand Down
25 changes: 18 additions & 7 deletions docs/preview/preview.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { decodeDds, parseHeaders } from 'dds-parser';
import { parse as parseMDL } from '../../mdl/parse';
import { parse as parseMDX } from '../../mdx/parse';
import { Model, TextureFlags } from '../../model';
import { ModelRenderer } from '../../renderer/modelRenderer';
import { DDS_FORMAT, ModelRenderer } from '../../renderer/modelRenderer';
import { vec3RotateZ } from '../../renderer/util';
import { decode, getImageData } from '../../blp/decode';
import '../common/shim';
Expand Down Expand Up @@ -37,6 +37,7 @@ let wireframe = false;
let showSkeleton = false;
let skeletonNodes: string[] | null = null;
let shadow = true;
let ibl = true;

const cameraBasePos: vec3 = vec3.create();
const cameraPos: vec3 = vec3.create();
Expand Down Expand Up @@ -151,7 +152,7 @@ function calcCameraQuat(cameraPos: vec3, cameraTarget: vec3): quat {

function drawScene() {
gl.depthMask(true);
mat4.perspective(pMatrix, Math.PI / 4, canvas.width / canvas.height, 0.1, 2000.0);
mat4.perspective(pMatrix, Math.PI / 4, canvas.width / canvas.height, 0.1, 3000.0);

vec3.set(
cameraBasePos,
Expand All @@ -173,7 +174,7 @@ function drawScene() {

const cameraQuat: quat = calcCameraQuat(cameraPos, cameraTarget);
const lightQuat: quat = calcCameraQuat(lightPosition, lightTarget);

modelRenderer.setLightPosition(lightPosition);
modelRenderer.setLightColor(lightColor);

Expand All @@ -194,8 +195,12 @@ function drawScene() {
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);

modelRenderer.setCamera(cameraPos, cameraQuat);
if (ibl) {
modelRenderer.renderEnvironment(mvMatrix, pMatrix);
}
modelRenderer.render(mvMatrix, pMatrix, {
wireframe,
useEnvironmentMap: ibl,
shadowMapTexture: shadow ? framebufferDepthTexture : undefined,
shadowMapMatrix: shadow ? shadowMapMatrix : undefined,
shadowBias: 1e-6,
Expand All @@ -213,7 +218,7 @@ function tick(timestamp: number) {
drawScene();
}

function loadTexture(src: string, textureName: string, flags: TextureFlags) {
function loadTexture(src: string, textureName: string, flags: TextureFlags | 0) {
const img = new Image();

img.onload = () => {
Expand Down Expand Up @@ -337,6 +342,12 @@ function initControls() {
shadow = shadowCheck.checked;
});

const iblCheck = document.getElementById('ibl') as HTMLInputElement;
ibl = iblCheck.checked;
iblCheck.addEventListener('input', () => {
ibl = iblCheck.checked;
});

const readSkeletonNodes = (value: string) => {
const val = value.trim();

Expand Down Expand Up @@ -420,8 +431,8 @@ function initCameraMove() {
if (cameraTheta > Math.PI / 2 * 0.98) {
cameraTheta = Math.PI / 2 * 0.98;
}
if (cameraTheta < 0) {
cameraTheta = 0;
if (cameraTheta < -Math.PI / 2 * 0.98) {
cameraTheta = -Math.PI / 2 * 0.98;
}

downX = x;
Expand Down Expand Up @@ -601,7 +612,7 @@ function initDragDrop() {
if (format) {
modelRenderer.setTextureCompressedImage(
textureName,
format,
format as DDS_FORMAT,
reader.result as ArrayBuffer,
dds,
textureFlags
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "war3-model",
"version": "3.1.2",
"version": "3.2.0",
"description": "Warcraft 3 model parser, generator, convertor and previewer",
"keywords": [
"warcraft3",
Expand Down
Loading

0 comments on commit 6f500ec

Please sign in to comment.