@needle-tools/materialx 1.2.1-next.f90216c → 1.2.2

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/CHANGELOG.md CHANGED
@@ -4,6 +4,9 @@ All notable changes to this package will be documented in this file.
4
4
  The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
5
5
  and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
6
6
 
7
+ ## [1.2.2] - 2025-07-24
8
+ - Add: `preloadWasm` function with support to wait for network idle. This is automatically done for Needle Engine projects.
9
+
7
10
  ## [1.2.1] - 2025-07-23
8
11
  - Fix: error caused by scene.environment being null
9
12
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@needle-tools/materialx",
3
- "version": "1.2.1-next.f90216c",
3
+ "version": "1.2.2",
4
4
  "type": "module",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
@@ -56,4 +56,4 @@
56
56
  "mtlx",
57
57
  "rendering"
58
58
  ]
59
- }
59
+ }
package/src/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- export { ready, type MaterialXContext } from "./materialx.js";
1
+ export { ready, type MaterialXContext, preloadWasm } from "./materialx.js";
2
2
  export { MaterialXMaterial } from "./materialx.material.js";
3
3
  export { MaterialXLoader } from "./loader/loader.three.js";
4
4
 
@@ -9,3 +9,4 @@ declare const Experimental_API: {
9
9
  };
10
10
 
11
11
  export { Experimental_API };
12
+
package/src/index.js CHANGED
@@ -1,11 +1,16 @@
1
- export { ready } from "./materialx.js";
1
+ import { createMaterialXMaterial } from "./loader/loader.three.js";
2
+
3
+ export { ready, preloadWasm } from "./materialx.js";
2
4
  export { MaterialXMaterial } from "./materialx.material.js";
3
5
  export { MaterialXLoader } from "./loader/loader.three.js";
4
6
 
5
- import { createMaterialXMaterial } from "./loader/loader.three.js";
6
7
 
8
+ /**
9
+ * Experimental API for creating MaterialX materials.
10
+ */
7
11
  const Experimental_API = {
8
12
  createMaterialXMaterial
9
- }
13
+ };
14
+
15
+ export { Experimental_API };
10
16
 
11
- export { Experimental_API }
@@ -1,6 +1,7 @@
1
1
  import { addCustomExtensionPlugin, Context } from "@needle-tools/engine";
2
2
  import { useNeedleMaterialX as _useNeedleMaterialX } from "./loader.three.js";
3
3
  import { debug } from "../utils.js";
4
+ import { preloadWasm } from "../materialx.js";
4
5
 
5
6
  /**
6
7
  * @typedef {import("@needle-tools/engine").INeedleGLTFExtensionPlugin} INeedleGLTFExtensionPlugin
@@ -58,5 +59,6 @@ export class MaterialXLoaderPlugin {
58
59
  * @returns {Promise<void>}
59
60
  */
60
61
  export async function useNeedleMaterialX() {
62
+ preloadWasm("network_idle");
61
63
  addCustomExtensionPlugin(new MaterialXLoaderPlugin());
62
64
  }
@@ -1,6 +1,8 @@
1
1
  import { Light, Scene, Texture, WebGLRenderer } from "three";
2
2
  import type { MaterialX as MX } from "./materialx.types.js";
3
3
 
4
+ export function preloadWasm(trigger: "immediately" | "network_idle"): Promise<void>;
5
+
4
6
  export type MaterialXContext = {
5
7
  getTime?(): number;
6
8
  getFrame?(): number;
package/src/materialx.js CHANGED
@@ -1,10 +1,27 @@
1
1
  import MaterialX from "../bin/JsMaterialXGenShader.js";
2
- import { debug } from "./utils.js";
2
+ import { debug, waitForNetworkIdle } from "./utils.js";
3
3
  import { renderPMREMToEquirect } from "./utils.texture.js";
4
4
  import { Light, Mesh, MeshBasicMaterial, Object3D, PlaneGeometry, PMREMGenerator, Scene, Texture, WebGLRenderer } from "three";
5
5
  import { registerLights, getLightData } from "./materialx.helper.js";
6
6
  import { whiteTexture } from "./utils.texture.js";
7
7
 
8
+
9
+ /**
10
+ * Preloads the MaterialX WebAssembly module.
11
+ * @type {import("./materialx.js").preloadWasm}
12
+ */
13
+ export async function preloadWasm(trigger) {
14
+ if (trigger === "immediately") {
15
+ // Load the WASM module immediately
16
+ return ready();
17
+ } else if (trigger === "network_idle") {
18
+ // Wait for network to be idle before loading
19
+ return waitForNetworkIdle().then(ready);
20
+ }
21
+ }
22
+
23
+
24
+
8
25
  export const state = new class {
9
26
  /** @type {import("./materialx.types.js").MaterialX.MODULE | null} */
10
27
  materialXModule = null;
package/src/utils.d.ts CHANGED
@@ -15,3 +15,6 @@ export function getTime(): number;
15
15
  * Get current frame number
16
16
  */
17
17
  export function getFrame(): number;
18
+
19
+
20
+ export function waitForNetworkIdle(): Promise<void>;
package/src/utils.js CHANGED
@@ -44,3 +44,16 @@ function updateTime() {
44
44
  }
45
45
 
46
46
  window.requestAnimationFrame(updateTime);
47
+
48
+
49
+
50
+
51
+ export async function waitForNetworkIdle() {
52
+ if (typeof requestIdleCallback !== "undefined") {
53
+ return new Promise(res => requestIdleCallback(res));
54
+ }
55
+ else {
56
+ console.debug("[MaterialX] Can not wait for network idle, using fallback");
57
+ return new Promise(res => setTimeout(res, 100)); // Fallback to a short delay
58
+ }
59
+ }
@@ -1,5 +1,7 @@
1
1
  import { WebGLRenderer, WebGLRenderTarget, Texture } from 'three';
2
2
 
3
+ export const whiteTexture: Texture;
4
+
3
5
  /**
4
6
  * Renders a PMREM environment map to an equirectangular texture with specified roughness
5
7
  */