@nexart/codemode-sdk 1.1.0 → 1.1.1
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 +109 -0
- package/CODE_MODE_PROTOCOL.md +312 -0
- package/README.md +200 -58
- package/dist/core-index.d.ts +21 -0
- package/dist/core-index.d.ts.map +1 -0
- package/dist/core-index.js +26 -0
- package/dist/execute.d.ts +46 -0
- package/dist/execute.d.ts.map +1 -0
- package/dist/execute.js +268 -0
- package/dist/index.d.ts +36 -17
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +43 -17
- package/dist/loop-engine.d.ts +4 -1
- package/dist/loop-engine.d.ts.map +1 -1
- package/dist/loop-engine.js +17 -12
- package/dist/noise-bridge.d.ts +44 -0
- package/dist/noise-bridge.d.ts.map +1 -0
- package/dist/noise-bridge.js +68 -0
- package/dist/noise-engine.d.ts +74 -0
- package/dist/noise-engine.d.ts.map +1 -0
- package/dist/noise-engine.js +132 -0
- package/dist/noise-sketches/fractalNoise.d.ts +11 -0
- package/dist/noise-sketches/fractalNoise.d.ts.map +1 -0
- package/dist/noise-sketches/fractalNoise.js +121 -0
- package/dist/noise-sketches/index.d.ts +21 -0
- package/dist/noise-sketches/index.d.ts.map +1 -0
- package/dist/noise-sketches/index.js +28 -0
- package/dist/p5-runtime.d.ts +56 -4
- package/dist/p5-runtime.d.ts.map +1 -1
- package/dist/p5-runtime.js +348 -22
- package/dist/sound-bridge.d.ts +89 -0
- package/dist/sound-bridge.d.ts.map +1 -0
- package/dist/sound-bridge.js +128 -0
- package/dist/soundart-engine.d.ts +87 -0
- package/dist/soundart-engine.d.ts.map +1 -0
- package/dist/soundart-engine.js +173 -0
- package/dist/soundart-sketches/chladniBloom.d.ts +3 -0
- package/dist/soundart-sketches/chladniBloom.d.ts.map +1 -0
- package/dist/soundart-sketches/chladniBloom.js +53 -0
- package/dist/soundart-sketches/dualVortex.d.ts +3 -0
- package/dist/soundart-sketches/dualVortex.d.ts.map +1 -0
- package/dist/soundart-sketches/dualVortex.js +67 -0
- package/dist/soundart-sketches/geometryIllusion.d.ts +3 -0
- package/dist/soundart-sketches/geometryIllusion.d.ts.map +1 -0
- package/dist/soundart-sketches/geometryIllusion.js +89 -0
- package/dist/soundart-sketches/index.d.ts +39 -0
- package/dist/soundart-sketches/index.d.ts.map +1 -0
- package/dist/soundart-sketches/index.js +72 -0
- package/dist/soundart-sketches/isoflow.d.ts +3 -0
- package/dist/soundart-sketches/isoflow.d.ts.map +1 -0
- package/dist/soundart-sketches/isoflow.js +60 -0
- package/dist/soundart-sketches/loomWeave.d.ts +3 -0
- package/dist/soundart-sketches/loomWeave.d.ts.map +1 -0
- package/dist/soundart-sketches/loomWeave.js +59 -0
- package/dist/soundart-sketches/noiseTerraces.d.ts +3 -0
- package/dist/soundart-sketches/noiseTerraces.d.ts.map +1 -0
- package/dist/soundart-sketches/noiseTerraces.js +53 -0
- package/dist/soundart-sketches/orb.d.ts +3 -0
- package/dist/soundart-sketches/orb.d.ts.map +1 -0
- package/dist/soundart-sketches/orb.js +50 -0
- package/dist/soundart-sketches/pixelGlyphs.d.ts +3 -0
- package/dist/soundart-sketches/pixelGlyphs.d.ts.map +1 -0
- package/dist/soundart-sketches/pixelGlyphs.js +72 -0
- package/dist/soundart-sketches/prismFlowFields.d.ts +3 -0
- package/dist/soundart-sketches/prismFlowFields.d.ts.map +1 -0
- package/dist/soundart-sketches/prismFlowFields.js +51 -0
- package/dist/soundart-sketches/radialBurst.d.ts +3 -0
- package/dist/soundart-sketches/radialBurst.d.ts.map +1 -0
- package/dist/soundart-sketches/radialBurst.js +60 -0
- package/dist/soundart-sketches/resonantSoundBodies.d.ts +3 -0
- package/dist/soundart-sketches/resonantSoundBodies.d.ts.map +1 -0
- package/dist/soundart-sketches/resonantSoundBodies.js +89 -0
- package/dist/soundart-sketches/rings.d.ts +11 -0
- package/dist/soundart-sketches/rings.d.ts.map +1 -0
- package/dist/soundart-sketches/rings.js +89 -0
- package/dist/soundart-sketches/squares.d.ts +3 -0
- package/dist/soundart-sketches/squares.d.ts.map +1 -0
- package/dist/soundart-sketches/squares.js +52 -0
- package/dist/soundart-sketches/waveStripes.d.ts +3 -0
- package/dist/soundart-sketches/waveStripes.d.ts.map +1 -0
- package/dist/soundart-sketches/waveStripes.js +44 -0
- package/dist/static-engine.d.ts +4 -1
- package/dist/static-engine.d.ts.map +1 -1
- package/dist/static-engine.js +13 -8
- package/dist/types.d.ts +75 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +19 -1
- package/package.json +23 -17
package/dist/index.d.ts
CHANGED
|
@@ -1,31 +1,50 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* NexArt Code Mode Runtime SDK
|
|
3
|
-
* Version:
|
|
3
|
+
* Version: 1.1.0 (Protocol v1.0.0)
|
|
4
4
|
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
5
|
+
* ╔══════════════════════════════════════════════════════════════════════════╗
|
|
6
|
+
* ║ @nexart/codemode-sdk — Canonical Code Mode Authority ║
|
|
7
|
+
* ║ ║
|
|
8
|
+
* ║ This SDK defines the official Code Mode execution surface. ║
|
|
9
|
+
* ║ All implementations (NexArt, ByX, external) MUST use this SDK. ║
|
|
10
|
+
* ║ ║
|
|
11
|
+
* ║ Protocol: nexart ║
|
|
12
|
+
* ║ Engine: codemode ║
|
|
13
|
+
* ║ SDK Version: 1.1.0 ║
|
|
14
|
+
* ║ Protocol Version: 1.0.0 ║
|
|
15
|
+
* ║ Phase: 1 ║
|
|
16
|
+
* ║ Enforcement: HARD ║
|
|
17
|
+
* ╚══════════════════════════════════════════════════════════════════════════╝
|
|
7
18
|
*
|
|
8
19
|
* @example
|
|
9
20
|
* ```typescript
|
|
10
|
-
* import {
|
|
21
|
+
* import { executeCodeMode } from '@nexart/codemode-sdk';
|
|
11
22
|
*
|
|
12
|
-
* const
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* ellipse(width/2, height/2, 100);
|
|
20
|
-
* }
|
|
21
|
-
* `,
|
|
22
|
-
* onComplete: (result) => {
|
|
23
|
-
* console.log('Rendered:', result.type, result.blob.size, 'bytes');
|
|
24
|
-
* }
|
|
23
|
+
* const result = await executeCodeMode({
|
|
24
|
+
* source: `function setup() { background(255); ellipse(width/2, height/2, 100); }`,
|
|
25
|
+
* width: 1950,
|
|
26
|
+
* height: 2400,
|
|
27
|
+
* seed: 12345,
|
|
28
|
+
* vars: [50, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
|
29
|
+
* mode: 'static'
|
|
25
30
|
* });
|
|
31
|
+
*
|
|
32
|
+
* console.log(result.metadata.protocolVersion); // '1.0.0'
|
|
26
33
|
* ```
|
|
27
34
|
*/
|
|
35
|
+
export { executeCodeMode, validateCodeModeSource } from './execute';
|
|
36
|
+
export type { ExecuteCodeModeInput, ExecuteCodeModeResult, ProtocolMetadata, } from './types';
|
|
37
|
+
export { PROTOCOL_IDENTITY } from './types';
|
|
28
38
|
export { createEngine } from './engine';
|
|
29
39
|
export type { Engine, EngineConfig, RunOptions, RenderResult, ProgressInfo, RenderMode, TimeVariables, } from './types';
|
|
30
40
|
export { DEFAULT_CONFIG } from './types';
|
|
41
|
+
export { renderSoundArtViaCodeMode, canRenderViaCodeMode, getCodeModeAvailableStyles, type SoundArtEngineConfig, type SoundArtRenderOptions, type SoundArtRenderResult, type SoundArtMetadata, } from './soundart-engine';
|
|
42
|
+
export { type SoundSnapshot, type SoundFeatures, createSoundSnapshot, createEmptySoundSnapshot, freezeSoundSnapshot, } from '../../shared/soundSnapshot';
|
|
43
|
+
export { injectSoundGlobals, createSoundGlobals, createEmptySoundGlobals, generateSoundPalette, inferGenreProfile, createSoundHelpers, type SoundGlobals, type GenreProfile, } from './sound-bridge';
|
|
44
|
+
export { getSoundArtSketch, getAvailableSoundArtSketches, isSoundArtSketchAvailable, type SoundArtSketchName, } from './soundart-sketches';
|
|
45
|
+
export { createP5Runtime, type P5Runtime, type P5RuntimeConfig } from './p5-runtime';
|
|
46
|
+
export { renderNoiseViaCodeMode, compileNoiseSystem, canRenderNoiseViaCodeMode, type NoiseEngineConfig, type NoiseRenderOptions, type NoiseRenderResult, type NoiseMetadata, } from './noise-engine';
|
|
47
|
+
export { type NoiseSnapshot, type NoiseParams, type NoiseBlendMode, createNoiseSnapshot, validateNoiseSnapshot, } from '../../shared/noiseSnapshot';
|
|
48
|
+
export { createNoiseGlobals, injectNoiseGlobals, type NoiseGlobals, } from './noise-bridge';
|
|
49
|
+
export { getNoiseSketch, getAvailableNoiseSketchNames, isValidNoiseSketch, type NoiseSketchName, } from './noise-sketches';
|
|
31
50
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AAKH,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AACpE,YAAY,EACV,oBAAoB,EACpB,qBAAqB,EACrB,gBAAgB,GACjB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAK5C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,YAAY,EACV,MAAM,EACN,YAAY,EACZ,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,UAAU,EACV,aAAa,GACd,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGzC,OAAO,EACL,yBAAyB,EACzB,oBAAoB,EACpB,0BAA0B,EAC1B,KAAK,oBAAoB,EACzB,KAAK,qBAAqB,EAC1B,KAAK,oBAAoB,EACzB,KAAK,gBAAgB,GACtB,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,mBAAmB,EACnB,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,4BAA4B,CAAC;AAEpC,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,uBAAuB,EACvB,oBAAoB,EACpB,iBAAiB,EACjB,kBAAkB,EAClB,KAAK,YAAY,EACjB,KAAK,YAAY,GAClB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,iBAAiB,EACjB,4BAA4B,EAC5B,yBAAyB,EACzB,KAAK,kBAAkB,GACxB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,eAAe,EAAE,KAAK,SAAS,EAAE,KAAK,eAAe,EAAE,MAAM,cAAc,CAAC;AAGrF,OAAO,EACL,sBAAsB,EACtB,kBAAkB,EAClB,yBAAyB,EACzB,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,EACtB,KAAK,aAAa,GACnB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,WAAW,EAChB,KAAK,cAAc,EACnB,mBAAmB,EACnB,qBAAqB,GACtB,MAAM,4BAA4B,CAAC;AAEpC,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,KAAK,YAAY,GAClB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,cAAc,EACd,4BAA4B,EAC5B,kBAAkB,EAClB,KAAK,eAAe,GACrB,MAAM,kBAAkB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,29 +1,55 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* NexArt Code Mode Runtime SDK
|
|
3
|
-
* Version:
|
|
3
|
+
* Version: 1.1.0 (Protocol v1.0.0)
|
|
4
4
|
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
5
|
+
* ╔══════════════════════════════════════════════════════════════════════════╗
|
|
6
|
+
* ║ @nexart/codemode-sdk — Canonical Code Mode Authority ║
|
|
7
|
+
* ║ ║
|
|
8
|
+
* ║ This SDK defines the official Code Mode execution surface. ║
|
|
9
|
+
* ║ All implementations (NexArt, ByX, external) MUST use this SDK. ║
|
|
10
|
+
* ║ ║
|
|
11
|
+
* ║ Protocol: nexart ║
|
|
12
|
+
* ║ Engine: codemode ║
|
|
13
|
+
* ║ SDK Version: 1.1.0 ║
|
|
14
|
+
* ║ Protocol Version: 1.0.0 ║
|
|
15
|
+
* ║ Phase: 1 ║
|
|
16
|
+
* ║ Enforcement: HARD ║
|
|
17
|
+
* ╚══════════════════════════════════════════════════════════════════════════╝
|
|
7
18
|
*
|
|
8
19
|
* @example
|
|
9
20
|
* ```typescript
|
|
10
|
-
* import {
|
|
21
|
+
* import { executeCodeMode } from '@nexart/codemode-sdk';
|
|
11
22
|
*
|
|
12
|
-
* const
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* ellipse(width/2, height/2, 100);
|
|
20
|
-
* }
|
|
21
|
-
* `,
|
|
22
|
-
* onComplete: (result) => {
|
|
23
|
-
* console.log('Rendered:', result.type, result.blob.size, 'bytes');
|
|
24
|
-
* }
|
|
23
|
+
* const result = await executeCodeMode({
|
|
24
|
+
* source: `function setup() { background(255); ellipse(width/2, height/2, 100); }`,
|
|
25
|
+
* width: 1950,
|
|
26
|
+
* height: 2400,
|
|
27
|
+
* seed: 12345,
|
|
28
|
+
* vars: [50, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
|
29
|
+
* mode: 'static'
|
|
25
30
|
* });
|
|
31
|
+
*
|
|
32
|
+
* console.log(result.metadata.protocolVersion); // '1.0.0'
|
|
26
33
|
* ```
|
|
27
34
|
*/
|
|
35
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
36
|
+
// CANONICAL EXECUTION ENTRY POINT
|
|
37
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
38
|
+
export { executeCodeMode, validateCodeModeSource } from './execute';
|
|
39
|
+
export { PROTOCOL_IDENTITY } from './types';
|
|
40
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
41
|
+
// LEGACY ENGINE API (use executeCodeMode for new implementations)
|
|
42
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
28
43
|
export { createEngine } from './engine';
|
|
29
44
|
export { DEFAULT_CONFIG } from './types';
|
|
45
|
+
// SoundArt → Code Mode integration
|
|
46
|
+
export { renderSoundArtViaCodeMode, canRenderViaCodeMode, getCodeModeAvailableStyles, } from './soundart-engine';
|
|
47
|
+
export { createSoundSnapshot, createEmptySoundSnapshot, freezeSoundSnapshot, } from '../../shared/soundSnapshot';
|
|
48
|
+
export { injectSoundGlobals, createSoundGlobals, createEmptySoundGlobals, generateSoundPalette, inferGenreProfile, createSoundHelpers, } from './sound-bridge';
|
|
49
|
+
export { getSoundArtSketch, getAvailableSoundArtSketches, isSoundArtSketchAvailable, } from './soundart-sketches';
|
|
50
|
+
export { createP5Runtime } from './p5-runtime';
|
|
51
|
+
// Noise → Code Mode integration
|
|
52
|
+
export { renderNoiseViaCodeMode, compileNoiseSystem, canRenderNoiseViaCodeMode, } from './noise-engine';
|
|
53
|
+
export { createNoiseSnapshot, validateNoiseSnapshot, } from '../../shared/noiseSnapshot';
|
|
54
|
+
export { createNoiseGlobals, injectNoiseGlobals, } from './noise-bridge';
|
|
55
|
+
export { getNoiseSketch, getAvailableNoiseSketchNames, isValidNoiseSketch, } from './noise-sketches';
|
package/dist/loop-engine.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* NexArt Code Mode Runtime SDK - Loop Engine
|
|
3
|
-
*
|
|
3
|
+
* Protocol: v1.0.0 (Phase 1) — HARD ENFORCEMENT
|
|
4
4
|
*
|
|
5
5
|
* Loop mode renderer: frame-authoritative, stateless execution.
|
|
6
6
|
* - Executes setup() once
|
|
@@ -8,6 +8,9 @@
|
|
|
8
8
|
* - Clears canvas before each frame (transparent)
|
|
9
9
|
* - Injects normalized time variables
|
|
10
10
|
* - No canvas persistence between frames
|
|
11
|
+
*
|
|
12
|
+
* Determinism Guarantee:
|
|
13
|
+
* Same code + same seed + same VARs = identical frame sequence
|
|
11
14
|
*/
|
|
12
15
|
import type { EngineConfig, RunOptions } from './types';
|
|
13
16
|
export declare function cancelLoopMode(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loop-engine.d.ts","sourceRoot":"","sources":["../loop-engine.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"loop-engine.d.ts","sourceRoot":"","sources":["../loop-engine.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAA+B,MAAM,SAAS,CAAC;AAMrF,wBAAgB,cAAc,IAAI,IAAI,CAErC;AAED,wBAAsB,WAAW,CAC/B,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,UAAU,GAClB,OAAO,CAAC,IAAI,CAAC,CA+Lf"}
|
package/dist/loop-engine.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* NexArt Code Mode Runtime SDK - Loop Engine
|
|
3
|
-
*
|
|
3
|
+
* Protocol: v1.0.0 (Phase 1) — HARD ENFORCEMENT
|
|
4
4
|
*
|
|
5
5
|
* Loop mode renderer: frame-authoritative, stateless execution.
|
|
6
6
|
* - Executes setup() once
|
|
@@ -8,15 +8,18 @@
|
|
|
8
8
|
* - Clears canvas before each frame (transparent)
|
|
9
9
|
* - Injects normalized time variables
|
|
10
10
|
* - No canvas persistence between frames
|
|
11
|
+
*
|
|
12
|
+
* Determinism Guarantee:
|
|
13
|
+
* Same code + same seed + same VARs = identical frame sequence
|
|
11
14
|
*/
|
|
12
15
|
import { DEFAULT_CONFIG } from './types';
|
|
13
|
-
import { createP5Runtime } from './p5-runtime';
|
|
16
|
+
import { createP5Runtime, injectProtocolVariables } from './p5-runtime';
|
|
14
17
|
let isCancelled = false;
|
|
15
18
|
export function cancelLoopMode() {
|
|
16
19
|
isCancelled = true;
|
|
17
20
|
}
|
|
18
21
|
export async function runLoopMode(config, options) {
|
|
19
|
-
const { code, onPreview, onProgress, onComplete, onError } = options;
|
|
22
|
+
const { code, seed, vars, onPreview, onProgress, onComplete, onError } = options;
|
|
20
23
|
const width = config.width ?? DEFAULT_CONFIG.width;
|
|
21
24
|
const height = config.height ?? DEFAULT_CONFIG.height;
|
|
22
25
|
const duration = Math.max(DEFAULT_CONFIG.minDuration, Math.min(DEFAULT_CONFIG.maxDuration, config.duration ?? DEFAULT_CONFIG.duration));
|
|
@@ -33,8 +36,10 @@ export async function runLoopMode(config, options) {
|
|
|
33
36
|
const canvas = document.createElement('canvas');
|
|
34
37
|
canvas.width = width;
|
|
35
38
|
canvas.height = height;
|
|
36
|
-
// Create p5 runtime
|
|
37
|
-
const p = createP5Runtime(canvas, width, height);
|
|
39
|
+
// Create p5 runtime with optional seed for determinism
|
|
40
|
+
const p = createP5Runtime(canvas, width, height, { seed });
|
|
41
|
+
// Inject protocol variables (VAR[0..9])
|
|
42
|
+
injectProtocolVariables(p, vars);
|
|
38
43
|
// Validate code
|
|
39
44
|
const hasDrawFunction = /function\s+draw\s*\(\s*\)/.test(code);
|
|
40
45
|
if (!hasDrawFunction) {
|
|
@@ -64,16 +69,16 @@ export async function runLoopMode(config, options) {
|
|
|
64
69
|
if (!drawCode) {
|
|
65
70
|
throw new Error('Loop Mode requires a draw() function with content.');
|
|
66
71
|
}
|
|
67
|
-
// Create wrapped functions with p5 context
|
|
68
|
-
const wrappedSetup = new Function('p', 'frameCount', 't', 'time', 'tGlobal', `with(p) { ${setupCode} }`);
|
|
69
|
-
const wrappedDraw = new Function('p', 'frameCount', 't', 'time', 'tGlobal', `with(p) { ${drawCode} }`);
|
|
72
|
+
// Create wrapped functions with p5 context, time variables, and VAR
|
|
73
|
+
const wrappedSetup = new Function('p', 'frameCount', 't', 'time', 'tGlobal', 'VAR', `with(p) { ${setupCode} }`);
|
|
74
|
+
const wrappedDraw = new Function('p', 'frameCount', 't', 'time', 'tGlobal', 'VAR', `with(p) { ${drawCode} }`);
|
|
70
75
|
onProgress?.({
|
|
71
76
|
phase: 'setup',
|
|
72
77
|
percent: 10,
|
|
73
78
|
message: 'Executing setup()...',
|
|
74
79
|
});
|
|
75
|
-
// Execute setup() once with time = 0
|
|
76
|
-
wrappedSetup(p, 0, 0, 0, 0);
|
|
80
|
+
// Execute setup() once with time = 0 and VAR
|
|
81
|
+
wrappedSetup(p, 0, 0, 0, 0, p.VAR);
|
|
77
82
|
// Capture frames
|
|
78
83
|
const frames = [];
|
|
79
84
|
onProgress?.({
|
|
@@ -97,8 +102,8 @@ export async function runLoopMode(config, options) {
|
|
|
97
102
|
// This enforces stateless, frame-authoritative rendering
|
|
98
103
|
// Preserves artist-defined backgrounds (if they call background() in draw)
|
|
99
104
|
p.clear();
|
|
100
|
-
// Execute draw() with time variables
|
|
101
|
-
wrappedDraw(p, frame, t, time, t);
|
|
105
|
+
// Execute draw() with time variables and VAR
|
|
106
|
+
wrappedDraw(p, frame, t, time, t, p.VAR);
|
|
102
107
|
// Capture frame as PNG blob
|
|
103
108
|
const blob = await new Promise((resolve, reject) => {
|
|
104
109
|
canvas.toBlob((b) => b ? resolve(b) : reject(new Error(`Failed to capture frame ${frame}`)), 'image/png');
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Noise Bridge - Injects N.* globals into Code Mode runtime
|
|
3
|
+
*
|
|
4
|
+
* This is the bridge between NoiseSnapshot data and the Code Mode p5-runtime.
|
|
5
|
+
* It creates frozen N.* globals that noise sketches can access deterministically.
|
|
6
|
+
*
|
|
7
|
+
* Similar to sound-bridge.ts for SoundArt, but for Noise parameters.
|
|
8
|
+
*/
|
|
9
|
+
import type { NoiseSnapshot, NoiseBlendMode } from '../../shared/noiseSnapshot';
|
|
10
|
+
/**
|
|
11
|
+
* The N.* global object type for noise sketches
|
|
12
|
+
*/
|
|
13
|
+
export interface NoiseGlobals {
|
|
14
|
+
scale: number;
|
|
15
|
+
octaves: number;
|
|
16
|
+
persistence: number;
|
|
17
|
+
lacunarity: number;
|
|
18
|
+
cellDensity: number;
|
|
19
|
+
cellDistortion: number;
|
|
20
|
+
blendMode: NoiseBlendMode;
|
|
21
|
+
isPerlinOnly: boolean;
|
|
22
|
+
isBlend: boolean;
|
|
23
|
+
isWarp: boolean;
|
|
24
|
+
isInterleave: boolean;
|
|
25
|
+
bgR: number;
|
|
26
|
+
bgG: number;
|
|
27
|
+
bgB: number;
|
|
28
|
+
noiseR: number;
|
|
29
|
+
noiseG: number;
|
|
30
|
+
noiseB: number;
|
|
31
|
+
seed: number;
|
|
32
|
+
zoom: number;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create N.* globals from a NoiseSnapshot
|
|
36
|
+
*/
|
|
37
|
+
export declare function createNoiseGlobals(snapshot: NoiseSnapshot): NoiseGlobals;
|
|
38
|
+
/**
|
|
39
|
+
* Inject N.* globals into code string
|
|
40
|
+
*
|
|
41
|
+
* This wraps the sketch code with N.* variable declarations
|
|
42
|
+
*/
|
|
43
|
+
export declare function injectNoiseGlobals(sketchCode: string, globals: NoiseGlobals): string;
|
|
44
|
+
//# sourceMappingURL=noise-bridge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noise-bridge.d.ts","sourceRoot":"","sources":["../noise-bridge.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEhF;;GAEG;AACH,MAAM,WAAW,YAAY;IAE3B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IAGnB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IAGvB,SAAS,EAAE,cAAc,CAAC;IAC1B,YAAY,EAAE,OAAO,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,OAAO,CAAC;IAChB,YAAY,EAAE,OAAO,CAAC;IAGtB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IAGf,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,aAAa,GAAG,YAAY,CAsBxE;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,GAAG,MAAM,CA6BpF"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Noise Bridge - Injects N.* globals into Code Mode runtime
|
|
3
|
+
*
|
|
4
|
+
* This is the bridge between NoiseSnapshot data and the Code Mode p5-runtime.
|
|
5
|
+
* It creates frozen N.* globals that noise sketches can access deterministically.
|
|
6
|
+
*
|
|
7
|
+
* Similar to sound-bridge.ts for SoundArt, but for Noise parameters.
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* Create N.* globals from a NoiseSnapshot
|
|
11
|
+
*/
|
|
12
|
+
export function createNoiseGlobals(snapshot) {
|
|
13
|
+
return Object.freeze({
|
|
14
|
+
scale: snapshot.scale,
|
|
15
|
+
octaves: snapshot.octaves,
|
|
16
|
+
persistence: snapshot.persistence,
|
|
17
|
+
lacunarity: snapshot.lacunarity,
|
|
18
|
+
cellDensity: snapshot.cellDensity,
|
|
19
|
+
cellDistortion: snapshot.cellDistortion,
|
|
20
|
+
blendMode: snapshot.blendMode,
|
|
21
|
+
isPerlinOnly: snapshot.blendMode === 'perlin_only',
|
|
22
|
+
isBlend: snapshot.blendMode === 'blend',
|
|
23
|
+
isWarp: snapshot.blendMode === 'warp',
|
|
24
|
+
isInterleave: snapshot.blendMode === 'interleave',
|
|
25
|
+
bgR: snapshot.bgR,
|
|
26
|
+
bgG: snapshot.bgG,
|
|
27
|
+
bgB: snapshot.bgB,
|
|
28
|
+
noiseR: snapshot.noiseR,
|
|
29
|
+
noiseG: snapshot.noiseG,
|
|
30
|
+
noiseB: snapshot.noiseB,
|
|
31
|
+
seed: snapshot.seed,
|
|
32
|
+
zoom: snapshot.zoomLevel,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Inject N.* globals into code string
|
|
37
|
+
*
|
|
38
|
+
* This wraps the sketch code with N.* variable declarations
|
|
39
|
+
*/
|
|
40
|
+
export function injectNoiseGlobals(sketchCode, globals) {
|
|
41
|
+
const injection = `
|
|
42
|
+
// === Injected Noise Globals (N.*) ===
|
|
43
|
+
const N = Object.freeze({
|
|
44
|
+
scale: ${globals.scale},
|
|
45
|
+
octaves: ${globals.octaves},
|
|
46
|
+
persistence: ${globals.persistence},
|
|
47
|
+
lacunarity: ${globals.lacunarity},
|
|
48
|
+
cellDensity: ${globals.cellDensity},
|
|
49
|
+
cellDistortion: ${globals.cellDistortion},
|
|
50
|
+
blendMode: '${globals.blendMode}',
|
|
51
|
+
isPerlinOnly: ${globals.isPerlinOnly},
|
|
52
|
+
isBlend: ${globals.isBlend},
|
|
53
|
+
isWarp: ${globals.isWarp},
|
|
54
|
+
isInterleave: ${globals.isInterleave},
|
|
55
|
+
bgR: ${globals.bgR},
|
|
56
|
+
bgG: ${globals.bgG},
|
|
57
|
+
bgB: ${globals.bgB},
|
|
58
|
+
noiseR: ${globals.noiseR},
|
|
59
|
+
noiseG: ${globals.noiseG},
|
|
60
|
+
noiseB: ${globals.noiseB},
|
|
61
|
+
seed: ${globals.seed},
|
|
62
|
+
zoom: ${globals.zoom}
|
|
63
|
+
});
|
|
64
|
+
// === End Injected Globals ===
|
|
65
|
+
|
|
66
|
+
`;
|
|
67
|
+
return injection + sketchCode;
|
|
68
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Noise → Code Mode Engine
|
|
3
|
+
*
|
|
4
|
+
* This is the orchestrator that runs Noise rendering through the Code Mode engine.
|
|
5
|
+
* It replaces the legacy p5.js-based NoiseCanvas with a protocol-compliant pipeline.
|
|
6
|
+
*
|
|
7
|
+
* Architecture:
|
|
8
|
+
* 1. NoiseParams from UI state
|
|
9
|
+
* 2. NoiseParams → NoiseSnapshot conversion
|
|
10
|
+
* 3. NoiseSnapshot injected as N.* globals into Code Mode
|
|
11
|
+
* 4. Noise sketch executed via Code Mode runtime
|
|
12
|
+
* 5. Result: PNG output (deterministic)
|
|
13
|
+
*/
|
|
14
|
+
import type { NoiseSnapshot, NoiseParams } from '../../shared/noiseSnapshot';
|
|
15
|
+
export interface NoiseEngineConfig {
|
|
16
|
+
width: number;
|
|
17
|
+
height: number;
|
|
18
|
+
seed: number;
|
|
19
|
+
}
|
|
20
|
+
export interface NoiseRenderOptions {
|
|
21
|
+
params: NoiseParams;
|
|
22
|
+
canvas: HTMLCanvasElement;
|
|
23
|
+
config: NoiseEngineConfig;
|
|
24
|
+
onProgress?: (progress: number) => void;
|
|
25
|
+
}
|
|
26
|
+
export interface NoiseRenderResult {
|
|
27
|
+
mode: 'noise';
|
|
28
|
+
snapshot: NoiseSnapshot;
|
|
29
|
+
metadata: NoiseMetadata;
|
|
30
|
+
}
|
|
31
|
+
export interface NoiseMetadata {
|
|
32
|
+
mode: 'Noise';
|
|
33
|
+
timestamp: string;
|
|
34
|
+
enforcement: 'hard';
|
|
35
|
+
renderedVia: 'codemode';
|
|
36
|
+
noiseParams: {
|
|
37
|
+
scale: number;
|
|
38
|
+
octaves: number;
|
|
39
|
+
persistence: number;
|
|
40
|
+
lacunarity: number;
|
|
41
|
+
cellDensity: number;
|
|
42
|
+
cellDistortion: number;
|
|
43
|
+
blendMode: string;
|
|
44
|
+
};
|
|
45
|
+
generationParams: {
|
|
46
|
+
seed: number;
|
|
47
|
+
canvasSize: {
|
|
48
|
+
width: number;
|
|
49
|
+
height: number;
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Render noise via Code Mode runtime
|
|
55
|
+
*
|
|
56
|
+
* This is the main entry point for protocol-compliant noise rendering.
|
|
57
|
+
* All rendering goes through the Code Mode runtime for determinism.
|
|
58
|
+
*/
|
|
59
|
+
export declare function renderNoiseViaCodeMode(options: NoiseRenderOptions): Promise<NoiseRenderResult>;
|
|
60
|
+
/**
|
|
61
|
+
* Compile noise params to a Code Mode system
|
|
62
|
+
* This produces a reproducible system definition
|
|
63
|
+
*/
|
|
64
|
+
export declare function compileNoiseSystem(params: NoiseParams): {
|
|
65
|
+
sketchCode: string;
|
|
66
|
+
snapshot: NoiseSnapshot;
|
|
67
|
+
seed: number;
|
|
68
|
+
};
|
|
69
|
+
/**
|
|
70
|
+
* Check if noise can be rendered via Code Mode
|
|
71
|
+
* (Always true - no legacy fallback)
|
|
72
|
+
*/
|
|
73
|
+
export declare function canRenderNoiseViaCodeMode(): boolean;
|
|
74
|
+
//# sourceMappingURL=noise-engine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noise-engine.d.ts","sourceRoot":"","sources":["../noise-engine.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAM7E,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,WAAW,CAAC;IACpB,MAAM,EAAE,iBAAiB,CAAC;IAC1B,MAAM,EAAE,iBAAiB,CAAC;IAC1B,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;CACzC;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,OAAO,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,UAAU,CAAC;IACxB,WAAW,EAAE;QACX,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC;QACnB,WAAW,EAAE,MAAM,CAAC;QACpB,cAAc,EAAE,MAAM,CAAC;QACvB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,gBAAgB,EAAE;QAChB,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,MAAM,EAAE,MAAM,CAAA;SAAE,CAAC;KAC/C,CAAC;CACH;AAED;;;;;GAKG;AACH,wBAAsB,sBAAsB,CAC1C,OAAO,EAAE,kBAAkB,GAC1B,OAAO,CAAC,iBAAiB,CAAC,CAsF5B;AAwBD;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,WAAW,GAAG;IACvD,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,aAAa,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;CACd,CAUA;AAED;;;GAGG;AACH,wBAAgB,yBAAyB,IAAI,OAAO,CAEnD"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Noise → Code Mode Engine
|
|
3
|
+
*
|
|
4
|
+
* This is the orchestrator that runs Noise rendering through the Code Mode engine.
|
|
5
|
+
* It replaces the legacy p5.js-based NoiseCanvas with a protocol-compliant pipeline.
|
|
6
|
+
*
|
|
7
|
+
* Architecture:
|
|
8
|
+
* 1. NoiseParams from UI state
|
|
9
|
+
* 2. NoiseParams → NoiseSnapshot conversion
|
|
10
|
+
* 3. NoiseSnapshot injected as N.* globals into Code Mode
|
|
11
|
+
* 4. Noise sketch executed via Code Mode runtime
|
|
12
|
+
* 5. Result: PNG output (deterministic)
|
|
13
|
+
*/
|
|
14
|
+
import { createNoiseSnapshot, validateNoiseSnapshot } from '../../shared/noiseSnapshot';
|
|
15
|
+
import { createP5Runtime } from './p5-runtime';
|
|
16
|
+
import { createNoiseGlobals, injectNoiseGlobals } from './noise-bridge';
|
|
17
|
+
import { getNoiseSketch } from './noise-sketches';
|
|
18
|
+
/**
|
|
19
|
+
* Render noise via Code Mode runtime
|
|
20
|
+
*
|
|
21
|
+
* This is the main entry point for protocol-compliant noise rendering.
|
|
22
|
+
* All rendering goes through the Code Mode runtime for determinism.
|
|
23
|
+
*/
|
|
24
|
+
export async function renderNoiseViaCodeMode(options) {
|
|
25
|
+
const { params, canvas, config, onProgress } = options;
|
|
26
|
+
// Protocol enforcement logging
|
|
27
|
+
console.log('[Noise] Protocol enforcement: HARD | renderedVia: codemode');
|
|
28
|
+
onProgress?.(0.1);
|
|
29
|
+
// Create and validate snapshot
|
|
30
|
+
const rawSnapshot = createNoiseSnapshot(params);
|
|
31
|
+
const snapshot = validateNoiseSnapshot(rawSnapshot);
|
|
32
|
+
onProgress?.(0.2);
|
|
33
|
+
// Create N.* globals
|
|
34
|
+
const noiseGlobals = createNoiseGlobals(snapshot);
|
|
35
|
+
// Get the noise sketch
|
|
36
|
+
const sketchName = 'fractalNoise';
|
|
37
|
+
const sketchCode = getNoiseSketch(sketchName);
|
|
38
|
+
// Inject N.* globals into sketch
|
|
39
|
+
const injectedCode = injectNoiseGlobals(sketchCode, noiseGlobals);
|
|
40
|
+
onProgress?.(0.3);
|
|
41
|
+
// Set canvas dimensions
|
|
42
|
+
canvas.width = config.width;
|
|
43
|
+
canvas.height = config.height;
|
|
44
|
+
// Create P5 runtime with correct signature
|
|
45
|
+
const runtimeConfig = {
|
|
46
|
+
seed: config.seed,
|
|
47
|
+
};
|
|
48
|
+
const runtime = createP5Runtime(canvas, config.width, config.height, runtimeConfig);
|
|
49
|
+
onProgress?.(0.5);
|
|
50
|
+
// Build globals with all runtime functions and noise globals
|
|
51
|
+
const globals = {
|
|
52
|
+
...runtime,
|
|
53
|
+
width: config.width,
|
|
54
|
+
height: config.height,
|
|
55
|
+
};
|
|
56
|
+
// Execute the sketch
|
|
57
|
+
try {
|
|
58
|
+
executeNoiseSketch(injectedCode, globals);
|
|
59
|
+
onProgress?.(0.9);
|
|
60
|
+
console.log('[Noise] Rendered via Code Mode runtime');
|
|
61
|
+
// Build metadata
|
|
62
|
+
const metadata = {
|
|
63
|
+
mode: 'Noise',
|
|
64
|
+
timestamp: new Date().toISOString(),
|
|
65
|
+
enforcement: 'hard',
|
|
66
|
+
renderedVia: 'codemode',
|
|
67
|
+
noiseParams: {
|
|
68
|
+
scale: snapshot.scale,
|
|
69
|
+
octaves: snapshot.octaves,
|
|
70
|
+
persistence: snapshot.persistence,
|
|
71
|
+
lacunarity: snapshot.lacunarity,
|
|
72
|
+
cellDensity: snapshot.cellDensity,
|
|
73
|
+
cellDistortion: snapshot.cellDistortion,
|
|
74
|
+
blendMode: snapshot.blendMode,
|
|
75
|
+
},
|
|
76
|
+
generationParams: {
|
|
77
|
+
seed: config.seed,
|
|
78
|
+
canvasSize: { width: config.width, height: config.height },
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
onProgress?.(1.0);
|
|
82
|
+
return {
|
|
83
|
+
mode: 'noise',
|
|
84
|
+
snapshot,
|
|
85
|
+
metadata,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
console.error('[Noise] Code Mode execution failed:', error);
|
|
90
|
+
throw error;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Execute a noise sketch string in the context of the runtime globals
|
|
95
|
+
*/
|
|
96
|
+
function executeNoiseSketch(code, globals) {
|
|
97
|
+
const globalNames = Object.keys(globals);
|
|
98
|
+
const globalValues = Object.values(globals);
|
|
99
|
+
// Wrap the sketch code to call setup()
|
|
100
|
+
const wrappedCode = `
|
|
101
|
+
${code}
|
|
102
|
+
|
|
103
|
+
// Execute setup (noise is static - single frame)
|
|
104
|
+
if (typeof setup === 'function') {
|
|
105
|
+
setup();
|
|
106
|
+
}
|
|
107
|
+
`;
|
|
108
|
+
// Create and execute the function
|
|
109
|
+
const sketchFunction = new Function(...globalNames, wrappedCode);
|
|
110
|
+
sketchFunction(...globalValues);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Compile noise params to a Code Mode system
|
|
114
|
+
* This produces a reproducible system definition
|
|
115
|
+
*/
|
|
116
|
+
export function compileNoiseSystem(params) {
|
|
117
|
+
const snapshot = validateNoiseSnapshot(createNoiseSnapshot(params));
|
|
118
|
+
const noiseGlobals = createNoiseGlobals(snapshot);
|
|
119
|
+
const sketchCode = injectNoiseGlobals(getNoiseSketch('fractalNoise'), noiseGlobals);
|
|
120
|
+
return {
|
|
121
|
+
sketchCode,
|
|
122
|
+
snapshot,
|
|
123
|
+
seed: params.seed,
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Check if noise can be rendered via Code Mode
|
|
128
|
+
* (Always true - no legacy fallback)
|
|
129
|
+
*/
|
|
130
|
+
export function canRenderNoiseViaCodeMode() {
|
|
131
|
+
return true;
|
|
132
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Fractal Noise - Code Mode Sketch
|
|
3
|
+
*
|
|
4
|
+
* This sketch implements Perlin FBM and Cellular noise rendering
|
|
5
|
+
* through the Code Mode p5-runtime. Uses N.* globals for all parameters.
|
|
6
|
+
*
|
|
7
|
+
* Original: client/src/components/noise-canvas-simple.tsx
|
|
8
|
+
*/
|
|
9
|
+
export declare const FRACTAL_NOISE_SKETCH = "\n// Fractal Noise - Code Mode Sketch\n// Uses N.* noise globals and standard p5-like functions\n\nfunction setup() {\n // Set seeded random for reproducibility\n randomSeed(N.seed);\n noiseSeed(N.seed);\n \n // Set background color\n background(N.bgR, N.bgG, N.bgB);\n \n // Noise rendering parameters\n const adjustedScale = N.scale * (1 / N.zoom) * 0.05;\n const cellSize = 4; // Fixed for quality\n \n // Generate cellular points if needed\n const numPoints = Math.floor(20 + N.cellDensity * 180);\n const cellPoints = [];\n for (let i = 0; i < numPoints; i++) {\n cellPoints.push([random(0, width), random(0, height)]);\n }\n \n // Helper: Perlin FBM (Fractional Brownian Motion)\n function perlinFBM(x, y, scale) {\n let value = 0;\n let amplitude = 1;\n let frequency = 1;\n let maxValue = 0;\n \n const oct = Math.min(N.octaves, 6); // Cap for performance\n \n for (let i = 0; i < oct; i++) {\n value += noise(x * scale * frequency, y * scale * frequency) * amplitude;\n maxValue += amplitude;\n amplitude *= N.persistence;\n frequency *= N.lacunarity;\n }\n \n return value / maxValue;\n }\n \n // Helper: Cellular noise (Worley)\n function cellularNoise(x, y, points) {\n let sampleX = x;\n let sampleY = y;\n \n // Warp distortion if using warp mode\n if (N.isWarp && N.cellDistortion > 0) {\n const distortionAmount = N.cellDistortion * 100;\n sampleX += noise(x * 0.01, y * 0.01) * distortionAmount;\n sampleY += noise(y * 0.01, x * 0.01) * distortionAmount;\n }\n \n // Find distances to closest points\n let minDist = 999999;\n let secondMinDist = 999999;\n \n for (let i = 0; i < points.length; i++) {\n const px = points[i][0];\n const py = points[i][1];\n const dx = sampleX - px;\n const dy = sampleY - py;\n const dist = Math.sqrt(dx * dx + dy * dy);\n \n if (dist < minDist) {\n secondMinDist = minDist;\n minDist = dist;\n } else if (dist < secondMinDist) {\n secondMinDist = dist;\n }\n }\n \n // Normalize distance\n return Math.min(1.0, (secondMinDist - minDist) / 50);\n }\n \n // Render the noise grid\n noStroke();\n \n for (let y = 0; y < height; y += cellSize) {\n for (let x = 0; x < width; x += cellSize) {\n // Calculate Perlin value\n const perlinValue = perlinFBM(x, y, adjustedScale);\n \n // Calculate final value based on blend mode\n let finalValue = perlinValue;\n \n if (!N.isPerlinOnly) {\n const cellValue = cellularNoise(x, y, cellPoints);\n \n if (N.isBlend) {\n finalValue = perlinValue * cellValue;\n } else if (N.isWarp) {\n finalValue = (perlinValue + cellValue) / 2;\n } else if (N.isInterleave) {\n finalValue = (Math.floor(x / 20) + Math.floor(y / 20)) % 2 === 0\n ? perlinValue\n : cellValue;\n }\n }\n \n // Set opacity based on noise value\n const alpha = map(finalValue, 0, 1, 0, 255);\n \n // Fill with noise color and calculated alpha\n fill(N.noiseR, N.noiseG, N.noiseB, alpha);\n rect(x, y, cellSize, cellSize);\n }\n }\n}\n";
|
|
10
|
+
export default FRACTAL_NOISE_SKETCH;
|
|
11
|
+
//# sourceMappingURL=fractalNoise.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fractalNoise.d.ts","sourceRoot":"","sources":["../../noise-sketches/fractalNoise.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,eAAO,MAAM,oBAAoB,4sGA+GhC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|