Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Wind Waker: Particle system improvements #739

Merged
merged 25 commits into from
Jan 4, 2025
Merged
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
68f7dc7
Wind Waker: Split dPa_control_c init into common and scene
themikelester Jan 1, 2025
3c32a75
Wind Waker: Replace Particle.ts EffectDrawGroup with ParticleGroup
themikelester Jan 1, 2025
c166533
JPA: Fix misplaced `workData.volumeEmitCount = this.emitCount`
themikelester Jan 1, 2025
ee2103d
Wind Waker: Introducing "simple" emitters
themikelester Jan 1, 2025
8b055af
Wind Waker: "Simple" particles can now access the framebuffer
themikelester Jan 1, 2025
0571751
Wind Waker: Fix common particles spawning once on scene creation
themikelester Jan 1, 2025
2f74099
Formatting improvements
themikelester Jan 1, 2025
ab74ba4
Wind Waker: d_a_ep now uses simple particles
themikelester Jan 1, 2025
03ccde5
Wind Waker: Small note regarding simple particles ignoring emitter tr…
themikelester Jan 3, 2025
a70ff02
Wind Waker: Remove indirect particle hack
themikelester Jan 3, 2025
2f587b1
Wind Waker: Simple particle emitters are cleared every frame
themikelester Jan 3, 2025
ccc5706
Wind Waker: Fixup d_a_ep (torch) actor. The default state now matches…
themikelester Jan 3, 2025
eb9f410
Wind Waker: Allow type 2 d_a_ep to render flames
themikelester Jan 3, 2025
aa99a35
Wind Waker: Explicit return types for d_particle functions
themikelester Jan 3, 2025
2c1e8f7
Wind Waker: Fixed TODO - d_a_obj_flame now uses simple particle emitters
themikelester Jan 3, 2025
8c65343
Wind Waker: Remove old `patchResData` indirect particles hack
themikelester Jan 3, 2025
07df049
Wind Waker: Add frustum culling for simple emitters
themikelester Jan 3, 2025
d830542
Wind Waker: Don't distance cull 2D/UI particle emitters
themikelester Jan 3, 2025
b09e553
J2D: Add `J2DGrafContext.getFrustumForView()`
themikelester Jan 3, 2025
ca3419e
Wind Waker: Draw 2D/UI particle groups with ortho view/proj matrices
themikelester Jan 3, 2025
8740623
Wind Waker: Implement first 2D emitter for d_a_title
themikelester Jan 3, 2025
fe73bef
Wind Waker: Add sparkle emitter to d_a_title
themikelester Jan 3, 2025
a88d2c1
Wind Waker: Add new drawlists for fore/background 2D particles
themikelester Jan 3, 2025
d39b97a
Wind Waker: Don't frustum cull 2D particles
themikelester Jan 4, 2025
b1099c1
Wind Waker: Use computeModelMatrixT to avoid list creation
themikelester Jan 4, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
JPA: Fix misplaced workData.volumeEmitCount = this.emitCount
Now `workData.volumeEmitCount` is always valid when it should be
  • Loading branch information
themikelester committed Jan 1, 2025
commit c1665333495f1b75e8e18ff881490ce4238c99c2
5 changes: 3 additions & 2 deletions src/Common/JSYSTEM/JPA.ts
Original file line number Diff line number Diff line change
@@ -1711,7 +1711,7 @@ export class JPABaseEmitter {
throw "whoops";
}

private createParticle(): JPABaseParticle | null {
public createParticle(): JPABaseParticle | null {
if (this.emitterManager.deadParticlePool.length === 0)
return null;

@@ -1736,7 +1736,6 @@ export class JPABaseEmitter {
this.emitCount = bem1.divNumber * bem1.divNumber * 4 + 2;
else
this.emitCount = bem1.divNumber;
workData.volumeEmitCount = this.emitCount;
workData.volumeEmitIdx = 0;
} else {
// Rate
@@ -1748,6 +1747,8 @@ export class JPABaseEmitter {
this.emitCount = 1;
}

workData.volumeEmitCount = this.emitCount;

if (!!(this.status & JPAEmitterStatus.STOP_CREATE_PARTICLE))
this.emitCount = 0;