rayzee 4.8.12 → 4.8.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/dist/rayzee.es.js +48 -48
- package/dist/rayzee.es.js.map +1 -1
- package/dist/rayzee.umd.js +3 -3
- package/dist/rayzee.umd.js.map +1 -1
- package/package.json +1 -1
- package/src/Processor/AssetLoader.js +1 -1
- package/src/TSL/BVHTraversal.js +2 -1
- package/src/TSL/LightsDirect.js +8 -4
package/README.md
CHANGED
|
@@ -540,6 +540,30 @@ OIDN provides high-quality AI denoising for final renders. It runs automatically
|
|
|
540
540
|
|
|
541
541
|
## Troubleshooting
|
|
542
542
|
|
|
543
|
+
**OIDN: `Cannot find module './tza'` (webpack)**
|
|
544
|
+
The `oidn-web` package uses dynamic imports that webpack cannot resolve. This does not affect Vite or other ESM-native bundlers. Add `oidn-web` to your webpack externals:
|
|
545
|
+
|
|
546
|
+
```js
|
|
547
|
+
// webpack.config.js
|
|
548
|
+
module.exports = {
|
|
549
|
+
externals: {
|
|
550
|
+
'oidn-web': 'oidn-web'
|
|
551
|
+
}
|
|
552
|
+
};
|
|
553
|
+
```
|
|
554
|
+
|
|
555
|
+
Then load it via a script tag or import map instead:
|
|
556
|
+
|
|
557
|
+
```html
|
|
558
|
+
<script type="importmap">
|
|
559
|
+
{
|
|
560
|
+
"imports": {
|
|
561
|
+
"oidn-web": "https://cdn.jsdelivr.net/npm/oidn-web@0.3.0/+esm"
|
|
562
|
+
}
|
|
563
|
+
}
|
|
564
|
+
</script>
|
|
565
|
+
```
|
|
566
|
+
|
|
543
567
|
**Black screen / "WebGPU not supported"**
|
|
544
568
|
Your browser may not support WebGPU. Use Chrome 113+, Edge 113+, Safari 18+, or Firefox 141+. Ensure you're on HTTPS or localhost.
|
|
545
569
|
|
package/dist/rayzee.es.js
CHANGED
|
@@ -2181,10 +2181,10 @@ var Xr = X("\n fn constructTBN( N: vec3f ) -> mat3x3f {\n\n var majorAxis: vec3
|
|
|
2181
2181
|
let t = z(1).sub(o).sub(s), r = $(n, a, B(6), B(ui)), c = $(n, a, B(7), B(ui));
|
|
2182
2182
|
i.uv.assign(r.xy.mul(t).add(r.zw.mul(o)).add(c.xy.mul(s))), i.triangleIndex.assign(a);
|
|
2183
2183
|
}), i;
|
|
2184
|
-
}), bi = M(([e, t, n, r]) => {
|
|
2185
|
-
let
|
|
2184
|
+
}), bi = M(([e, t, n, r, i]) => {
|
|
2185
|
+
let a = Tr({
|
|
2186
2186
|
didHit: !1,
|
|
2187
|
-
dst:
|
|
2187
|
+
dst: i,
|
|
2188
2188
|
hitPoint: J(0),
|
|
2189
2189
|
normal: J(0),
|
|
2190
2190
|
uv: q(0),
|
|
@@ -2192,62 +2192,62 @@ var Xr = X("\n fn constructTBN( N: vec3f ) -> mat3x3f {\n\n var majorAxis: vec3
|
|
|
2192
2192
|
meshIndex: B(-1),
|
|
2193
2193
|
boxTests: B(0),
|
|
2194
2194
|
triTests: B(0)
|
|
2195
|
-
}).toVar(),
|
|
2196
|
-
|
|
2197
|
-
let
|
|
2198
|
-
return P(
|
|
2199
|
-
|
|
2200
|
-
let
|
|
2201
|
-
N(
|
|
2202
|
-
N(
|
|
2203
|
-
let t = B(
|
|
2195
|
+
}).toVar(), o = fi(), s = B(1).toVar();
|
|
2196
|
+
o.element(B(0)).assign(B(0));
|
|
2197
|
+
let c = H(J(1), pt(e.direction), ct(e.direction, J(0))), l = H(J(1).div(e.direction), J(di).mul(c), nt(F(e.direction), J(1e-8))).toVar(), u = B(0).toVar();
|
|
2198
|
+
return P(s.greaterThan(B(0)).and(a.didHit.not()).and(u.lessThan(B(ci))), () => {
|
|
2199
|
+
u.addAssign(1), s.subAssign(1);
|
|
2200
|
+
let i = o.element(s).toVar(), c = $(t, i, B(0), B(li));
|
|
2201
|
+
N(c.w.lessThan(0), () => {
|
|
2202
|
+
N(c.w.greaterThan(z(-1.5)), () => {
|
|
2203
|
+
let t = B(c.x).toVar(), i = B(c.y).toVar();
|
|
2204
2204
|
P({
|
|
2205
2205
|
start: B(0),
|
|
2206
|
-
end:
|
|
2207
|
-
}, ({ i
|
|
2208
|
-
let o = t.add(
|
|
2206
|
+
end: i
|
|
2207
|
+
}, ({ i }) => {
|
|
2208
|
+
let o = t.add(i).toVar(), s = $(n, o, B(0), B(ui)).xyz, c = $(n, o, B(1), B(ui)).xyz, l = $(n, o, B(2), B(ui)).xyz, u = pi({
|
|
2209
2209
|
rayOrigin: e.origin,
|
|
2210
2210
|
rayDir: e.direction,
|
|
2211
2211
|
pA: s,
|
|
2212
2212
|
pB: c,
|
|
2213
2213
|
pC: l,
|
|
2214
|
-
closestHitDst:
|
|
2214
|
+
closestHitDst: a.dst
|
|
2215
2215
|
});
|
|
2216
2216
|
N(u.w.greaterThan(.5), () => {
|
|
2217
|
-
let t = $(n, o, B(7), B(ui)),
|
|
2218
|
-
N(gi(
|
|
2219
|
-
|
|
2217
|
+
let t = $(n, o, B(7), B(ui)), i = B(t.z);
|
|
2218
|
+
N(gi(i, r), () => {
|
|
2219
|
+
a.didHit.assign(!0), a.dst.assign(u.x), a.materialIndex.assign(i), a.meshIndex.assign(B(t.w)), a.hitPoint.assign(e.origin.add(e.direction.mul(u.x))), a.normal.assign(U(Xe(c.sub(s), l.sub(s)))), He();
|
|
2220
2220
|
});
|
|
2221
2221
|
});
|
|
2222
2222
|
});
|
|
2223
2223
|
}).Else(() => {
|
|
2224
|
-
let e = B(
|
|
2225
|
-
N(
|
|
2226
|
-
|
|
2224
|
+
let e = B(c.x).toVar();
|
|
2225
|
+
N(s.lessThan(B(si)), () => {
|
|
2226
|
+
o.element(s).assign(e), s.addAssign(1);
|
|
2227
2227
|
});
|
|
2228
2228
|
});
|
|
2229
2229
|
}).Else(() => {
|
|
2230
|
-
let n = $(t,
|
|
2230
|
+
let n = $(t, i, B(1), B(li)), r = $(t, i, B(2), B(li)), u = $(t, i, B(3), B(li)), d = B(c.w).toVar(), f = B(n.w).toVar(), p = mi({
|
|
2231
2231
|
rayOrigin: e.origin,
|
|
2232
|
-
invDir:
|
|
2233
|
-
boxMin:
|
|
2232
|
+
invDir: l,
|
|
2233
|
+
boxMin: c.xyz,
|
|
2234
2234
|
boxMax: n.xyz
|
|
2235
2235
|
}).toVar(), m = mi({
|
|
2236
2236
|
rayOrigin: e.origin,
|
|
2237
|
-
invDir:
|
|
2237
|
+
invDir: l,
|
|
2238
2238
|
boxMin: r.xyz,
|
|
2239
|
-
boxMax:
|
|
2239
|
+
boxMax: u.xyz
|
|
2240
2240
|
}).toVar();
|
|
2241
|
-
N(ot(p, m).lessThan(
|
|
2241
|
+
N(ot(p, m).lessThan(a.dst), () => {
|
|
2242
2242
|
let e = p.lessThan(m), t = W(e, d, f).toVar(), n = W(e, f, d).toVar();
|
|
2243
|
-
N(W(e, m, p).toVar().lessThan(
|
|
2244
|
-
|
|
2245
|
-
}), N(
|
|
2246
|
-
|
|
2243
|
+
N(W(e, m, p).toVar().lessThan(a.dst).and(s.lessThan(B(si))), () => {
|
|
2244
|
+
o.element(s).assign(n), s.addAssign(1);
|
|
2245
|
+
}), N(s.lessThan(B(si)), () => {
|
|
2246
|
+
o.element(s).assign(t), s.addAssign(1);
|
|
2247
2247
|
});
|
|
2248
2248
|
});
|
|
2249
2249
|
});
|
|
2250
|
-
}),
|
|
2250
|
+
}), a;
|
|
2251
2251
|
}), xi = M(([e, t, n, r, i, a, o, s, c, l, u]) => {
|
|
2252
2252
|
let d = J(e.xy, 1), f = r.mul(Y(d, 1)), p = U(at(n[0].xyz, n[1].xyz, n[2].xyz).mul(f.xyz.div(f.w))).toVar(), m = J(n[3]).toVar(), h = m.toVar(), g = p.toVar();
|
|
2253
2253
|
return N(i.and(a.greaterThan(0)).and(o.lessThan(64)).and(s.greaterThan(.001)), () => {
|
|
@@ -3228,7 +3228,7 @@ M(([e, t, n]) => {
|
|
|
3228
3228
|
}), r;
|
|
3229
3229
|
});
|
|
3230
3230
|
var qa = M(([e, t, n, r, i, a, o, s]) => {
|
|
3231
|
-
let c = z(1).toVar(), l = e.toVar();
|
|
3231
|
+
let c = z(1).toVar(), l = e.toVar(), u = z(n).toVar();
|
|
3232
3232
|
return P({
|
|
3233
3233
|
start: B(0),
|
|
3234
3234
|
end: B(8)
|
|
@@ -3236,25 +3236,25 @@ var qa = M(([e, t, n, r, i, a, o, s]) => {
|
|
|
3236
3236
|
let e = Cr({
|
|
3237
3237
|
origin: l,
|
|
3238
3238
|
direction: t
|
|
3239
|
-
}),
|
|
3240
|
-
N(
|
|
3239
|
+
}), n = Tr.wrap(i(e, a, o, s, u));
|
|
3240
|
+
N(n.didHit.not(), () => {
|
|
3241
3241
|
He();
|
|
3242
3242
|
});
|
|
3243
|
-
let
|
|
3244
|
-
N(
|
|
3245
|
-
let e = R(t,
|
|
3246
|
-
N(e.not().and(
|
|
3247
|
-
let e = tt(
|
|
3243
|
+
let r = wr.wrap(ii(n.materialIndex, s));
|
|
3244
|
+
N(r.transmission.greaterThan(0), () => {
|
|
3245
|
+
let e = R(t, n.normal).lessThan(0), i = W(e, n.normal, n.normal.negate());
|
|
3246
|
+
N(e.not().and(r.attenuationDistance.greaterThan(0)), () => {
|
|
3247
|
+
let e = tt(n.hitPoint.sub(l)), t = Ca(r.attenuationColor, r.attenuationDistance, e);
|
|
3248
3248
|
c.mulAssign(t.x.add(t.y).add(t.z).div(3));
|
|
3249
3249
|
});
|
|
3250
|
-
let
|
|
3251
|
-
c.mulAssign(
|
|
3250
|
+
let a = qi(F(R(t, i)), Zi(r.ior, z(1))), o = z(1).sub(a).mul(r.transmission);
|
|
3251
|
+
c.mulAssign(o), N(c.lessThan(.005), () => {
|
|
3252
3252
|
c.assign(0), He();
|
|
3253
|
-
}), l.assign(
|
|
3254
|
-
}).ElseIf(
|
|
3255
|
-
c.mulAssign(z(1).sub(
|
|
3253
|
+
}), l.assign(n.hitPoint.add(t.mul(.001))), u.subAssign(n.dst.add(.001));
|
|
3254
|
+
}).ElseIf(r.transparent, () => {
|
|
3255
|
+
c.mulAssign(z(1).sub(r.opacity)), N(c.lessThan(.005), () => {
|
|
3256
3256
|
c.assign(0), He();
|
|
3257
|
-
}), l.assign(
|
|
3257
|
+
}), l.assign(n.hitPoint.add(t.mul(.001))), u.subAssign(n.dst.add(.001));
|
|
3258
3258
|
}).Else(() => {
|
|
3259
3259
|
c.assign(0), He();
|
|
3260
3260
|
});
|
|
@@ -11011,7 +11011,7 @@ var oc = class extends fn {
|
|
|
11011
11011
|
e.traverse((e) => {
|
|
11012
11012
|
let n = e.userData;
|
|
11013
11013
|
if (e.isRectAreaLight && !t.includes(e.uuid) && t.push(e.uuid), e.name.startsWith("RectAreaLightPlaceholder") && n.name && n.type === "RectAreaLight") {
|
|
11014
|
-
let r = new we(new v(...n.color), n.intensity, n.width, n.height);
|
|
11014
|
+
let r = new we(new v(...n.color), n.intensity / Math.PI, n.width, n.height);
|
|
11015
11015
|
r.position.z = -2, r.name = n.name, e.add(r), t.push(r.uuid);
|
|
11016
11016
|
}
|
|
11017
11017
|
if (e.isMesh && Array.isArray(e.material)) {
|