Releases & Changelogs

Needle Engine 4.16.11

Needle Engine

  • Fix: iOS audio β€” AudioSource playback now survives a device lock / audio-session interruption and resumes automatically on unlock
  • Fix: typeof window/globalThis !== undefined guards were always true and could throw outside a browser (SSR / Node)

:bullseye: Download Unity Plugin :package: Install from NPM
:octopus: Changelog on Github :bookmark_tabs: Needle Engine API
:light_bulb: Get started :sparkles: Samples

Needle Engine 5.1.0 alpha.9

Needle Engine

Added

  • <needle-app> β€” embed a published Needle Engine app in any web page (with custom code etc) (docs)

Changed

  • <needle-app>: improved cross-origin handling and src parsing
  • ScrollFollow: now works inside an iframe (uses the top window)

Fixed

  • iOS audio: AudioSource playback now survives a device lock / audio-session interruption and resumes automatically on unlock
  • SceneSwitcher: ?scene= is now honored for scenes referenced as in-scene Object3Ds; scene preview loading supports prefabs and correct parenting under the SceneSwitcher
  • DragControls: widened the two-pointer scale clamp range and now reads world scale from the matrix columns
  • EventList: corrected the arguments passed to overridden methods
  • serializeObject: fixed Color / Euler / object-reference serialization, and OneEuroFilter.reset()
  • Prevented a TypeError when a scene-data error proxy is coerced to a string

Unity Integration

Fixed

  • Needle Component menu: fixed a null-reference on non-GameObject inspectors, handling of multiple targets and locked inspectors, and the β€œAdd Needle Component” button is now hidden for objects flagged NotEditable

:bullseye: Download Unity Plugin :package: Install from NPM
:octopus: Changelog on Github :bookmark_tabs: Needle Engine API
:light_bulb: Get started :sparkles: Samples

Needle Engine Blender Addon 1.2.1

  • Add: preload property for AudioSource for smoother audio playback
  • Add: density property for Colliders
  • Add: Gizmo for OrbitControls targetBound with improved gizmo interaction
  • Add: New β€œSamples & AI” panel with quick access to samples
  • Add: Easier to read, colored dev server output
  • Change: Updated to Needle Engine 5.0.10
  • Change: Cleaner, more focused UI β€” Needle settings and components now live in the viewport sidebar
  • Change: Improved DeleteBox gizmo display
  • Change: Broader Node.js support (20.19 – 24)
  • Fix: More reliable project path handling, including relative paths
  • Fix: Several stability improvements β€” fewer crashes on reload, with zero-scale objects, and on quit (macOS)
  • Fix: Corrected SeeThrough.overrideAlpha minimum value

:bullseye: Download Blender Addon :package: Download Samples
:light_bulb: Documentation :sparkles: Live Samples

Needle Engine 5.1.0

:star: Highlights

Scene Bindings β€” Fully Typed Scenes (preview)

Your glTF and GLB scenes now come with auto-generated TypeScript types. Access nodes, components, and properties with full autocomplete and type checking via ctx.sceneData or the new needle shorthand β€” no configuration required. Types regenerate automatically whenever your scene files change, and it works with local files, remote URLs, and Needle Cloud assets alike.

const cam   = ctx.sceneData.MyScene.MainCamera.$object;                      // THREE.PerspectiveCamera
const orbit = ctx.sceneData.MyScene.MainCamera.$components.OrbitControls;    // typed!
orbit.autoRotate = true;

First-Class Framework Support (preview)

Needle Engine now feels at home in any modern web stack. SSR support lets you import the engine in SvelteKit, Next.js, and Nuxt without crashes, JSX type declarations bring full autocomplete to React, Preact, SolidJS, and friends, and the new needle shorthand gives you instant access to the current context from anywhere β€” components, button handlers, or plain JavaScript.

import { needle } from "@needle-tools/engine";
needle.scene.traverse(obj => { ... });   // access the three.js scene
needle.renderer;                          // access the WebGLRenderer

Embed Anywhere with <needle-app>

Drop a published Needle Engine app into any web page with a single element β€” no build setup, custom code, or framework required. It handles cross-origin loading for you and works inside iframes.

<needle-app src="https://your-app.needle.run"></needle-app>

Animation & Timelines from Code (preview)

A new set of builder APIs lets you create animations, animator controllers, and timelines entirely in code, with typed keyframes and inline track definitions. Great for procedural content, runtime-generated sequences, and tooling.

const timeline = TimelineBuilder.create("MyTimeline")
    .animationTrack("Walk", animator).clip(walkClip, { duration: 2 })
    .activationTrack("FX", vfxObject).activate({ start: 1, duration: 0.5 })
    .build();
director.playableAsset = timeline;

A More Powerful Compression Pipeline

The build pipeline gets a major upgrade with new ways to shrink your builds automatically. Audio compression turns heavy WAV files into compact, web-friendly clips, and HDRi β†’ PMREM (FastHDR) compression converts environment maps into a format that loads up to 10Γ— faster and uses a fraction of the GPU memory β€” all on top of the existing Draco/meshopt geometry and KTX2 texture compression. Smaller downloads, faster loads, no manual work.

DragControls β€” A Big Upgrade

DragControls received a major overhaul with a new constraint system: keep-scale, two-touch scaling with min/max limits, refined hit regions, and a dedicated screen-space drag mode for AR. Single-touch dragging is now more predictable, and reliability is improved across snapping, side views, and multi-input scenarios.

MaterialX β€” Faster & Richer

The bundled MaterialX runtime jumps to 1.7.0 with faster environment lighting (new radiance sampling modes and PMREM support), better Three.js integration, and overall performance improvements. MaterialX export from Needle Engine projects no longer requires a PRO license.

Needle AI in the Editor

Needle AI is integrated directly into the Unity inspector and hierarchy, with awareness of your local Unity and web project so its assistance is relevant to what you’re actually building.

Needle Engine

Added

  • Scene Bindings (preview) β€” auto-generated, fully typed access to your scenes via ctx.sceneData / needle.sceneData
  • SSR support (preview) for SvelteKit, Next.js, and Nuxt, plus JSX type declarations for React, Preact, SolidJS and more
  • needle shorthand (preview) for quick access to the current engine context from anywhere
  • <needle-app> β€” embed a published Needle Engine app in any web page (docs)
  • Context.events β€” a typed event bus for decoupled component communication:
    context.events.on("scene-content-changed", e => console.log(e.object));
    context.events.emit<{ pts: number }>("scored", { pts: 10 });
    
  • autoCleanup on Behaviour β€” register disposables and cleanup tied to the component lifecycle
  • Builder APIs (preview) β€” TimelineBuilder, AnimatorControllerBuilder, and AnimationBuilder for defining timelines, controllers, and animations in code with typed keyframes and inline tracks
  • DragControls: new constraint system with keepScale, two-touch scale limits, refined hit regions, a screen-space AR drag mode, and EventList support
  • Skybox: new background-rotation / environment-rotation attributes and background-image-loaded / environment-image-loaded events
  • WebXRImageTracking: per-frame imageTracked event with typed access to the tracked object, plus resetImage / resetAllImages to re-arm markers without restarting XR
  • AudioClip type with standalone playback control, AudioSource spatial blend and .opus support
  • context.lights array and context.mainLight getter for quick access to scene lighting
  • NeedleXRSession.appClipUrl β€” launch a custom-branded Needle AppClip experience on iOS AR (provide your registered appclip.needle.tools/x/… URL or experience id) for your own App Clip card title and image
  • Physics raycast includeTriggers option
  • Unsubscribe functions returned from Input, Networking, and XR event subscriptions
  • needlePlugins() can now be called without arguments β€” the Vite command is resolved automatically

Changed

  • OrbitControls now uses lookAtTarget / lockLookAtTarget, with smoother focus and camera transitions
  • Postprocessing moved to core (context.postprocessing); tonemapping-only setups skip the extra pass
  • Timeline track classes renamed for consistency (e.g. AnimationTrackHandler β†’ TimelineAnimationTrack)
  • GroundProjectionEnv.applyOnAwake now defaults to true, matching Unity and Blender

Fixed & Improved

  • Major DragControls reliability improvements across snap points, AR drag, side views, and multi-input handover
  • More reliable camera handling (fallback camera, fitCamera, scene clearing)
  • More efficient Skybox attribute handling and load deduplication
  • Smoother, more reliable progressive LOD loading and disposal, including texture-only LODs that update correctly with camera distance
  • AudioSource on iOS now survives a device lock / audio-session interruption and resumes automatically
  • SceneSwitcher: ?scene= honored for in-scene object references, with prefab preview support
  • VoIP improvements including better iOS mic handling and shared AudioContext
  • Faster initial loading via improved dependency chunking
  • General reliability and stability improvements throughout the engine and Vite plugin

MaterialX

  • Updated bundled MaterialX runtime to 1.7.0 β€” faster environment lighting (new radiance sampling modes, PMREM support), better Three.js integration (texture sampling, environment rotation, alpha modes), and overall performance improvements
  • MaterialX export in Needle Engine projects no longer requires a PRO license

Unity Integration

  • Updated build pipeline with WAV audio compression and HDRi β†’ PMREM (FastHDR) compression for smaller, faster-loading builds
  • Needle AI chat integration with inspector and hierarchy context menus, pulling context from your local Unity and web project for more relevant assistance
  • SceneSwitcher improvements: drag-and-drop, per-scene toggle buttons, unload button, preview, and scene closing
  • WebXRImageTracking component now exposes an imageTracked UnityEvent
  • Component Compiler: new // @header directive emits a Unity [Header(...)] attribute to group and label fields in the inspector (works alongside // @tooltip):
    // @header Movement Settings
    @serializable()
    speed: number = 1;
    
  • Add: context menu action to compress the output directory (useful when a scene uses SceneSwitcher with dependencies)
  • Updated needle-cloud CLI to version 2 with security hardening
  • Sample search now matches tags and ranks results by relevance
  • Improved editor connection stability with better error recovery and cleanup

:bullseye: Download Unity Plugin :package: Install from NPM
:octopus: Changelog on Github :bookmark_tabs: Needle Engine API
:light_bulb: Get started :sparkles: Samples

Needle Engine 5.1.2

Needle Engine

Fixed

  • SyncedTransform: added world scale support β€” networked objects now keep the correct scale across clients, even when nested under scaled parents, with smooth interpolation
  • AR & XR improvements: networked avatars now use the correct scale, stale avatars are reliably removed after a peer disconnects, and remote hands display correctly in Screen AR

Unity Integration

  • Fix: MaterialX importer in the editor

:bullseye: Download Unity Plugin :package: Install from NPM
:octopus: Changelog on Github :bookmark_tabs: Needle Engine API
:light_bulb: Get started :sparkles: Samples

Needle Engine Blender Addon 1.3.0

:star: Highlights

Needle Engine 5.1

Ships with Needle Engine 5.1 β€” bringing improved DragControls, spatial audio blend, and smoother OrbitControls camera transitions.

DragControls β€” Rebuilt

DragControls received a major overhaul with refined hit regions and a dedicated screen-space drag mode for AR. New dragStarted, dragUpdated, and dragEnded events let you react to drag interactions without code.

Better Audio

AudioSource now supports spatial blend for smooth 2D/3D crossfade and survives iOS device lock without losing playback. VoIP gains volume, speakingThreshold, and createMenuButton properties with improved iOS mic handling.

  • Add: New keepScale property and dragStarted/dragUpdated/dragEnded events for DragControls
  • Add: volume, speakingThreshold, and createMenuButton properties for VoIP component
  • Change: Updated to Needle Engine 5.1
  • Change: Major DragControls overhaul β€” refined hit regions and dedicated screen-space AR drag mode
  • Change: AudioSource now supports spatial blend (2D/3D crossfade)
  • Change: OrbitControls uses smoother focus and camera transitions with lookAtTarget/lockLookAtTarget
  • Change: ContactShadows auto-refit when scene content changes (e.g. SceneSwitcher, DropListener)
  • Fix: AudioSource on iOS now survives device lock and resumes automatically
  • Fix: VoIP improvements including better iOS mic handling and shared AudioContext
  • Fix: More reliable progressive LOD loading and disposal

:bullseye: Download Blender Addon :package: Download Samples
:light_bulb: Documentation :sparkles: Live Samples