From 33cf94bb0015c114b9f20ba269d3aedf0c9738d4 Mon Sep 17 00:00:00 2001 From: Mike Lester Date: Fri, 3 Jan 2025 18:01:07 -0700 Subject: [PATCH] Wind Waker: Fix title demo not respecting camera fov and roll It should be in Cinematic mode, but it does not want letterboxing --- src/ZeldaWindWaker/Main.ts | 3 +-- src/ZeldaWindWaker/d_camera.ts | 7 +++++-- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/ZeldaWindWaker/Main.ts b/src/ZeldaWindWaker/Main.ts index 27d750ec8..1c41087c5 100644 --- a/src/ZeldaWindWaker/Main.ts +++ b/src/ZeldaWindWaker/Main.ts @@ -968,8 +968,7 @@ class DemoDesc extends SceneDesc implements Viewer.SceneDesc { if (demoData !== null) { globals.scnPlay.demo.create(this.id, demoData, this.offsetPos, this.rotY / 180.0 * Math.PI, this.startFrame); - if (globals.scnPlay.demo.getName() !== 'title') - globals.camera.snapToCinematic(); + globals.camera.snapToCinematic(); } else { console.warn('Failed to load demo data:', this.stbFilename); } diff --git a/src/ZeldaWindWaker/d_camera.ts b/src/ZeldaWindWaker/d_camera.ts index b7468b803..871ca7870 100644 --- a/src/ZeldaWindWaker/d_camera.ts +++ b/src/ZeldaWindWaker/d_camera.ts @@ -125,19 +125,22 @@ export class dCamera_c extends leafdraw_class { if (demoCam.flags & EDemoCamFlags.HasNearZ) { this.near = demoCam.projNear; } if (demoCam.flags & EDemoCamFlags.HasFarZ) { this.far = demoCam.projFar; } - this.cameraMode = (globals.scnPlay.demo.getName() == 'title') ? CameraMode.Default : CameraMode.Cinematic; + this.cameraMode = CameraMode.Cinematic; globals.sceneContext.inputManager.isMouseEnabled = false; } else { this.cameraMode = CameraMode.Default; globals.sceneContext.inputManager.isMouseEnabled = true; } + // From dCamera_c::SetTrimSize() and defaultTriming() + const trimSize = globals.scnPlay.demo.getName() != 'title' ? dCamera_c.trimHeightCinematic : 0; + // Adapted from dCamera_c::CalcTrimSize() // When switching between Cinematic and Regular camera modes (e.g. when pausing a cutscene), // blend the camera parameters smoothly. This accounts for deltaTime, but still works when paused. deltaTimeFrames = clamp(deltaTimeFrames, 0.5, 1); this.cameraModeBlendVal += (this.cameraMode - this.cameraModeBlendVal) * 0.25 * deltaTimeFrames; - this.trimHeight = lerp(0, dCamera_c.trimHeightCinematic, this.cameraModeBlendVal); + this.trimHeight = lerp(0, trimSize, this.cameraModeBlendVal); this.fovY = lerp(this.fovY, this.demoFov, this.cameraModeBlendVal); this.roll = lerp(this.roll, this.demoRoll, this.cameraModeBlendVal);