@codexo/exojs 0.11.0 → 0.13.0
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 +307 -0
- package/LICENSE +21 -0
- package/README.md +59 -23
- package/dist/esm/animation/Easing.d.ts +1 -0
- package/dist/esm/animation/Easing.d.ts.map +1 -0
- package/dist/esm/animation/Tween.d.ts +1 -0
- package/dist/esm/animation/Tween.d.ts.map +1 -0
- package/dist/esm/animation/TweenManager.d.ts +1 -0
- package/dist/esm/animation/TweenManager.d.ts.map +1 -0
- package/dist/esm/animation/index.d.ts +1 -0
- package/dist/esm/animation/index.d.ts.map +1 -0
- package/dist/esm/animation/types.d.ts +1 -0
- package/dist/esm/animation/types.d.ts.map +1 -0
- package/dist/esm/audio/AbstractMedia.d.ts +5 -4
- package/dist/esm/audio/AbstractMedia.d.ts.map +1 -0
- package/dist/esm/audio/AbstractMedia.js.map +1 -1
- package/dist/esm/audio/AudioAnalyser.d.ts +4 -3
- package/dist/esm/audio/AudioAnalyser.d.ts.map +1 -0
- package/dist/esm/audio/AudioAnalyser.js +1 -1
- package/dist/esm/audio/AudioAnalyser.js.map +1 -1
- package/dist/esm/audio/AudioBus.d.ts +1 -0
- package/dist/esm/audio/AudioBus.d.ts.map +1 -0
- package/dist/esm/audio/AudioFilter.d.ts +1 -0
- package/dist/esm/audio/AudioFilter.d.ts.map +1 -0
- package/dist/esm/audio/AudioListener.d.ts +4 -3
- package/dist/esm/audio/AudioListener.d.ts.map +1 -0
- package/dist/esm/audio/AudioManager.d.ts +1 -0
- package/dist/esm/audio/AudioManager.d.ts.map +1 -0
- package/dist/esm/audio/BeatDetector.d.ts +5 -4
- package/dist/esm/audio/BeatDetector.d.ts.map +1 -0
- package/dist/esm/audio/BeatDetector.js +1 -1
- package/dist/esm/audio/BeatDetector.js.map +1 -1
- package/dist/esm/audio/Envelope.d.ts +1 -0
- package/dist/esm/audio/Envelope.d.ts.map +1 -0
- package/dist/esm/audio/Media.d.ts +2 -1
- package/dist/esm/audio/Media.d.ts.map +1 -0
- package/dist/esm/audio/Music.d.ts +4 -3
- package/dist/esm/audio/Music.d.ts.map +1 -0
- package/dist/esm/audio/Music.js +1 -1
- package/dist/esm/audio/Music.js.map +1 -1
- package/dist/esm/audio/OscillatorSound.d.ts +2 -1
- package/dist/esm/audio/OscillatorSound.d.ts.map +1 -0
- package/dist/esm/audio/Sound.d.ts +5 -4
- package/dist/esm/audio/Sound.d.ts.map +1 -0
- package/dist/esm/audio/Sound.js +2 -2
- package/dist/esm/audio/Sound.js.map +1 -1
- package/dist/esm/audio/audio-context.d.ts +2 -1
- package/dist/esm/audio/audio-context.d.ts.map +1 -0
- package/dist/esm/audio/crossFade.d.ts +1 -0
- package/dist/esm/audio/crossFade.d.ts.map +1 -0
- package/dist/esm/audio/dsp/fft.d.ts +1 -0
- package/dist/esm/audio/dsp/fft.d.ts.map +1 -0
- package/dist/esm/audio/dsp/mel.d.ts +1 -0
- package/dist/esm/audio/dsp/mel.d.ts.map +1 -0
- package/dist/esm/audio/dsp/tempogram.d.ts +1 -0
- package/dist/esm/audio/dsp/tempogram.d.ts.map +1 -0
- package/dist/esm/audio/filters/ChorusFilter.d.ts +2 -1
- package/dist/esm/audio/filters/ChorusFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/CompressorFilter.d.ts +2 -1
- package/dist/esm/audio/filters/CompressorFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/DelayFilter.d.ts +2 -1
- package/dist/esm/audio/filters/DelayFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/DuckingFilter.d.ts +2 -1
- package/dist/esm/audio/filters/DuckingFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/DuckingFilter.js.map +1 -1
- package/dist/esm/audio/filters/EqualizerFilter.d.ts +2 -1
- package/dist/esm/audio/filters/EqualizerFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/GranularFilter.d.ts +1 -0
- package/dist/esm/audio/filters/GranularFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/GranularFilter.js.map +1 -1
- package/dist/esm/audio/filters/HighpassFilter.d.ts +2 -1
- package/dist/esm/audio/filters/HighpassFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/LowpassFilter.d.ts +2 -1
- package/dist/esm/audio/filters/LowpassFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/PitchShiftFilter.d.ts +1 -0
- package/dist/esm/audio/filters/PitchShiftFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/PitchShiftFilter.js.map +1 -1
- package/dist/esm/audio/filters/ReverbFilter.d.ts +2 -1
- package/dist/esm/audio/filters/ReverbFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/VocoderFilter.d.ts +2 -1
- package/dist/esm/audio/filters/VocoderFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/VocoderFilter.js.map +1 -1
- package/dist/esm/audio/filters/WorkletFilter.d.ts +2 -1
- package/dist/esm/audio/filters/WorkletFilter.d.ts.map +1 -0
- package/dist/esm/audio/filters/index.d.ts +1 -0
- package/dist/esm/audio/filters/index.d.ts.map +1 -0
- package/dist/esm/audio/index.d.ts +2 -1
- package/dist/esm/audio/index.d.ts.map +1 -0
- package/dist/esm/audio/worklet/registerWorklet.d.ts +1 -0
- package/dist/esm/audio/worklet/registerWorklet.d.ts.map +1 -0
- package/dist/esm/audio/worklets/beat-detector.worklet.d.ts +1 -0
- package/dist/esm/audio/worklets/beat-detector.worklet.d.ts.map +1 -0
- package/dist/esm/audio/worklets/granular.worklet.d.ts +1 -0
- package/dist/esm/audio/worklets/granular.worklet.d.ts.map +1 -0
- package/dist/esm/audio/worklets/pitch-shift.worklet.d.ts +1 -0
- package/dist/esm/audio/worklets/pitch-shift.worklet.d.ts.map +1 -0
- package/dist/esm/audio/worklets/vocoder.worklet.d.ts +1 -0
- package/dist/esm/audio/worklets/vocoder.worklet.d.ts.map +1 -0
- package/dist/esm/core/Application.d.ts +24 -14
- package/dist/esm/core/Application.d.ts.map +1 -0
- package/dist/esm/core/Application.js +50 -5
- package/dist/esm/core/Application.js.map +1 -1
- package/dist/esm/core/Bounds.d.ts +3 -2
- package/dist/esm/core/Bounds.d.ts.map +1 -0
- package/dist/esm/core/BuildInfo.d.ts +16 -0
- package/dist/esm/core/BuildInfo.d.ts.map +1 -0
- package/dist/esm/core/BuildInfo.js +8 -0
- package/dist/esm/core/BuildInfo.js.map +1 -0
- package/dist/esm/core/Clock.d.ts +1 -0
- package/dist/esm/core/Clock.d.ts.map +1 -0
- package/dist/esm/core/Clock.js +1 -1
- package/dist/esm/core/Clock.js.map +1 -1
- package/dist/esm/core/Color.d.ts +2 -1
- package/dist/esm/core/Color.d.ts.map +1 -0
- package/dist/esm/core/Color.js.map +1 -1
- package/dist/esm/core/Perf.d.ts +1 -0
- package/dist/esm/core/Perf.d.ts.map +1 -0
- package/dist/esm/core/Scene.d.ts +7 -6
- package/dist/esm/core/Scene.d.ts.map +1 -0
- package/dist/esm/core/SceneManager.d.ts +1 -0
- package/dist/esm/core/SceneManager.d.ts.map +1 -0
- package/dist/esm/core/SceneNode.d.ts +11 -10
- package/dist/esm/core/SceneNode.d.ts.map +1 -0
- package/dist/esm/core/Signal.d.ts +1 -0
- package/dist/esm/core/Signal.d.ts.map +1 -0
- package/dist/esm/core/Time.d.ts +2 -1
- package/dist/esm/core/Time.d.ts.map +1 -0
- package/dist/esm/core/Timer.d.ts +2 -1
- package/dist/esm/core/Timer.d.ts.map +1 -0
- package/dist/esm/core/Timer.js +1 -1
- package/dist/esm/core/Timer.js.map +1 -1
- package/dist/esm/core/capabilities.d.ts +1 -0
- package/dist/esm/core/capabilities.d.ts.map +1 -0
- package/dist/esm/core/dev.d.ts +1 -0
- package/dist/esm/core/dev.d.ts.map +1 -0
- package/dist/esm/core/dev.js +31 -10
- package/dist/esm/core/dev.js.map +1 -1
- package/dist/esm/core/index.d.ts +2 -0
- package/dist/esm/core/index.d.ts.map +1 -0
- package/dist/esm/core/types.d.ts +2 -1
- package/dist/esm/core/types.d.ts.map +1 -0
- package/dist/esm/core/utils.d.ts +4 -3
- package/dist/esm/core/utils.d.ts.map +1 -0
- package/dist/esm/core/utils.js +1 -1
- package/dist/esm/core/utils.js.map +1 -1
- package/dist/esm/debug/BoundingBoxesLayer.d.ts +4 -3
- package/dist/esm/debug/BoundingBoxesLayer.d.ts.map +1 -0
- package/dist/esm/debug/DebugLayer.d.ts +4 -3
- package/dist/esm/debug/DebugLayer.d.ts.map +1 -0
- package/dist/esm/debug/DebugOverlay.d.ts +2 -1
- package/dist/esm/debug/DebugOverlay.d.ts.map +1 -0
- package/dist/esm/debug/HitTestLayer.d.ts +4 -3
- package/dist/esm/debug/HitTestLayer.d.ts.map +1 -0
- package/dist/esm/debug/PerformanceLayer.d.ts +4 -3
- package/dist/esm/debug/PerformanceLayer.d.ts.map +1 -0
- package/dist/esm/debug/PointerStackLayer.d.ts +4 -3
- package/dist/esm/debug/PointerStackLayer.d.ts.map +1 -0
- package/dist/esm/debug/RenderPassInspectorLayer.d.ts +33 -4
- package/dist/esm/debug/RenderPassInspectorLayer.d.ts.map +1 -0
- package/dist/esm/debug/RenderPassInspectorLayer.js +41 -0
- package/dist/esm/debug/RenderPassInspectorLayer.js.map +1 -1
- package/dist/esm/debug/index.d.ts +2 -1
- package/dist/esm/debug/index.d.ts.map +1 -0
- package/dist/esm/extensions/Extension.d.ts +102 -0
- package/dist/esm/extensions/Extension.d.ts.map +1 -0
- package/dist/esm/extensions/ExtensionRegistry.d.ts +35 -0
- package/dist/esm/extensions/ExtensionRegistry.d.ts.map +1 -0
- package/dist/esm/extensions/ExtensionRegistry.js +63 -0
- package/dist/esm/extensions/ExtensionRegistry.js.map +1 -0
- package/dist/esm/extensions/index.d.ts +3 -0
- package/dist/esm/extensions/index.d.ts.map +1 -0
- package/dist/esm/extensions/index.js +2 -0
- package/dist/esm/extensions/index.js.map +1 -0
- package/dist/esm/extensions/materialize.d.ts +16 -0
- package/dist/esm/extensions/materialize.d.ts.map +1 -0
- package/dist/esm/extensions/materialize.js +61 -0
- package/dist/esm/extensions/materialize.js.map +1 -0
- package/dist/esm/extensions/snapshot.d.ts +26 -0
- package/dist/esm/extensions/snapshot.d.ts.map +1 -0
- package/dist/esm/extensions/snapshot.js +78 -0
- package/dist/esm/extensions/snapshot.js.map +1 -0
- package/dist/esm/extensions/testing.d.ts +7 -0
- package/dist/esm/extensions/testing.d.ts.map +1 -0
- package/dist/esm/index.d.ts +9 -8
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +29 -50
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/input/ArcadeStickGamepadMapping.d.ts +1 -0
- package/dist/esm/input/ArcadeStickGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/GameCubeGamepadMapping.d.ts +1 -0
- package/dist/esm/input/GameCubeGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/Gamepad.d.ts +2 -1
- package/dist/esm/input/Gamepad.d.ts.map +1 -0
- package/dist/esm/input/Gamepad.js +1 -1
- package/dist/esm/input/GamepadAxis.d.ts +1 -0
- package/dist/esm/input/GamepadAxis.d.ts.map +1 -0
- package/dist/esm/input/GamepadAxis.js +1 -1
- package/dist/esm/input/GamepadAxis.js.map +1 -1
- package/dist/esm/input/GamepadButton.d.ts +1 -0
- package/dist/esm/input/GamepadButton.d.ts.map +1 -0
- package/dist/esm/input/GamepadButton.js +1 -1
- package/dist/esm/input/GamepadButton.js.map +1 -1
- package/dist/esm/input/GamepadDefinitions.d.ts +1 -0
- package/dist/esm/input/GamepadDefinitions.d.ts.map +1 -0
- package/dist/esm/input/GamepadMapping.d.ts +1 -0
- package/dist/esm/input/GamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/GamepadPromptLayouts.d.ts +1 -0
- package/dist/esm/input/GamepadPromptLayouts.d.ts.map +1 -0
- package/dist/esm/input/GenericDualAnalogGamepadMapping.d.ts +1 -0
- package/dist/esm/input/GenericDualAnalogGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/GestureRecognizer.d.ts +3 -2
- package/dist/esm/input/GestureRecognizer.d.ts.map +1 -0
- package/dist/esm/input/InputBinding.d.ts +3 -2
- package/dist/esm/input/InputBinding.d.ts.map +1 -0
- package/dist/esm/input/InputManager.d.ts +4 -3
- package/dist/esm/input/InputManager.d.ts.map +1 -0
- package/dist/esm/input/InputManager.js +1 -1
- package/dist/esm/input/InteractionEvent.d.ts +2 -1
- package/dist/esm/input/InteractionEvent.d.ts.map +1 -0
- package/dist/esm/input/InteractionManager.d.ts +4 -3
- package/dist/esm/input/InteractionManager.d.ts.map +1 -0
- package/dist/esm/input/JoyConLeftGamepadMapping.d.ts +1 -0
- package/dist/esm/input/JoyConLeftGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/JoyConRightGamepadMapping.d.ts +1 -0
- package/dist/esm/input/JoyConRightGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/PlayStationGamepadMapping.d.ts +1 -0
- package/dist/esm/input/PlayStationGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/Pointer.d.ts +4 -3
- package/dist/esm/input/Pointer.d.ts.map +1 -0
- package/dist/esm/input/Pointer.js +1 -1
- package/dist/esm/input/Pointer.js.map +1 -1
- package/dist/esm/input/SteamControllerGamepadMapping.d.ts +1 -0
- package/dist/esm/input/SteamControllerGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/SteamDeckGamepadMapping.d.ts +1 -0
- package/dist/esm/input/SteamDeckGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/SwitchProGamepadMapping.d.ts +1 -0
- package/dist/esm/input/SwitchProGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/XboxGamepadMapping.d.ts +1 -0
- package/dist/esm/input/XboxGamepadMapping.d.ts.map +1 -0
- package/dist/esm/input/index.d.ts +1 -0
- package/dist/esm/input/index.d.ts.map +1 -0
- package/dist/esm/input/internal/interactionManagerRegistry.d.ts +2 -1
- package/dist/esm/input/internal/interactionManagerRegistry.d.ts.map +1 -0
- package/dist/esm/input/types.d.ts +1 -0
- package/dist/esm/input/types.d.ts.map +1 -0
- package/dist/esm/math/AbstractVector.d.ts +2 -1
- package/dist/esm/math/AbstractVector.d.ts.map +1 -0
- package/dist/esm/math/Circle.d.ts +7 -6
- package/dist/esm/math/Circle.d.ts.map +1 -0
- package/dist/esm/math/Circle.js.map +1 -1
- package/dist/esm/math/CircleLike.d.ts +1 -0
- package/dist/esm/math/CircleLike.d.ts.map +1 -0
- package/dist/esm/math/Collision.d.ts +3 -2
- package/dist/esm/math/Collision.d.ts.map +1 -0
- package/dist/esm/math/Ellipse.d.ts +7 -6
- package/dist/esm/math/Ellipse.d.ts.map +1 -0
- package/dist/esm/math/Ellipse.js.map +1 -1
- package/dist/esm/math/EllipseLike.d.ts +1 -0
- package/dist/esm/math/EllipseLike.d.ts.map +1 -0
- package/dist/esm/math/Flags.d.ts +2 -1
- package/dist/esm/math/Flags.d.ts.map +1 -0
- package/dist/esm/math/Interval.d.ts +2 -1
- package/dist/esm/math/Interval.d.ts.map +1 -0
- package/dist/esm/math/Line.d.ts +7 -6
- package/dist/esm/math/Line.d.ts.map +1 -0
- package/dist/esm/math/Line.js.map +1 -1
- package/dist/esm/math/LineLike.d.ts +1 -0
- package/dist/esm/math/LineLike.d.ts.map +1 -0
- package/dist/esm/math/Matrix.d.ts +2 -1
- package/dist/esm/math/Matrix.d.ts.map +1 -0
- package/dist/esm/math/Matrix.js.map +1 -1
- package/dist/esm/math/ObservableSize.d.ts +1 -0
- package/dist/esm/math/ObservableSize.d.ts.map +1 -0
- package/dist/esm/math/ObservableVector.d.ts +2 -1
- package/dist/esm/math/ObservableVector.d.ts.map +1 -0
- package/dist/esm/math/PointLike.d.ts +1 -0
- package/dist/esm/math/PointLike.d.ts.map +1 -0
- package/dist/esm/math/PolarVector.d.ts +2 -1
- package/dist/esm/math/PolarVector.d.ts.map +1 -0
- package/dist/esm/math/Polygon.d.ts +7 -6
- package/dist/esm/math/Polygon.d.ts.map +1 -0
- package/dist/esm/math/Polygon.js.map +1 -1
- package/dist/esm/math/PolygonLike.d.ts +2 -1
- package/dist/esm/math/PolygonLike.d.ts.map +1 -0
- package/dist/esm/math/Quadtree.d.ts +1 -0
- package/dist/esm/math/Quadtree.d.ts.map +1 -0
- package/dist/esm/math/Random.d.ts +1 -0
- package/dist/esm/math/Random.d.ts.map +1 -0
- package/dist/esm/math/Rectangle.d.ts +8 -7
- package/dist/esm/math/Rectangle.d.ts.map +1 -0
- package/dist/esm/math/Rectangle.js.map +1 -1
- package/dist/esm/math/RectangleLike.d.ts +1 -0
- package/dist/esm/math/RectangleLike.d.ts.map +1 -0
- package/dist/esm/math/Segment.d.ts +3 -2
- package/dist/esm/math/Segment.d.ts.map +1 -0
- package/dist/esm/math/Segment.js.map +1 -1
- package/dist/esm/math/ShapeLike.d.ts +3 -2
- package/dist/esm/math/ShapeLike.d.ts.map +1 -0
- package/dist/esm/math/Size.d.ts +2 -1
- package/dist/esm/math/Size.d.ts.map +1 -0
- package/dist/esm/math/Vector.d.ts +6 -5
- package/dist/esm/math/Vector.d.ts.map +1 -0
- package/dist/esm/math/Vector.js +1 -1
- package/dist/esm/math/collision-detection.d.ts +8 -7
- package/dist/esm/math/collision-detection.d.ts.map +1 -0
- package/dist/esm/math/collision-detection.js +1 -1
- package/dist/esm/math/collision-detection.js.map +1 -1
- package/dist/esm/math/collision-primitives.d.ts +3 -2
- package/dist/esm/math/collision-primitives.d.ts.map +1 -0
- package/dist/esm/math/geometry.d.ts +1 -0
- package/dist/esm/math/geometry.d.ts.map +1 -0
- package/dist/esm/math/index.d.ts +1 -0
- package/dist/esm/math/index.d.ts.map +1 -0
- package/dist/esm/math/swept-collision.d.ts +1 -0
- package/dist/esm/math/swept-collision.d.ts.map +1 -0
- package/dist/esm/math/triangulate.d.ts +1 -0
- package/dist/esm/math/triangulate.d.ts.map +1 -0
- package/dist/esm/math/utils.d.ts +2 -1
- package/dist/esm/math/utils.d.ts.map +1 -0
- package/dist/esm/renderer-sdk.d.ts +27 -0
- package/dist/esm/renderer-sdk.d.ts.map +1 -0
- package/dist/esm/rendering/BackendRenderPass.d.ts +17 -0
- package/dist/esm/rendering/BackendRenderPass.d.ts.map +1 -0
- package/dist/esm/rendering/BackendTargetPass.d.ts +38 -0
- package/dist/esm/rendering/BackendTargetPass.d.ts.map +1 -0
- package/dist/esm/rendering/{RenderTargetPass.js → BackendTargetPass.js} +12 -7
- package/dist/esm/rendering/BackendTargetPass.js.map +1 -0
- package/dist/esm/rendering/CallbackRenderPass.d.ts +38 -14
- package/dist/esm/rendering/CallbackRenderPass.d.ts.map +1 -0
- package/dist/esm/rendering/CallbackRenderPass.js +61 -13
- package/dist/esm/rendering/CallbackRenderPass.js.map +1 -1
- package/dist/esm/rendering/Camera.d.ts +3 -2
- package/dist/esm/rendering/Camera.d.ts.map +1 -0
- package/dist/esm/rendering/Camera.js.map +1 -1
- package/dist/esm/rendering/Container.d.ts +2 -1
- package/dist/esm/rendering/Container.d.ts.map +1 -0
- package/dist/esm/rendering/Drawable.d.ts +27 -3
- package/dist/esm/rendering/Drawable.d.ts.map +1 -0
- package/dist/esm/rendering/Drawable.js +35 -1
- package/dist/esm/rendering/Drawable.js.map +1 -1
- package/dist/esm/rendering/RenderBackend.d.ts +13 -10
- package/dist/esm/rendering/RenderBackend.d.ts.map +1 -0
- package/dist/esm/rendering/RenderBackendType.d.ts +1 -0
- package/dist/esm/rendering/RenderBackendType.d.ts.map +1 -0
- package/dist/esm/rendering/RenderNode.d.ts +13 -12
- package/dist/esm/rendering/RenderNode.d.ts.map +1 -0
- package/dist/esm/rendering/RenderNode.js +2 -2
- package/dist/esm/rendering/RenderNode.js.map +1 -1
- package/dist/esm/rendering/RenderNodePass.d.ts +38 -0
- package/dist/esm/rendering/RenderNodePass.d.ts.map +1 -0
- package/dist/esm/rendering/RenderNodePass.js +48 -0
- package/dist/esm/rendering/RenderNodePass.js.map +1 -0
- package/dist/esm/rendering/RenderPass.d.ts +53 -8
- package/dist/esm/rendering/RenderPass.d.ts.map +1 -0
- package/dist/esm/rendering/RenderPass.js +48 -0
- package/dist/esm/rendering/RenderPass.js.map +1 -0
- package/dist/esm/rendering/RenderPipeline.d.ts +61 -0
- package/dist/esm/rendering/RenderPipeline.d.ts.map +1 -0
- package/dist/esm/rendering/RenderPipeline.js +177 -0
- package/dist/esm/rendering/RenderPipeline.js.map +1 -0
- package/dist/esm/rendering/RenderStats.d.ts +1 -0
- package/dist/esm/rendering/RenderStats.d.ts.map +1 -0
- package/dist/esm/rendering/RenderTarget.d.ts +4 -3
- package/dist/esm/rendering/RenderTarget.d.ts.map +1 -0
- package/dist/esm/rendering/Renderer.d.ts +1 -0
- package/dist/esm/rendering/Renderer.d.ts.map +1 -0
- package/dist/esm/rendering/RendererRegistry.d.ts +13 -2
- package/dist/esm/rendering/RendererRegistry.d.ts.map +1 -0
- package/dist/esm/rendering/RendererRegistry.js +60 -7
- package/dist/esm/rendering/RendererRegistry.js.map +1 -1
- package/dist/esm/rendering/RenderingContext.d.ts +7 -6
- package/dist/esm/rendering/RenderingContext.d.ts.map +1 -0
- package/dist/esm/rendering/RenderingContext.js +5 -5
- package/dist/esm/rendering/TransformBuffer.d.ts +3 -2
- package/dist/esm/rendering/TransformBuffer.d.ts.map +1 -0
- package/dist/esm/rendering/View.d.ts +7 -6
- package/dist/esm/rendering/View.d.ts.map +1 -0
- package/dist/esm/rendering/coreRendererBindings.d.ts +10 -0
- package/dist/esm/rendering/coreRendererBindings.d.ts.map +1 -0
- package/dist/esm/rendering/coreRendererBindings.js +73 -0
- package/dist/esm/rendering/coreRendererBindings.js.map +1 -0
- package/dist/esm/rendering/filters/BlurFilter.d.ts +3 -2
- package/dist/esm/rendering/filters/BlurFilter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/BlurFilter.js +2 -2
- package/dist/esm/rendering/filters/BlurFilter.js.map +1 -1
- package/dist/esm/rendering/filters/ColorFilter.d.ts +4 -3
- package/dist/esm/rendering/filters/ColorFilter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/ColorFilter.js +2 -2
- package/dist/esm/rendering/filters/ColorFilter.js.map +1 -1
- package/dist/esm/rendering/filters/Filter.d.ts +3 -2
- package/dist/esm/rendering/filters/Filter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/LutFilter.d.ts +4 -3
- package/dist/esm/rendering/filters/LutFilter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/WebGl2ShaderFilter.d.ts +4 -3
- package/dist/esm/rendering/filters/WebGl2ShaderFilter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/WebGl2ShaderFilter.js +2 -2
- package/dist/esm/rendering/filters/WebGl2ShaderFilter.js.map +1 -1
- package/dist/esm/rendering/filters/WebGpuShaderFilter.d.ts +3 -2
- package/dist/esm/rendering/filters/WebGpuShaderFilter.d.ts.map +1 -0
- package/dist/esm/rendering/filters/WebGpuShaderFilter.js +3 -3
- package/dist/esm/rendering/filters/WebGpuShaderFilter.js.map +1 -1
- package/dist/esm/rendering/geometry/Geometry.d.ts +2 -1
- package/dist/esm/rendering/geometry/Geometry.d.ts.map +1 -0
- package/dist/esm/rendering/geometry/GeometryAttribute.d.ts +1 -0
- package/dist/esm/rendering/geometry/GeometryAttribute.d.ts.map +1 -0
- package/dist/esm/rendering/geometry/QuadGeometry.d.ts +1 -0
- package/dist/esm/rendering/geometry/QuadGeometry.d.ts.map +1 -0
- package/dist/esm/rendering/gradient/Gradient.d.ts +5 -4
- package/dist/esm/rendering/gradient/Gradient.d.ts.map +1 -0
- package/dist/esm/rendering/gradient/LinearGradient.d.ts +1 -0
- package/dist/esm/rendering/gradient/LinearGradient.d.ts.map +1 -0
- package/dist/esm/rendering/gradient/RadialGradient.d.ts +1 -0
- package/dist/esm/rendering/gradient/RadialGradient.d.ts.map +1 -0
- package/dist/esm/rendering/index.d.ts +100 -84
- package/dist/esm/rendering/index.d.ts.map +1 -0
- package/dist/esm/rendering/material/Material.d.ts +5 -4
- package/dist/esm/rendering/material/Material.d.ts.map +1 -0
- package/dist/esm/rendering/material/MaterialKey.d.ts +5 -4
- package/dist/esm/rendering/material/MaterialKey.d.ts.map +1 -0
- package/dist/esm/rendering/material/MeshMaterial.d.ts +1 -0
- package/dist/esm/rendering/material/MeshMaterial.d.ts.map +1 -0
- package/dist/esm/rendering/material/ShaderSource.d.ts +1 -0
- package/dist/esm/rendering/material/ShaderSource.d.ts.map +1 -0
- package/dist/esm/rendering/material/SpriteMaterial.d.ts +1 -0
- package/dist/esm/rendering/material/SpriteMaterial.d.ts.map +1 -0
- package/dist/esm/rendering/mesh/Mesh.d.ts +6 -5
- package/dist/esm/rendering/mesh/Mesh.d.ts.map +1 -0
- package/dist/esm/rendering/pass/RenderPassCoordinator.d.ts +8 -7
- package/dist/esm/rendering/pass/RenderPassCoordinator.d.ts.map +1 -0
- package/dist/esm/rendering/pass/RenderPassDescriptor.d.ts +4 -3
- package/dist/esm/rendering/pass/RenderPassDescriptor.d.ts.map +1 -0
- package/dist/esm/rendering/pass/RenderPassDescriptor.js.map +1 -1
- package/dist/esm/rendering/pixelSnap.d.ts +219 -0
- package/dist/esm/rendering/pixelSnap.d.ts.map +1 -0
- package/dist/esm/rendering/pixelSnap.js +186 -0
- package/dist/esm/rendering/pixelSnap.js.map +1 -0
- package/dist/esm/rendering/plan/RenderCommand.d.ts +4 -3
- package/dist/esm/rendering/plan/RenderCommand.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderEffectExecutor.d.ts +2 -1
- package/dist/esm/rendering/plan/RenderEffectExecutor.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderInstruction.d.ts +1 -0
- package/dist/esm/rendering/plan/RenderInstruction.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderPlan.d.ts +4 -3
- package/dist/esm/rendering/plan/RenderPlan.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderPlanBuilder.d.ts +5 -4
- package/dist/esm/rendering/plan/RenderPlanBuilder.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderPlanOptimizer.d.ts +1 -0
- package/dist/esm/rendering/plan/RenderPlanOptimizer.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderPlanPlayer.d.ts +2 -1
- package/dist/esm/rendering/plan/RenderPlanPlayer.d.ts.map +1 -0
- package/dist/esm/rendering/plan/RenderPlanPlayer.js +21 -1
- package/dist/esm/rendering/plan/RenderPlanPlayer.js.map +1 -1
- package/dist/esm/rendering/plan/RenderScope.d.ts +6 -5
- package/dist/esm/rendering/plan/RenderScope.d.ts.map +1 -0
- package/dist/esm/rendering/plan/playRenderTree.d.ts +3 -2
- package/dist/esm/rendering/plan/playRenderTree.d.ts.map +1 -0
- package/dist/esm/rendering/primitives/Graphics.d.ts +7 -6
- package/dist/esm/rendering/primitives/Graphics.d.ts.map +1 -0
- package/dist/esm/rendering/shader/Shader.d.ts +1 -0
- package/dist/esm/rendering/shader/Shader.d.ts.map +1 -0
- package/dist/esm/rendering/shader/ShaderAttribute.d.ts +1 -0
- package/dist/esm/rendering/shader/ShaderAttribute.d.ts.map +1 -0
- package/dist/esm/rendering/shader/ShaderUniform.d.ts +2 -1
- package/dist/esm/rendering/shader/ShaderUniform.d.ts.map +1 -0
- package/dist/esm/rendering/shader/upgradeFragmentShaderToGl300.d.ts +1 -0
- package/dist/esm/rendering/shader/upgradeFragmentShaderToGl300.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/AnimatedSprite.d.ts +6 -5
- package/dist/esm/rendering/sprite/AnimatedSprite.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/NineSliceSprite.d.ts +69 -0
- package/dist/esm/rendering/sprite/NineSliceSprite.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/NineSliceSprite.js +207 -0
- package/dist/esm/rendering/sprite/NineSliceSprite.js.map +1 -0
- package/dist/esm/rendering/sprite/RepeatingSprite.d.ts +120 -0
- package/dist/esm/rendering/sprite/RepeatingSprite.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/RepeatingSprite.js +279 -0
- package/dist/esm/rendering/sprite/RepeatingSprite.js.map +1 -0
- package/dist/esm/rendering/sprite/Sprite.d.ts +21 -7
- package/dist/esm/rendering/sprite/Sprite.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/Sprite.js +23 -0
- package/dist/esm/rendering/sprite/Sprite.js.map +1 -1
- package/dist/esm/rendering/sprite/Spritesheet.d.ts +3 -2
- package/dist/esm/rendering/sprite/Spritesheet.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/nineSlice.d.ts +53 -0
- package/dist/esm/rendering/sprite/nineSlice.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/nineSlice.js +340 -0
- package/dist/esm/rendering/sprite/nineSlice.js.map +1 -0
- package/dist/esm/rendering/sprite/repeatingSpritePlan.d.ts +57 -0
- package/dist/esm/rendering/sprite/repeatingSpritePlan.d.ts.map +1 -0
- package/dist/esm/rendering/sprite/repeatingSpritePlan.js +156 -0
- package/dist/esm/rendering/sprite/repeatingSpritePlan.js.map +1 -0
- package/dist/esm/rendering/sprite/spriteMaterialSources.d.ts +1 -0
- package/dist/esm/rendering/sprite/spriteMaterialSources.d.ts.map +1 -0
- package/dist/esm/rendering/text/AbstractText.d.ts +2 -1
- package/dist/esm/rendering/text/AbstractText.d.ts.map +1 -0
- package/dist/esm/rendering/text/BitmapText.d.ts +2 -1
- package/dist/esm/rendering/text/BitmapText.d.ts.map +1 -0
- package/dist/esm/rendering/text/BitmapText.js +1 -4
- package/dist/esm/rendering/text/BitmapText.js.map +1 -1
- package/dist/esm/rendering/text/BmFont.d.ts +2 -1
- package/dist/esm/rendering/text/BmFont.d.ts.map +1 -0
- package/dist/esm/rendering/text/GlyphAtlas.d.ts +3 -2
- package/dist/esm/rendering/text/GlyphAtlas.d.ts.map +1 -0
- package/dist/esm/rendering/text/GlyphAtlasPool.d.ts +1 -0
- package/dist/esm/rendering/text/GlyphAtlasPool.d.ts.map +1 -0
- package/dist/esm/rendering/text/GlyphSdf.d.ts +1 -0
- package/dist/esm/rendering/text/GlyphSdf.d.ts.map +1 -0
- package/dist/esm/rendering/text/GlyphSdf.js +7 -0
- package/dist/esm/rendering/text/GlyphSdf.js.map +1 -1
- package/dist/esm/rendering/text/HTMLText.d.ts +2 -1
- package/dist/esm/rendering/text/HTMLText.d.ts.map +1 -0
- package/dist/esm/rendering/text/LayoutOptions.d.ts +1 -0
- package/dist/esm/rendering/text/LayoutOptions.d.ts.map +1 -0
- package/dist/esm/rendering/text/Text.d.ts +1 -0
- package/dist/esm/rendering/text/Text.d.ts.map +1 -0
- package/dist/esm/rendering/text/TextLayout.d.ts +1 -0
- package/dist/esm/rendering/text/TextLayout.d.ts.map +1 -0
- package/dist/esm/rendering/text/TextStyle.d.ts +3 -2
- package/dist/esm/rendering/text/TextStyle.d.ts.map +1 -0
- package/dist/esm/rendering/text/types.d.ts +1 -0
- package/dist/esm/rendering/text/types.d.ts.map +1 -0
- package/dist/esm/rendering/texture/DataTexture.d.ts +3 -2
- package/dist/esm/rendering/texture/DataTexture.d.ts.map +1 -0
- package/dist/esm/rendering/texture/DataTexture.js +1 -1
- package/dist/esm/rendering/texture/DataTexture.js.map +1 -1
- package/dist/esm/rendering/texture/RenderTexture.d.ts +4 -3
- package/dist/esm/rendering/texture/RenderTexture.d.ts.map +1 -0
- package/dist/esm/rendering/texture/RenderTexture.js.map +1 -1
- package/dist/esm/rendering/texture/Sampler.d.ts +2 -1
- package/dist/esm/rendering/texture/Sampler.d.ts.map +1 -0
- package/dist/esm/rendering/texture/Texture.d.ts +4 -3
- package/dist/esm/rendering/texture/Texture.d.ts.map +1 -0
- package/dist/esm/rendering/texture/TextureRegion.d.ts +100 -0
- package/dist/esm/rendering/texture/TextureRegion.d.ts.map +1 -0
- package/dist/esm/rendering/texture/TextureRegion.js +144 -0
- package/dist/esm/rendering/texture/TextureRegion.js.map +1 -0
- package/dist/esm/rendering/texture/repeat.d.ts +96 -0
- package/dist/esm/rendering/texture/repeat.d.ts.map +1 -0
- package/dist/esm/rendering/texture/repeat.js +158 -0
- package/dist/esm/rendering/texture/repeat.js.map +1 -0
- package/dist/esm/rendering/types.d.ts +1 -0
- package/dist/esm/rendering/types.d.ts.map +1 -0
- package/dist/esm/rendering/utils.d.ts +1 -0
- package/dist/esm/rendering/utils.d.ts.map +1 -0
- package/dist/esm/rendering/video/Video.d.ts +8 -7
- package/dist/esm/rendering/video/Video.d.ts.map +1 -0
- package/dist/esm/rendering/video/Video.js.map +1 -1
- package/dist/esm/rendering/webgl2/AbstractWebGl2BatchedRenderer.d.ts +7 -6
- package/dist/esm/rendering/webgl2/AbstractWebGl2BatchedRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/AbstractWebGl2BatchedRenderer.js +1 -1
- package/dist/esm/rendering/webgl2/AbstractWebGl2Renderer.d.ts +4 -3
- package/dist/esm/rendering/webgl2/AbstractWebGl2Renderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/AbstractWebGl2Renderer.js.map +1 -1
- package/dist/esm/rendering/webgl2/WebGl2Backend.d.ts +42 -21
- package/dist/esm/rendering/webgl2/WebGl2Backend.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2Backend.js +34 -19
- package/dist/esm/rendering/webgl2/WebGl2Backend.js.map +1 -1
- package/dist/esm/rendering/webgl2/WebGl2MaskCompositor.d.ts +4 -3
- package/dist/esm/rendering/webgl2/WebGl2MaskCompositor.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2MaskCompositor.js +1 -1
- package/dist/esm/rendering/webgl2/WebGl2MeshRenderer.d.ts +2 -1
- package/dist/esm/rendering/webgl2/WebGl2MeshRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2NineSliceSpriteRenderer.d.ts +32 -0
- package/dist/esm/rendering/webgl2/WebGl2NineSliceSpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2NineSliceSpriteRenderer.js +308 -0
- package/dist/esm/rendering/webgl2/WebGl2NineSliceSpriteRenderer.js.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2PassCoordinator.d.ts +10 -9
- package/dist/esm/rendering/webgl2/WebGl2PassCoordinator.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2PassCoordinator.js +1 -1
- package/dist/esm/rendering/webgl2/WebGl2PassCoordinator.js.map +1 -1
- package/dist/esm/rendering/webgl2/WebGl2RenderBuffer.d.ts +3 -2
- package/dist/esm/rendering/webgl2/WebGl2RenderBuffer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2RepeatingSpriteRenderer.d.ts +49 -0
- package/dist/esm/rendering/webgl2/WebGl2RepeatingSpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2RepeatingSpriteRenderer.js +535 -0
- package/dist/esm/rendering/webgl2/WebGl2RepeatingSpriteRenderer.js.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2ShaderBlock.d.ts +2 -1
- package/dist/esm/rendering/webgl2/WebGl2ShaderBlock.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2ShaderBlock.js.map +1 -1
- package/dist/esm/rendering/webgl2/WebGl2ShaderMappings.d.ts +1 -0
- package/dist/esm/rendering/webgl2/WebGl2ShaderMappings.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2ShaderProgram.d.ts +2 -1
- package/dist/esm/rendering/webgl2/WebGl2ShaderProgram.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2ShaderProgram.js +1 -1
- package/dist/esm/rendering/webgl2/WebGl2SpriteRenderer.d.ts +11 -1
- package/dist/esm/rendering/webgl2/WebGl2SpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2SpriteRenderer.js +23 -3
- package/dist/esm/rendering/webgl2/WebGl2SpriteRenderer.js.map +1 -1
- package/dist/esm/rendering/webgl2/WebGl2StencilClipper.d.ts +3 -2
- package/dist/esm/rendering/webgl2/WebGl2StencilClipper.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2StencilClipper.js +1 -1
- package/dist/esm/rendering/webgl2/WebGl2TextRenderer.d.ts +3 -2
- package/dist/esm/rendering/webgl2/WebGl2TextRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgl2/WebGl2TextRenderer.js +3 -3
- package/dist/esm/rendering/webgl2/WebGl2VertexArrayObject.d.ts +3 -2
- package/dist/esm/rendering/webgl2/WebGl2VertexArrayObject.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/AbstractWebGpuRenderer.d.ts +4 -3
- package/dist/esm/rendering/webgpu/AbstractWebGpuRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/AbstractWebGpuRenderer.js.map +1 -1
- package/dist/esm/rendering/webgpu/WebGpuBackend.d.ts +41 -20
- package/dist/esm/rendering/webgpu/WebGpuBackend.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuBackend.js +31 -17
- package/dist/esm/rendering/webgpu/WebGpuBackend.js.map +1 -1
- package/dist/esm/rendering/webgpu/WebGpuBlendState.d.ts +2 -1
- package/dist/esm/rendering/webgpu/WebGpuBlendState.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuMaskCompositor.d.ts +4 -3
- package/dist/esm/rendering/webgpu/WebGpuMaskCompositor.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuMeshRenderer.d.ts +4 -3
- package/dist/esm/rendering/webgpu/WebGpuMeshRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuNineSliceSpriteRenderer.d.ts +36 -0
- package/dist/esm/rendering/webgpu/WebGpuNineSliceSpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuNineSliceSpriteRenderer.js +358 -0
- package/dist/esm/rendering/webgpu/WebGpuNineSliceSpriteRenderer.js.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuPassCoordinator.d.ts +10 -9
- package/dist/esm/rendering/webgpu/WebGpuPassCoordinator.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuRepeatingSpriteRenderer.d.ts +52 -0
- package/dist/esm/rendering/webgpu/WebGpuRepeatingSpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuRepeatingSpriteRenderer.js +556 -0
- package/dist/esm/rendering/webgpu/WebGpuRepeatingSpriteRenderer.js.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuSpriteRenderer.d.ts +13 -3
- package/dist/esm/rendering/webgpu/WebGpuSpriteRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuSpriteRenderer.js +22 -2
- package/dist/esm/rendering/webgpu/WebGpuSpriteRenderer.js.map +1 -1
- package/dist/esm/rendering/webgpu/WebGpuStencilClipper.d.ts +4 -3
- package/dist/esm/rendering/webgpu/WebGpuStencilClipper.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuStencilClipper.js.map +1 -1
- package/dist/esm/rendering/webgpu/WebGpuStencilState.d.ts +1 -0
- package/dist/esm/rendering/webgpu/WebGpuStencilState.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuTextRenderer.d.ts +3 -2
- package/dist/esm/rendering/webgpu/WebGpuTextRenderer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuTextRenderer.js +2 -2
- package/dist/esm/rendering/webgpu/WebGpuTransformStorage.d.ts +7 -5
- package/dist/esm/rendering/webgpu/WebGpuTransformStorage.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/WebGpuTransformStorage.js +4 -4
- package/dist/esm/rendering/webgpu/WebGpuTransformStorage.js.map +1 -1
- package/dist/esm/rendering/webgpu/compute/WebGpuComputePipeline.d.ts +1 -0
- package/dist/esm/rendering/webgpu/compute/WebGpuComputePipeline.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/compute/WebGpuStorageBuffer.d.ts +1 -0
- package/dist/esm/rendering/webgpu/compute/WebGpuStorageBuffer.d.ts.map +1 -0
- package/dist/esm/rendering/webgpu/compute/index.d.ts +1 -0
- package/dist/esm/rendering/webgpu/compute/index.d.ts.map +1 -0
- package/dist/esm/rendering.d.ts +29 -0
- package/dist/esm/rendering.d.ts.map +1 -0
- package/dist/esm/rendering.js +22 -0
- package/dist/esm/rendering.js.map +1 -0
- package/dist/esm/resources/AbstractAssetFactory.d.ts +1 -0
- package/dist/esm/resources/AbstractAssetFactory.d.ts.map +1 -0
- package/dist/esm/resources/Asset.d.ts +1 -0
- package/dist/esm/resources/Asset.d.ts.map +1 -0
- package/dist/esm/resources/AssetDefinitions.d.ts +9 -8
- package/dist/esm/resources/AssetDefinitions.d.ts.map +1 -0
- package/dist/esm/resources/AssetFactory.d.ts +1 -0
- package/dist/esm/resources/AssetFactory.d.ts.map +1 -0
- package/dist/esm/resources/AssetManifest.d.ts +1 -0
- package/dist/esm/resources/AssetManifest.d.ts.map +1 -0
- package/dist/esm/resources/Assets.d.ts +1 -0
- package/dist/esm/resources/Assets.d.ts.map +1 -0
- package/dist/esm/resources/CacheFirstStrategy.d.ts +1 -0
- package/dist/esm/resources/CacheFirstStrategy.d.ts.map +1 -0
- package/dist/esm/resources/CacheStore.d.ts +1 -0
- package/dist/esm/resources/CacheStore.d.ts.map +1 -0
- package/dist/esm/resources/CacheStrategy.d.ts +1 -0
- package/dist/esm/resources/CacheStrategy.d.ts.map +1 -0
- package/dist/esm/resources/Database.d.ts +1 -0
- package/dist/esm/resources/Database.d.ts.map +1 -0
- package/dist/esm/resources/FactoryRegistry.d.ts +1 -0
- package/dist/esm/resources/FactoryRegistry.d.ts.map +1 -0
- package/dist/esm/resources/IndexedDbDatabase.d.ts +2 -1
- package/dist/esm/resources/IndexedDbDatabase.d.ts.map +1 -0
- package/dist/esm/resources/IndexedDbDatabase.js.map +1 -1
- package/dist/esm/resources/IndexedDbStore.d.ts +1 -0
- package/dist/esm/resources/IndexedDbStore.d.ts.map +1 -0
- package/dist/esm/resources/JsonStore.d.ts +1 -0
- package/dist/esm/resources/JsonStore.d.ts.map +1 -0
- package/dist/esm/resources/Loader.d.ts +67 -9
- package/dist/esm/resources/Loader.d.ts.map +1 -0
- package/dist/esm/resources/Loader.js +125 -69
- package/dist/esm/resources/Loader.js.map +1 -1
- package/dist/esm/resources/LoadingQueue.d.ts +2 -1
- package/dist/esm/resources/LoadingQueue.d.ts.map +1 -0
- package/dist/esm/resources/NetworkOnlyStrategy.d.ts +1 -0
- package/dist/esm/resources/NetworkOnlyStrategy.d.ts.map +1 -0
- package/dist/esm/resources/coreAssetBindings.d.ts +8 -0
- package/dist/esm/resources/coreAssetBindings.d.ts.map +1 -0
- package/dist/esm/resources/coreAssetBindings.js +151 -0
- package/dist/esm/resources/coreAssetBindings.js.map +1 -0
- package/dist/esm/resources/factories/BinaryFactory.d.ts +2 -1
- package/dist/esm/resources/factories/BinaryFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/BmFontFactory.d.ts +5 -4
- package/dist/esm/resources/factories/BmFontFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/CsvFactory.d.ts +2 -1
- package/dist/esm/resources/factories/CsvFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/FontFactory.d.ts +2 -1
- package/dist/esm/resources/factories/FontFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/ImageFactory.d.ts +2 -1
- package/dist/esm/resources/factories/ImageFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/JsonFactory.d.ts +2 -1
- package/dist/esm/resources/factories/JsonFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/MusicFactory.d.ts +4 -3
- package/dist/esm/resources/factories/MusicFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/SoundFactory.d.ts +4 -3
- package/dist/esm/resources/factories/SoundFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/SubtitleFactory.d.ts +2 -1
- package/dist/esm/resources/factories/SubtitleFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/SvgFactory.d.ts +2 -1
- package/dist/esm/resources/factories/SvgFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/TextFactory.d.ts +2 -1
- package/dist/esm/resources/factories/TextFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/TextureFactory.d.ts +4 -3
- package/dist/esm/resources/factories/TextureFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/VideoFactory.d.ts +5 -4
- package/dist/esm/resources/factories/VideoFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/WasmFactory.d.ts +2 -1
- package/dist/esm/resources/factories/WasmFactory.d.ts.map +1 -0
- package/dist/esm/resources/factories/XmlFactory.d.ts +2 -1
- package/dist/esm/resources/factories/XmlFactory.d.ts.map +1 -0
- package/dist/esm/resources/index.d.ts +16 -15
- package/dist/esm/resources/index.d.ts.map +1 -0
- package/dist/esm/resources/tokens.d.ts +1 -0
- package/dist/esm/resources/tokens.d.ts.map +1 -0
- package/dist/esm/resources/utils.d.ts +1 -0
- package/dist/esm/resources/utils.d.ts.map +1 -0
- package/dist/exo.debug.esm.js +949 -0
- package/dist/exo.debug.esm.js.map +1 -0
- package/dist/exo.esm.js +11087 -10352
- package/dist/exo.esm.js.map +1 -1
- package/package.json +93 -58
- package/dist/esm/particles/ParticleSystem.d.ts +0 -212
- package/dist/esm/particles/ParticleSystem.js +0 -573
- package/dist/esm/particles/ParticleSystem.js.map +0 -1
- package/dist/esm/particles/distributions/BoxArea.d.ts +0 -17
- package/dist/esm/particles/distributions/BoxArea.js +0 -48
- package/dist/esm/particles/distributions/BoxArea.js.map +0 -1
- package/dist/esm/particles/distributions/CircleArea.d.ts +0 -19
- package/dist/esm/particles/distributions/CircleArea.js +0 -33
- package/dist/esm/particles/distributions/CircleArea.js.map +0 -1
- package/dist/esm/particles/distributions/ColorGradient.d.ts +0 -40
- package/dist/esm/particles/distributions/ColorGradient.js +0 -72
- package/dist/esm/particles/distributions/ColorGradient.js.map +0 -1
- package/dist/esm/particles/distributions/ConeDirection.d.ts +0 -28
- package/dist/esm/particles/distributions/ConeDirection.js +0 -44
- package/dist/esm/particles/distributions/ConeDirection.js.map +0 -1
- package/dist/esm/particles/distributions/Constant.d.ts +0 -17
- package/dist/esm/particles/distributions/Constant.js +0 -35
- package/dist/esm/particles/distributions/Constant.js.map +0 -1
- package/dist/esm/particles/distributions/Curve.d.ts +0 -30
- package/dist/esm/particles/distributions/Curve.js +0 -53
- package/dist/esm/particles/distributions/Curve.js.map +0 -1
- package/dist/esm/particles/distributions/Distribution.d.ts +0 -45
- package/dist/esm/particles/distributions/LineSegment.d.ts +0 -15
- package/dist/esm/particles/distributions/LineSegment.js +0 -27
- package/dist/esm/particles/distributions/LineSegment.js.map +0 -1
- package/dist/esm/particles/distributions/Range.d.ts +0 -12
- package/dist/esm/particles/distributions/Range.js +0 -19
- package/dist/esm/particles/distributions/Range.js.map +0 -1
- package/dist/esm/particles/distributions/VectorRange.d.ts +0 -20
- package/dist/esm/particles/distributions/VectorRange.js +0 -31
- package/dist/esm/particles/distributions/VectorRange.js.map +0 -1
- package/dist/esm/particles/distributions/index.d.ts +0 -12
- package/dist/esm/particles/gpu/ParticleGpuState.d.ts +0 -57
- package/dist/esm/particles/gpu/ParticleGpuState.js +0 -535
- package/dist/esm/particles/gpu/ParticleGpuState.js.map +0 -1
- package/dist/esm/particles/index.d.ts +0 -4
- package/dist/esm/particles/modules/AlphaFadeOverLifetime.d.ts +0 -24
- package/dist/esm/particles/modules/AlphaFadeOverLifetime.js +0 -64
- package/dist/esm/particles/modules/AlphaFadeOverLifetime.js.map +0 -1
- package/dist/esm/particles/modules/ApplyForce.d.ts +0 -20
- package/dist/esm/particles/modules/ApplyForce.js +0 -48
- package/dist/esm/particles/modules/ApplyForce.js.map +0 -1
- package/dist/esm/particles/modules/AttractToPoint.d.ts +0 -27
- package/dist/esm/particles/modules/AttractToPoint.js +0 -73
- package/dist/esm/particles/modules/AttractToPoint.js.map +0 -1
- package/dist/esm/particles/modules/BurstSpawn.d.ts +0 -53
- package/dist/esm/particles/modules/BurstSpawn.js +0 -94
- package/dist/esm/particles/modules/BurstSpawn.js.map +0 -1
- package/dist/esm/particles/modules/ColorOverLifetime.d.ts +0 -22
- package/dist/esm/particles/modules/ColorOverLifetime.js +0 -65
- package/dist/esm/particles/modules/ColorOverLifetime.js.map +0 -1
- package/dist/esm/particles/modules/ColorOverSpeed.d.ts +0 -27
- package/dist/esm/particles/modules/ColorOverSpeed.js +0 -86
- package/dist/esm/particles/modules/ColorOverSpeed.js.map +0 -1
- package/dist/esm/particles/modules/DeathModule.d.ts +0 -24
- package/dist/esm/particles/modules/DeathModule.js +0 -25
- package/dist/esm/particles/modules/DeathModule.js.map +0 -1
- package/dist/esm/particles/modules/Drag.d.ts +0 -20
- package/dist/esm/particles/modules/Drag.js +0 -43
- package/dist/esm/particles/modules/Drag.js.map +0 -1
- package/dist/esm/particles/modules/OrbitalForce.d.ts +0 -28
- package/dist/esm/particles/modules/OrbitalForce.js +0 -65
- package/dist/esm/particles/modules/OrbitalForce.js.map +0 -1
- package/dist/esm/particles/modules/RateSpawn.d.ts +0 -41
- package/dist/esm/particles/modules/RateSpawn.js +0 -76
- package/dist/esm/particles/modules/RateSpawn.js.map +0 -1
- package/dist/esm/particles/modules/RepelFromPoint.d.ts +0 -24
- package/dist/esm/particles/modules/RepelFromPoint.js +0 -76
- package/dist/esm/particles/modules/RepelFromPoint.js.map +0 -1
- package/dist/esm/particles/modules/RotateOverLifetime.d.ts +0 -20
- package/dist/esm/particles/modules/RotateOverLifetime.js +0 -41
- package/dist/esm/particles/modules/RotateOverLifetime.js.map +0 -1
- package/dist/esm/particles/modules/ScaleOverLifetime.d.ts +0 -26
- package/dist/esm/particles/modules/ScaleOverLifetime.js +0 -59
- package/dist/esm/particles/modules/ScaleOverLifetime.js.map +0 -1
- package/dist/esm/particles/modules/SpawnModule.d.ts +0 -30
- package/dist/esm/particles/modules/SpawnModule.js +0 -31
- package/dist/esm/particles/modules/SpawnModule.js.map +0 -1
- package/dist/esm/particles/modules/SpawnOnDeath.d.ts +0 -24
- package/dist/esm/particles/modules/SpawnOnDeath.js +0 -47
- package/dist/esm/particles/modules/SpawnOnDeath.js.map +0 -1
- package/dist/esm/particles/modules/Turbulence.d.ts +0 -30
- package/dist/esm/particles/modules/Turbulence.js +0 -122
- package/dist/esm/particles/modules/Turbulence.js.map +0 -1
- package/dist/esm/particles/modules/UpdateModule.d.ts +0 -95
- package/dist/esm/particles/modules/UpdateModule.js +0 -66
- package/dist/esm/particles/modules/UpdateModule.js.map +0 -1
- package/dist/esm/particles/modules/VelocityOverLifetime.d.ts +0 -30
- package/dist/esm/particles/modules/VelocityOverLifetime.js +0 -84
- package/dist/esm/particles/modules/VelocityOverLifetime.js.map +0 -1
- package/dist/esm/particles/modules/WgslContribution.d.ts +0 -81
- package/dist/esm/particles/modules/WgslContribution.js +0 -34
- package/dist/esm/particles/modules/WgslContribution.js.map +0 -1
- package/dist/esm/particles/modules/index.d.ts +0 -22
- package/dist/esm/rendering/RenderTargetPass.d.ts +0 -29
- package/dist/esm/rendering/RenderTargetPass.js.map +0 -1
- package/dist/esm/rendering/webgl2/WebGl2ParticleRenderer.d.ts +0 -45
- package/dist/esm/rendering/webgl2/WebGl2ParticleRenderer.js +0 -330
- package/dist/esm/rendering/webgl2/WebGl2ParticleRenderer.js.map +0 -1
- package/dist/esm/rendering/webgl2/glsl/particle.frag.js +0 -4
- package/dist/esm/rendering/webgl2/glsl/particle.frag.js.map +0 -1
- package/dist/esm/rendering/webgl2/glsl/particle.vert.js +0 -4
- package/dist/esm/rendering/webgl2/glsl/particle.vert.js.map +0 -1
- package/dist/esm/rendering/webgpu/WebGpuParticleRenderer.d.ts +0 -48
- package/dist/esm/rendering/webgpu/WebGpuParticleRenderer.js +0 -556
- package/dist/esm/rendering/webgpu/WebGpuParticleRenderer.js.map +0 -1
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import type { Color } from '
|
|
2
|
-
import { Matrix } from '
|
|
3
|
-
import type { Rectangle } from '
|
|
4
|
-
import type { Geometry } from '
|
|
5
|
-
import type { RenderPassCoordinator } from '
|
|
6
|
-
import type { RenderPassDescriptor, RenderPassLoad } from '
|
|
7
|
-
import type { RenderStats } from '
|
|
8
|
-
import type { RenderTarget } from '
|
|
9
|
-
import type { View } from '
|
|
1
|
+
import type { Color } from '#core/Color';
|
|
2
|
+
import { Matrix } from '#math/Matrix';
|
|
3
|
+
import type { Rectangle } from '#math/Rectangle';
|
|
4
|
+
import type { Geometry } from '#rendering/geometry/Geometry';
|
|
5
|
+
import type { RenderPassCoordinator } from '#rendering/pass/RenderPassCoordinator';
|
|
6
|
+
import type { RenderPassDescriptor, RenderPassLoad } from '#rendering/pass/RenderPassDescriptor';
|
|
7
|
+
import type { RenderStats } from '#rendering/RenderStats';
|
|
8
|
+
import type { RenderTarget } from '#rendering/RenderTarget';
|
|
9
|
+
import type { View } from '#rendering/View';
|
|
10
10
|
import { stencilAttachmentFormat } from './WebGpuStencilClipper';
|
|
11
11
|
/** Pixel-space scissor rectangle, as returned by the backend. @internal */
|
|
12
12
|
interface ScissorRect {
|
|
@@ -139,3 +139,4 @@ export declare class WebGpuPassCoordinator implements RenderPassCoordinator {
|
|
|
139
139
|
private _createStencilAttachment;
|
|
140
140
|
}
|
|
141
141
|
export { stencilAttachmentFormat };
|
|
142
|
+
//# sourceMappingURL=WebGpuPassCoordinator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WebGpuPassCoordinator.d.ts","sourceRoot":"","sources":["../../../../src/rendering/webgpu/WebGpuPassCoordinator.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AACnF,OAAO,KAAK,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACjG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,uBAAuB,EAAwB,MAAM,wBAAwB,CAAC;AAEvF,2EAA2E;AAC3E,UAAU,WAAW;IACnB,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB;AAED;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,QAAQ,CAAC,OAAO,EAAE,iBAAiB,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,oBAAoB,CAAC;IACpC,QAAQ,CAAC,YAAY,EAAE,gBAAgB,CAAC;IACxC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC;IACpB,QAAQ,CAAC,cAAc,EAAE,OAAO,CAAC;IACjC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B;AAOD;;;;;GAKG;AACH,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,YAAY,EAAE,YAAY,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC;IACpB,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC;IAC3B,QAAQ,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;IAC9C,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC;IAC5B,eAAe,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI,GAAG,OAAO,CAAC;IACtD,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,OAAO,CAAC;IACpC,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,OAAO,CAAC;IAC9B,KAAK,IAAI,OAAO,CAAC;IACjB,eAAe,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC;IAC5C,cAAc,IAAI,OAAO,CAAC;IAC1B,qBAAqB,IAAI,4BAA4B,CAAC;IACtD,cAAc,IAAI,WAAW,GAAG,IAAI,CAAC;IACrC,MAAM,CAAC,aAAa,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAC9C,kEAAkE;IAClE,iBAAiB,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC;IACjD,2EAA2E;IAC3E,uBAAuB,CAAC,MAAM,EAAE,YAAY,GAAG;QAAE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;CACpG;AAED;;;;;;;;;;GAUG;AACH,qBAAa,qBAAsB,YAAW,qBAAqB;IACjE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoB;IAC7C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA8B;IACvD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAmC;IAClE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA+C;IAC9E,OAAO,CAAC,iBAAiB,CAAS;IAClC,OAAO,CAAC,uBAAuB,CAAS;IACxC,OAAO,CAAC,cAAc,CAAqB;IAC3C,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,OAAO,CAAuC;gBAEnC,OAAO,EAAE,iBAAiB;IAI7C,IAAW,YAAY,IAAI,YAAY,CAEtC;IAED,IAAW,UAAU,IAAI,IAAI,CAE5B;IAED,IAAW,aAAa,IAAI,OAAO,CAElC;IAED,gEAAgE;IAChE,IAAW,UAAU,IAAI,sBAAsB,GAAG,IAAI,CAErD;IAED;;;;;OAKG;IACH,IAAW,aAAa,IAAI,OAAO,CAElC;IAED,qFAAqF;IACrF,IAAW,gBAAgB,IAAI,MAAM,CAEpC;IAED;;;;;OAKG;IACI,WAAW,IAAI,sBAAsB;IA0C5C,8DAA8D;IACvD,OAAO,IAAI,IAAI;IAYf,SAAS,CAAC,UAAU,EAAE,oBAAoB,GAAG,IAAI;IASjD,aAAa,CAAC,UAAU,EAAE,oBAAoB,EAAE,IAAI,EAAE,MAAM,IAAI,GAAG,IAAI;IAiBvE,eAAe,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI;IAIxC,cAAc,IAAI,IAAI;IAI7B;;;;;OAKG;IACI,eAAe,CAAC,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IA4BhE,wFAAwF;IACjF,cAAc,IAAI,IAAI;IA4BtB,WAAW,CAAC,MAAM,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,GAAG,cAAc;IAOjF;;;;OAIG;IACI,oBAAoB,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IASvD;;;;;OAKG;IACI,YAAY,IAAI,IAAI;IAO3B,qFAAqF;IAC9E,cAAc,IAAI,IAAI;IAY7B,yFAAyF;IAClF,sBAAsB,IAAI,MAAM;IAUvC,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,gBAAgB;IAWxB,OAAO,CAAC,wBAAwB;CAqBjC;AAED,OAAO,EAAE,uBAAuB,EAAE,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { RepeatingSprite } from '#rendering/sprite/RepeatingSprite';
|
|
2
|
+
import { AbstractWebGpuRenderer } from './AbstractWebGpuRenderer';
|
|
3
|
+
import type { WebGpuBackend } from './WebGpuBackend';
|
|
4
|
+
/** Instanced renderer for {@link RepeatingSprite} using WebGPU. */
|
|
5
|
+
export declare class WebGpuRepeatingSpriteRenderer extends AbstractWebGpuRenderer<RepeatingSprite> {
|
|
6
|
+
private readonly _projData;
|
|
7
|
+
private _device;
|
|
8
|
+
private _uniformBindGroupLayout;
|
|
9
|
+
private _textureBindGroupLayout;
|
|
10
|
+
private _shaderModule;
|
|
11
|
+
private _uniformBuffer;
|
|
12
|
+
private _indexBuffer;
|
|
13
|
+
private _transformBindGroup;
|
|
14
|
+
private _transformStorageBuf;
|
|
15
|
+
private readonly _pipelines;
|
|
16
|
+
private readonly _samplers;
|
|
17
|
+
private _shaderInstBuf;
|
|
18
|
+
private _shaderInstCapacity;
|
|
19
|
+
private _shaderInstData;
|
|
20
|
+
private _shaderInstF32;
|
|
21
|
+
private _shaderInstU32;
|
|
22
|
+
private _shaderQuadCount;
|
|
23
|
+
private _geoInstBuf;
|
|
24
|
+
private _geoInstCapacity;
|
|
25
|
+
private _geoInstData;
|
|
26
|
+
private _geoInstF32;
|
|
27
|
+
private _geoInstU32;
|
|
28
|
+
private _geoQuadCount;
|
|
29
|
+
private _maxNodeIndex;
|
|
30
|
+
private _currentTexture;
|
|
31
|
+
private _currentBlendMode;
|
|
32
|
+
private _currentModeX;
|
|
33
|
+
private _currentModeY;
|
|
34
|
+
private _currentPath;
|
|
35
|
+
private readonly _snapBounds;
|
|
36
|
+
protected onConnect(backend: WebGpuBackend): void;
|
|
37
|
+
protected onDisconnect(): void;
|
|
38
|
+
render(sprite: RepeatingSprite): void;
|
|
39
|
+
private _writeShaderInstance;
|
|
40
|
+
private _writeGeoQuads;
|
|
41
|
+
flush(): void;
|
|
42
|
+
private _drawShaderBatch;
|
|
43
|
+
private _drawGeoBatch;
|
|
44
|
+
destroy(): void;
|
|
45
|
+
private _getOrCreateSampler;
|
|
46
|
+
private _getOrCreateTransformBindGroup;
|
|
47
|
+
private _getPipeline;
|
|
48
|
+
private _ensureShaderCapacity;
|
|
49
|
+
private _ensureGeoCapacity;
|
|
50
|
+
private _growCapacity;
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=WebGpuRepeatingSpriteRenderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WebGpuRepeatingSpriteRenderer.d.ts","sourceRoot":"","sources":["../../../../src/rendering/webgpu/WebGpuRepeatingSpriteRenderer.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAOzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAmIrD,mEAAmE;AACnE,qBAAa,6BAA8B,SAAQ,sBAAsB,CAAC,eAAe,CAAC;IACxF,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA2E;IAGrG,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,uBAAuB,CAAmC;IAClE,OAAO,CAAC,uBAAuB,CAAmC;IAClE,OAAO,CAAC,aAAa,CAAgC;IACrD,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,YAAY,CAA0B;IAC9C,OAAO,CAAC,mBAAmB,CAA6B;IACxD,OAAO,CAAC,oBAAoB,CAA0B;IACtD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAwC;IACnE,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAiC;IAG3D,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,mBAAmB,CAAK;IAChC,OAAO,CAAC,eAAe,CAAmC;IAC1D,OAAO,CAAC,cAAc,CAA0C;IAChE,OAAO,CAAC,cAAc,CAAyC;IAC/D,OAAO,CAAC,gBAAgB,CAAK;IAG7B,OAAO,CAAC,WAAW,CAA0B;IAC7C,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,YAAY,CAAmC;IACvD,OAAO,CAAC,WAAW,CAAuC;IAC1D,OAAO,CAAC,WAAW,CAAsC;IACzD,OAAO,CAAC,aAAa,CAAK;IAG1B,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,eAAe,CAAwC;IAC/D,OAAO,CAAC,iBAAiB,CAA2B;IACpD,OAAO,CAAC,aAAa,CAA2B;IAChD,OAAO,CAAC,aAAa,CAA2B;IAChD,OAAO,CAAC,YAAY,CAAsC;IAE1D,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAmB;IAE/C,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAkCjD,SAAS,CAAC,YAAY,IAAI,IAAI;IAuCvB,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI;IA6C5C,OAAO,CAAC,oBAAoB;IAgD5B,OAAO,CAAC,cAAc;IA+Cf,KAAK,IAAI,IAAI;IAyCpB,OAAO,CAAC,gBAAgB;IAmCxB,OAAO,CAAC,aAAa;IAiCd,OAAO,IAAI,IAAI;IAQtB,OAAO,CAAC,mBAAmB;IAe3B,OAAO,CAAC,8BAA8B;IAetC,OAAO,CAAC,YAAY;IA8DpB,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,kBAAkB;IAgB1B,OAAO,CAAC,aAAa;CAKtB"}
|
|
@@ -0,0 +1,556 @@
|
|
|
1
|
+
import { Rectangle } from '../../math/Rectangle.js';
|
|
2
|
+
import { computeShaderTiling } from '../sprite/repeatingSpritePlan.js';
|
|
3
|
+
import { Texture } from '../texture/Texture.js';
|
|
4
|
+
import '../types.js';
|
|
5
|
+
import { AbstractWebGpuRenderer } from './AbstractWebGpuRenderer.js';
|
|
6
|
+
import { getWebGpuBlendState } from './WebGpuBlendState.js';
|
|
7
|
+
import { stencilContentDepthStencilState } from './WebGpuStencilState.js';
|
|
8
|
+
|
|
9
|
+
/// <reference types="@webgpu/types" />
|
|
10
|
+
// ---------------------------------------------------------------------------
|
|
11
|
+
// Shared WGSL declarations — structs, bindings, and output struct used by
|
|
12
|
+
// both the shader path and the geometry path entry points.
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
const commonWgsl = `
|
|
15
|
+
struct ProjectionUniforms {
|
|
16
|
+
matrix: mat4x4<f32>,
|
|
17
|
+
};
|
|
18
|
+
struct TransformSlot {
|
|
19
|
+
m0: vec4<f32>,
|
|
20
|
+
m1: vec4<f32>,
|
|
21
|
+
m2: vec4<f32>,
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
@group(0) @binding(0) var<uniform> projection: ProjectionUniforms;
|
|
25
|
+
@group(0) @binding(1) var<storage, read> transforms: array<TransformSlot>;
|
|
26
|
+
@group(1) @binding(0) var spriteTexture: texture_2d<f32>;
|
|
27
|
+
@group(1) @binding(1) var spriteSampler: sampler;
|
|
28
|
+
|
|
29
|
+
struct VOut {
|
|
30
|
+
@builtin(position) pos: vec4<f32>,
|
|
31
|
+
@location(0) uv: vec2<f32>,
|
|
32
|
+
@location(1) color: vec4<f32>,
|
|
33
|
+
};
|
|
34
|
+
`;
|
|
35
|
+
// ---------------------------------------------------------------------------
|
|
36
|
+
// Shader path WGSL — one quad per sprite, UVs computed in vertex shader.
|
|
37
|
+
// ---------------------------------------------------------------------------
|
|
38
|
+
const shaderPathEntries = `
|
|
39
|
+
struct ShaderVIn {
|
|
40
|
+
@location(0) quadBounds: vec4<f32>, // x0,y0,x1,y1
|
|
41
|
+
@location(1) uvParams: vec4<f32>, // tilingX, tilingY, offsetU, offsetV
|
|
42
|
+
@location(2) color: vec4<f32>, // RGBA tint
|
|
43
|
+
@location(3) nodeIndex: u32,
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
@vertex
|
|
47
|
+
fn shaderVert(input: ShaderVIn, @builtin(vertex_index) vid: u32) -> VOut {
|
|
48
|
+
var out: VOut;
|
|
49
|
+
let cx = ((vid + 1u) >> 1u) & 1u;
|
|
50
|
+
let cy = vid >> 1u;
|
|
51
|
+
let lx = select(input.quadBounds.x, input.quadBounds.z, cx == 1u);
|
|
52
|
+
let ly = select(input.quadBounds.y, input.quadBounds.w, cy == 1u);
|
|
53
|
+
|
|
54
|
+
let destW = input.quadBounds.z - input.quadBounds.x;
|
|
55
|
+
let destH = input.quadBounds.w - input.quadBounds.y;
|
|
56
|
+
|
|
57
|
+
let slot = transforms[input.nodeIndex];
|
|
58
|
+
let wx = slot.m0.x * lx + slot.m0.y * ly + slot.m1.x;
|
|
59
|
+
let wy = slot.m0.z * lx + slot.m0.w * ly + slot.m1.y;
|
|
60
|
+
out.pos = projection.matrix * vec4<f32>(wx, wy, 0.0, 1.0);
|
|
61
|
+
|
|
62
|
+
let u = select(input.uvParams.z, ((lx - input.quadBounds.x) / destW) * input.uvParams.x + input.uvParams.z, destW > 0.0);
|
|
63
|
+
let v = select(input.uvParams.w, ((ly - input.quadBounds.y) / destH) * input.uvParams.y + input.uvParams.w, destH > 0.0);
|
|
64
|
+
out.uv = vec2<f32>(u, v);
|
|
65
|
+
out.color = vec4<f32>(input.color.rgb * input.color.a, input.color.a);
|
|
66
|
+
return out;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
@fragment
|
|
70
|
+
fn shaderFrag(input: VOut) -> @location(0) vec4<f32> {
|
|
71
|
+
return textureSample(spriteTexture, spriteSampler, input.uv) * input.color;
|
|
72
|
+
}
|
|
73
|
+
`;
|
|
74
|
+
// ---------------------------------------------------------------------------
|
|
75
|
+
// Geometry path WGSL — N quads per sprite, UVs pre-computed in CPU.
|
|
76
|
+
// ---------------------------------------------------------------------------
|
|
77
|
+
const geoPathEntries = `
|
|
78
|
+
struct GeoVIn {
|
|
79
|
+
@location(0) quadBounds: vec4<f32>, // x0,y0,x1,y1
|
|
80
|
+
@location(1) uvBounds: vec4<f32>, // u0,v0,u1,v1 (normalised, flipY pre-applied)
|
|
81
|
+
@location(2) color: vec4<f32>, // RGBA tint
|
|
82
|
+
@location(3) nodeIndex: u32,
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
@vertex
|
|
86
|
+
fn geoVert(input: GeoVIn, @builtin(vertex_index) vid: u32) -> VOut {
|
|
87
|
+
var out: VOut;
|
|
88
|
+
let cx = ((vid + 1u) >> 1u) & 1u;
|
|
89
|
+
let cy = vid >> 1u;
|
|
90
|
+
let lx = select(input.quadBounds.x, input.quadBounds.z, cx == 1u);
|
|
91
|
+
let ly = select(input.quadBounds.y, input.quadBounds.w, cy == 1u);
|
|
92
|
+
|
|
93
|
+
let slot = transforms[input.nodeIndex];
|
|
94
|
+
let wx = slot.m0.x * lx + slot.m0.y * ly + slot.m1.x;
|
|
95
|
+
let wy = slot.m0.z * lx + slot.m0.w * ly + slot.m1.y;
|
|
96
|
+
out.pos = projection.matrix * vec4<f32>(wx, wy, 0.0, 1.0);
|
|
97
|
+
|
|
98
|
+
let u = select(input.uvBounds.x, input.uvBounds.z, cx == 1u);
|
|
99
|
+
let v = select(input.uvBounds.y, input.uvBounds.w, cy == 1u);
|
|
100
|
+
out.uv = vec2<f32>(u, v);
|
|
101
|
+
out.color = vec4<f32>(input.color.rgb * input.color.a, input.color.a);
|
|
102
|
+
return out;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
@fragment
|
|
106
|
+
fn geoFrag(input: VOut) -> @location(0) vec4<f32> {
|
|
107
|
+
return textureSample(spriteTexture, spriteSampler, input.uv) * input.color;
|
|
108
|
+
}
|
|
109
|
+
`;
|
|
110
|
+
// ---------------------------------------------------------------------------
|
|
111
|
+
// Layout constants
|
|
112
|
+
// ---------------------------------------------------------------------------
|
|
113
|
+
const shaderStrideBytes = 40; // float32x4 bounds + float32x4 uvParams + unorm8x4 + uint32
|
|
114
|
+
const geoStrideBytes = 32; // float32x4 bounds + unorm16x4 + unorm8x4 + uint32 (NineSlice layout)
|
|
115
|
+
const projectionByteLength = 64;
|
|
116
|
+
const initialBatchCapacity = 32;
|
|
117
|
+
const indicesPerInstance = 6;
|
|
118
|
+
const quadIndices = new Uint16Array([0, 1, 2, 0, 2, 3]);
|
|
119
|
+
// ---------------------------------------------------------------------------
|
|
120
|
+
// Sampler address mode helper
|
|
121
|
+
// ---------------------------------------------------------------------------
|
|
122
|
+
function repeatModeToAddressMode(mode) {
|
|
123
|
+
if (mode === 'repeat')
|
|
124
|
+
return 'repeat';
|
|
125
|
+
if (mode === 'mirror-repeat')
|
|
126
|
+
return 'mirror-repeat';
|
|
127
|
+
return 'clamp-to-edge';
|
|
128
|
+
}
|
|
129
|
+
/** Instanced renderer for {@link RepeatingSprite} using WebGPU. */
|
|
130
|
+
class WebGpuRepeatingSpriteRenderer extends AbstractWebGpuRenderer {
|
|
131
|
+
_projData = new Float32Array(projectionByteLength / Float32Array.BYTES_PER_ELEMENT);
|
|
132
|
+
// Shared GPU objects
|
|
133
|
+
_device = null;
|
|
134
|
+
_uniformBindGroupLayout = null;
|
|
135
|
+
_textureBindGroupLayout = null;
|
|
136
|
+
_shaderModule = null;
|
|
137
|
+
_uniformBuffer = null;
|
|
138
|
+
_indexBuffer = null;
|
|
139
|
+
_transformBindGroup = null;
|
|
140
|
+
_transformStorageBuf = null;
|
|
141
|
+
_pipelines = new Map();
|
|
142
|
+
_samplers = new Map();
|
|
143
|
+
// Shader-path instance buffer
|
|
144
|
+
_shaderInstBuf = null;
|
|
145
|
+
_shaderInstCapacity = 0;
|
|
146
|
+
_shaderInstData = new ArrayBuffer(0);
|
|
147
|
+
_shaderInstF32 = new Float32Array(this._shaderInstData);
|
|
148
|
+
_shaderInstU32 = new Uint32Array(this._shaderInstData);
|
|
149
|
+
_shaderQuadCount = 0;
|
|
150
|
+
// Geometry-path instance buffer
|
|
151
|
+
_geoInstBuf = null;
|
|
152
|
+
_geoInstCapacity = 0;
|
|
153
|
+
_geoInstData = new ArrayBuffer(0);
|
|
154
|
+
_geoInstF32 = new Float32Array(this._geoInstData);
|
|
155
|
+
_geoInstU32 = new Uint32Array(this._geoInstData);
|
|
156
|
+
_geoQuadCount = 0;
|
|
157
|
+
// Shared batch state
|
|
158
|
+
_maxNodeIndex = 0;
|
|
159
|
+
_currentTexture = null;
|
|
160
|
+
_currentBlendMode = null;
|
|
161
|
+
_currentModeX = null;
|
|
162
|
+
_currentModeY = null;
|
|
163
|
+
_currentPath = null;
|
|
164
|
+
// Reusable scratch for device-snapped bounds ('geometry' mode).
|
|
165
|
+
_snapBounds = new Rectangle();
|
|
166
|
+
onConnect(backend) {
|
|
167
|
+
if (this._device)
|
|
168
|
+
return;
|
|
169
|
+
const device = backend.device;
|
|
170
|
+
this._device = device;
|
|
171
|
+
this._shaderModule = device.createShaderModule({ code: commonWgsl + shaderPathEntries + geoPathEntries });
|
|
172
|
+
this._uniformBindGroupLayout = device.createBindGroupLayout({
|
|
173
|
+
entries: [
|
|
174
|
+
{ binding: 0, visibility: GPUShaderStage.VERTEX, buffer: { type: 'uniform' } },
|
|
175
|
+
{ binding: 1, visibility: GPUShaderStage.VERTEX, buffer: { type: 'read-only-storage' } },
|
|
176
|
+
],
|
|
177
|
+
});
|
|
178
|
+
this._textureBindGroupLayout = device.createBindGroupLayout({
|
|
179
|
+
entries: [
|
|
180
|
+
{ binding: 0, visibility: GPUShaderStage.FRAGMENT, texture: { sampleType: 'float' } },
|
|
181
|
+
{ binding: 1, visibility: GPUShaderStage.FRAGMENT, sampler: { type: 'filtering' } },
|
|
182
|
+
],
|
|
183
|
+
});
|
|
184
|
+
this._uniformBuffer = device.createBuffer({
|
|
185
|
+
size: projectionByteLength,
|
|
186
|
+
usage: GPUBufferUsage.UNIFORM | GPUBufferUsage.COPY_DST,
|
|
187
|
+
});
|
|
188
|
+
this._indexBuffer = device.createBuffer({
|
|
189
|
+
size: quadIndices.byteLength,
|
|
190
|
+
usage: GPUBufferUsage.INDEX | GPUBufferUsage.COPY_DST,
|
|
191
|
+
});
|
|
192
|
+
device.queue.writeBuffer(this._indexBuffer, 0, quadIndices.buffer, quadIndices.byteOffset, quadIndices.byteLength);
|
|
193
|
+
}
|
|
194
|
+
onDisconnect() {
|
|
195
|
+
this._shaderInstBuf?.destroy();
|
|
196
|
+
this._geoInstBuf?.destroy();
|
|
197
|
+
this._indexBuffer?.destroy();
|
|
198
|
+
this._uniformBuffer?.destroy();
|
|
199
|
+
this._pipelines.clear();
|
|
200
|
+
this._samplers.clear();
|
|
201
|
+
this._shaderInstBuf = null;
|
|
202
|
+
this._geoInstBuf = null;
|
|
203
|
+
this._indexBuffer = null;
|
|
204
|
+
this._uniformBuffer = null;
|
|
205
|
+
this._transformBindGroup = null;
|
|
206
|
+
this._transformStorageBuf = null;
|
|
207
|
+
this._textureBindGroupLayout = null;
|
|
208
|
+
this._uniformBindGroupLayout = null;
|
|
209
|
+
this._shaderModule = null;
|
|
210
|
+
this._device = null;
|
|
211
|
+
this._backend = null;
|
|
212
|
+
this._shaderInstCapacity = 0;
|
|
213
|
+
this._shaderInstData = new ArrayBuffer(0);
|
|
214
|
+
this._shaderInstF32 = new Float32Array(this._shaderInstData);
|
|
215
|
+
this._shaderInstU32 = new Uint32Array(this._shaderInstData);
|
|
216
|
+
this._geoInstCapacity = 0;
|
|
217
|
+
this._geoInstData = new ArrayBuffer(0);
|
|
218
|
+
this._geoInstF32 = new Float32Array(this._geoInstData);
|
|
219
|
+
this._geoInstU32 = new Uint32Array(this._geoInstData);
|
|
220
|
+
this._shaderQuadCount = 0;
|
|
221
|
+
this._geoQuadCount = 0;
|
|
222
|
+
this._maxNodeIndex = 0;
|
|
223
|
+
this._currentTexture = null;
|
|
224
|
+
this._currentBlendMode = null;
|
|
225
|
+
this._currentModeX = null;
|
|
226
|
+
this._currentModeY = null;
|
|
227
|
+
this._currentPath = null;
|
|
228
|
+
}
|
|
229
|
+
render(sprite) {
|
|
230
|
+
const backend = this._backend;
|
|
231
|
+
if (!backend)
|
|
232
|
+
return;
|
|
233
|
+
const texture = sprite.texture;
|
|
234
|
+
if (texture instanceof Texture && texture.source === null)
|
|
235
|
+
return;
|
|
236
|
+
if (texture.width === 0 || texture.height === 0)
|
|
237
|
+
return;
|
|
238
|
+
const strategy = sprite.resolvedStrategy;
|
|
239
|
+
const blendMode = sprite.blendMode;
|
|
240
|
+
const modeX = sprite.modeX;
|
|
241
|
+
const modeY = sprite.modeY;
|
|
242
|
+
const hasData = this._shaderQuadCount > 0 || this._geoQuadCount > 0;
|
|
243
|
+
if (hasData) {
|
|
244
|
+
const pathChanged = this._currentPath !== strategy;
|
|
245
|
+
const texChanged = this._currentTexture !== texture;
|
|
246
|
+
const blendChanged = this._currentBlendMode !== blendMode;
|
|
247
|
+
const modeChanged = strategy === 'shader'
|
|
248
|
+
&& (this._currentModeX !== modeX || this._currentModeY !== modeY);
|
|
249
|
+
if (pathChanged || texChanged || blendChanged || modeChanged) {
|
|
250
|
+
this.flush();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
this._currentTexture = texture;
|
|
254
|
+
this._currentBlendMode = blendMode;
|
|
255
|
+
this._currentPath = strategy;
|
|
256
|
+
backend.setBlendMode(blendMode);
|
|
257
|
+
const command = backend.activeDrawCommand;
|
|
258
|
+
const nodeIndex = command !== null ? command.nodeIndex : backend._pushTransform(sprite);
|
|
259
|
+
if (nodeIndex > this._maxNodeIndex)
|
|
260
|
+
this._maxNodeIndex = nodeIndex;
|
|
261
|
+
if (strategy === 'shader') {
|
|
262
|
+
this._currentModeX = modeX;
|
|
263
|
+
this._currentModeY = modeY;
|
|
264
|
+
this._writeShaderInstance(sprite, nodeIndex);
|
|
265
|
+
}
|
|
266
|
+
else {
|
|
267
|
+
this._writeGeoQuads(sprite, nodeIndex);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
_writeShaderInstance(sprite, nodeIndex) {
|
|
271
|
+
const texture = sprite.texture;
|
|
272
|
+
const srcW = sprite.region.width;
|
|
273
|
+
const srcH = sprite.region.height;
|
|
274
|
+
let destW = sprite.width;
|
|
275
|
+
let destH = sprite.height;
|
|
276
|
+
const flipY = texture instanceof Texture && texture.flipY;
|
|
277
|
+
// 'geometry' mode: snap the destination quad to the device grid. Repetition
|
|
278
|
+
// stays shader-based; only the outer rectangle (and the tiling derived from
|
|
279
|
+
// it) moves. Position/none leave the destination unchanged.
|
|
280
|
+
if (sprite.pixelSnapMode === 'geometry') {
|
|
281
|
+
const backend = this.getBackend();
|
|
282
|
+
const snap = backend._getSnapPixelSize();
|
|
283
|
+
const rb = sprite.getRenderBounds(backend.view, snap.width, snap.height, this._snapBounds);
|
|
284
|
+
destW = rb.width;
|
|
285
|
+
destH = rb.height;
|
|
286
|
+
}
|
|
287
|
+
const tilingX = computeShaderTiling(srcW, destW, sprite.modeX, sprite.fitX);
|
|
288
|
+
const tilingY = computeShaderTiling(srcH, destH, sprite.modeY, sprite.fitY);
|
|
289
|
+
const offsetU = sprite.offsetX / (srcW > 0 ? srcW : 1);
|
|
290
|
+
const offsetV = sprite.offsetY / (srcH > 0 ? srcH : 1);
|
|
291
|
+
const uvParamY = flipY ? -tilingY : tilingY;
|
|
292
|
+
const uvParamW = flipY ? tilingY + offsetV : offsetV;
|
|
293
|
+
this._ensureShaderCapacity(this._shaderQuadCount + 1);
|
|
294
|
+
const words = shaderStrideBytes / 4;
|
|
295
|
+
const offset = this._shaderQuadCount * words;
|
|
296
|
+
const f32 = this._shaderInstF32;
|
|
297
|
+
const u32 = this._shaderInstU32;
|
|
298
|
+
f32[offset + 0] = 0;
|
|
299
|
+
f32[offset + 1] = 0;
|
|
300
|
+
f32[offset + 2] = destW;
|
|
301
|
+
f32[offset + 3] = destH;
|
|
302
|
+
f32[offset + 4] = tilingX;
|
|
303
|
+
f32[offset + 5] = uvParamY;
|
|
304
|
+
f32[offset + 6] = offsetU;
|
|
305
|
+
f32[offset + 7] = uvParamW;
|
|
306
|
+
u32[offset + 8] = sprite.tint.toRgba();
|
|
307
|
+
u32[offset + 9] = nodeIndex >>> 0;
|
|
308
|
+
this._shaderQuadCount++;
|
|
309
|
+
}
|
|
310
|
+
_writeGeoQuads(sprite, nodeIndex) {
|
|
311
|
+
let quads = sprite.quads;
|
|
312
|
+
// 'geometry' mode: snap shared segment boundaries once (gap-free), like NineSlice.
|
|
313
|
+
if (sprite.pixelSnapMode === 'geometry') {
|
|
314
|
+
const backend = this.getBackend();
|
|
315
|
+
const snap = backend._getSnapPixelSize();
|
|
316
|
+
quads = sprite.getRenderQuads(backend.view, snap.width, snap.height);
|
|
317
|
+
}
|
|
318
|
+
if (quads.length === 0)
|
|
319
|
+
return;
|
|
320
|
+
const flipY = (sprite.texture instanceof Texture) && sprite.texture.flipY;
|
|
321
|
+
const tint = sprite.tint.toRgba();
|
|
322
|
+
const words = geoStrideBytes / 4;
|
|
323
|
+
this._ensureGeoCapacity(this._geoQuadCount + quads.length);
|
|
324
|
+
const f32 = this._geoInstF32;
|
|
325
|
+
const u32 = this._geoInstU32;
|
|
326
|
+
for (let i = 0; i < quads.length; i++) {
|
|
327
|
+
const q = quads[i];
|
|
328
|
+
const offset = (this._geoQuadCount + i) * words;
|
|
329
|
+
f32[offset + 0] = q.x0;
|
|
330
|
+
f32[offset + 1] = q.y0;
|
|
331
|
+
f32[offset + 2] = q.x1;
|
|
332
|
+
f32[offset + 3] = q.y1;
|
|
333
|
+
const uMin = (q.u0 * 0xffff) & 0xffff;
|
|
334
|
+
const uMax = (q.u1 * 0xffff) & 0xffff;
|
|
335
|
+
const v0Raw = (q.v0 * 0xffff) & 0xffff;
|
|
336
|
+
const v1Raw = (q.v1 * 0xffff) & 0xffff;
|
|
337
|
+
const vMin = flipY ? v1Raw : v0Raw;
|
|
338
|
+
const vMax = flipY ? v0Raw : v1Raw;
|
|
339
|
+
u32[offset + 4] = uMin | (vMin << 16);
|
|
340
|
+
u32[offset + 5] = uMax | (vMax << 16);
|
|
341
|
+
u32[offset + 6] = tint;
|
|
342
|
+
u32[offset + 7] = nodeIndex >>> 0;
|
|
343
|
+
}
|
|
344
|
+
this._geoQuadCount += quads.length;
|
|
345
|
+
}
|
|
346
|
+
flush() {
|
|
347
|
+
const backend = this._backend;
|
|
348
|
+
const device = this._device;
|
|
349
|
+
const uniform = this._uniformBuffer;
|
|
350
|
+
if (!backend || !device || !uniform)
|
|
351
|
+
return;
|
|
352
|
+
if (this._shaderQuadCount === 0 && this._geoQuadCount === 0 && !backend.clearRequested) {
|
|
353
|
+
return;
|
|
354
|
+
}
|
|
355
|
+
const vm = backend.view.getTransform();
|
|
356
|
+
this._projData.set([vm.a, vm.c, 0, 0, vm.b, vm.d, 0, 0, 0, 0, 1, 0, vm.x, vm.y, 0, vm.z]);
|
|
357
|
+
device.queue.writeBuffer(uniform, 0, this._projData.buffer, this._projData.byteOffset, this._projData.byteLength);
|
|
358
|
+
const scissor = backend.getScissorRect();
|
|
359
|
+
const maskClipsAll = scissor !== null && (scissor.width <= 0 || scissor.height <= 0);
|
|
360
|
+
const pass = backend._passCoordinator.acquirePass().pass;
|
|
361
|
+
const stencil = backend._passCoordinator.stencilActive;
|
|
362
|
+
if (this._shaderQuadCount > 0 && !maskClipsAll) {
|
|
363
|
+
this._drawShaderBatch(device, backend, pass, stencil);
|
|
364
|
+
}
|
|
365
|
+
if (this._geoQuadCount > 0 && !maskClipsAll) {
|
|
366
|
+
this._drawGeoBatch(device, backend, pass, stencil);
|
|
367
|
+
}
|
|
368
|
+
backend._passCoordinator.endPass();
|
|
369
|
+
this._shaderQuadCount = 0;
|
|
370
|
+
this._geoQuadCount = 0;
|
|
371
|
+
this._maxNodeIndex = 0;
|
|
372
|
+
this._currentTexture = null;
|
|
373
|
+
this._currentBlendMode = null;
|
|
374
|
+
this._currentModeX = null;
|
|
375
|
+
this._currentModeY = null;
|
|
376
|
+
this._currentPath = null;
|
|
377
|
+
}
|
|
378
|
+
_drawShaderBatch(device, backend, pass, stencil) {
|
|
379
|
+
if (!this._shaderInstBuf || !this._indexBuffer || this._currentBlendMode === null || this._currentTexture === null)
|
|
380
|
+
return;
|
|
381
|
+
device.queue.writeBuffer(this._shaderInstBuf, 0, this._shaderInstData, 0, this._shaderQuadCount * shaderStrideBytes);
|
|
382
|
+
const storage = backend.getTransformStorageBuffer(this._maxNodeIndex + 1);
|
|
383
|
+
const uniformBindGroup = this._getOrCreateTransformBindGroup(device, this._uniformBuffer, storage.buffer);
|
|
384
|
+
const modeX = this._currentModeX ?? 'repeat';
|
|
385
|
+
const modeY = this._currentModeY ?? 'repeat';
|
|
386
|
+
const sampler = this._getOrCreateSampler(device, modeX, modeY);
|
|
387
|
+
const texView = backend.getTextureBinding(this._currentTexture).view;
|
|
388
|
+
const textureBindGroup = device.createBindGroup({
|
|
389
|
+
layout: this._textureBindGroupLayout,
|
|
390
|
+
entries: [{ binding: 0, resource: texView }, { binding: 1, resource: sampler }],
|
|
391
|
+
});
|
|
392
|
+
const pipeline = this._getPipeline('shader', this._currentBlendMode, backend.renderTargetFormat, stencil);
|
|
393
|
+
pass.setPipeline(pipeline);
|
|
394
|
+
pass.setBindGroup(0, uniformBindGroup);
|
|
395
|
+
pass.setBindGroup(1, textureBindGroup);
|
|
396
|
+
pass.setVertexBuffer(0, this._shaderInstBuf);
|
|
397
|
+
pass.setIndexBuffer(this._indexBuffer, 'uint16');
|
|
398
|
+
pass.drawIndexed(indicesPerInstance, this._shaderQuadCount, 0, 0, 0);
|
|
399
|
+
backend.stats.batches++;
|
|
400
|
+
backend.stats.drawCalls++;
|
|
401
|
+
}
|
|
402
|
+
_drawGeoBatch(device, backend, pass, stencil) {
|
|
403
|
+
if (!this._geoInstBuf || !this._indexBuffer || this._currentBlendMode === null || this._currentTexture === null)
|
|
404
|
+
return;
|
|
405
|
+
device.queue.writeBuffer(this._geoInstBuf, 0, this._geoInstData, 0, this._geoQuadCount * geoStrideBytes);
|
|
406
|
+
const storage = backend.getTransformStorageBuffer(this._maxNodeIndex + 1);
|
|
407
|
+
const uniformBindGroup = this._getOrCreateTransformBindGroup(device, this._uniformBuffer, storage.buffer);
|
|
408
|
+
// Geometry path: use backend's default (clamp) sampler.
|
|
409
|
+
const binding = backend.getTextureBinding(this._currentTexture);
|
|
410
|
+
const textureBindGroup = device.createBindGroup({
|
|
411
|
+
layout: this._textureBindGroupLayout,
|
|
412
|
+
entries: [{ binding: 0, resource: binding.view }, { binding: 1, resource: binding.sampler }],
|
|
413
|
+
});
|
|
414
|
+
const pipeline = this._getPipeline('geo', this._currentBlendMode, backend.renderTargetFormat, stencil);
|
|
415
|
+
pass.setPipeline(pipeline);
|
|
416
|
+
pass.setBindGroup(0, uniformBindGroup);
|
|
417
|
+
pass.setBindGroup(1, textureBindGroup);
|
|
418
|
+
pass.setVertexBuffer(0, this._geoInstBuf);
|
|
419
|
+
pass.setIndexBuffer(this._indexBuffer, 'uint16');
|
|
420
|
+
pass.drawIndexed(indicesPerInstance, this._geoQuadCount, 0, 0, 0);
|
|
421
|
+
backend.stats.batches++;
|
|
422
|
+
backend.stats.drawCalls++;
|
|
423
|
+
}
|
|
424
|
+
destroy() {
|
|
425
|
+
this.disconnect();
|
|
426
|
+
}
|
|
427
|
+
// -----------------------------------------------------------------------
|
|
428
|
+
// Private helpers
|
|
429
|
+
// -----------------------------------------------------------------------
|
|
430
|
+
_getOrCreateSampler(device, modeX, modeY) {
|
|
431
|
+
const key = `${modeX}:${modeY}`;
|
|
432
|
+
const existing = this._samplers.get(key);
|
|
433
|
+
if (existing)
|
|
434
|
+
return existing;
|
|
435
|
+
const sampler = device.createSampler({
|
|
436
|
+
addressModeU: repeatModeToAddressMode(modeX),
|
|
437
|
+
addressModeV: repeatModeToAddressMode(modeY),
|
|
438
|
+
magFilter: 'linear',
|
|
439
|
+
minFilter: 'linear',
|
|
440
|
+
});
|
|
441
|
+
this._samplers.set(key, sampler);
|
|
442
|
+
return sampler;
|
|
443
|
+
}
|
|
444
|
+
_getOrCreateTransformBindGroup(device, uniformBuf, storageBuf) {
|
|
445
|
+
if (this._transformBindGroup !== null && this._transformStorageBuf === storageBuf) {
|
|
446
|
+
return this._transformBindGroup;
|
|
447
|
+
}
|
|
448
|
+
this._transformStorageBuf = storageBuf;
|
|
449
|
+
this._transformBindGroup = device.createBindGroup({
|
|
450
|
+
layout: this._uniformBindGroupLayout,
|
|
451
|
+
entries: [
|
|
452
|
+
{ binding: 0, resource: { buffer: uniformBuf } },
|
|
453
|
+
{ binding: 1, resource: { buffer: storageBuf } },
|
|
454
|
+
],
|
|
455
|
+
});
|
|
456
|
+
return this._transformBindGroup;
|
|
457
|
+
}
|
|
458
|
+
_getPipeline(kind, blend, format, stencil) {
|
|
459
|
+
const key = `${kind}:${blend}:${format}:${stencil ? 's' : 'n'}`;
|
|
460
|
+
const existing = this._pipelines.get(key);
|
|
461
|
+
if (existing)
|
|
462
|
+
return existing;
|
|
463
|
+
if (!this._device || !this._shaderModule || !this._uniformBindGroupLayout || !this._textureBindGroupLayout) {
|
|
464
|
+
throw new Error('WebGpuRepeatingSpriteRenderer: not connected.');
|
|
465
|
+
}
|
|
466
|
+
const layout = this._device.createPipelineLayout({
|
|
467
|
+
bindGroupLayouts: [this._uniformBindGroupLayout, this._textureBindGroupLayout],
|
|
468
|
+
});
|
|
469
|
+
const isShader = kind === 'shader';
|
|
470
|
+
const strideBytes = isShader ? shaderStrideBytes : geoStrideBytes;
|
|
471
|
+
const buffers = isShader
|
|
472
|
+
? [{
|
|
473
|
+
arrayStride: strideBytes,
|
|
474
|
+
stepMode: 'instance',
|
|
475
|
+
attributes: [
|
|
476
|
+
{ shaderLocation: 0, offset: 0, format: 'float32x4' },
|
|
477
|
+
{ shaderLocation: 1, offset: 16, format: 'float32x4' },
|
|
478
|
+
{ shaderLocation: 2, offset: 32, format: 'unorm8x4' },
|
|
479
|
+
{ shaderLocation: 3, offset: 36, format: 'uint32' },
|
|
480
|
+
],
|
|
481
|
+
}]
|
|
482
|
+
: [{
|
|
483
|
+
arrayStride: strideBytes,
|
|
484
|
+
stepMode: 'instance',
|
|
485
|
+
attributes: [
|
|
486
|
+
{ shaderLocation: 0, offset: 0, format: 'float32x4' },
|
|
487
|
+
{ shaderLocation: 1, offset: 16, format: 'unorm16x4' },
|
|
488
|
+
{ shaderLocation: 2, offset: 24, format: 'unorm8x4' },
|
|
489
|
+
{ shaderLocation: 3, offset: 28, format: 'uint32' },
|
|
490
|
+
],
|
|
491
|
+
}];
|
|
492
|
+
const desc = {
|
|
493
|
+
layout,
|
|
494
|
+
vertex: {
|
|
495
|
+
module: this._shaderModule,
|
|
496
|
+
entryPoint: isShader ? 'shaderVert' : 'geoVert',
|
|
497
|
+
buffers,
|
|
498
|
+
},
|
|
499
|
+
fragment: {
|
|
500
|
+
module: this._shaderModule,
|
|
501
|
+
entryPoint: isShader ? 'shaderFrag' : 'geoFrag',
|
|
502
|
+
targets: [{ format, blend: getWebGpuBlendState(blend), writeMask: GPUColorWrite.ALL }],
|
|
503
|
+
},
|
|
504
|
+
primitive: { topology: 'triangle-list' },
|
|
505
|
+
};
|
|
506
|
+
if (stencil) {
|
|
507
|
+
desc.depthStencil = stencilContentDepthStencilState();
|
|
508
|
+
}
|
|
509
|
+
const pipeline = this._device.createRenderPipeline(desc);
|
|
510
|
+
this._pipelines.set(key, pipeline);
|
|
511
|
+
return pipeline;
|
|
512
|
+
}
|
|
513
|
+
_ensureShaderCapacity(needed) {
|
|
514
|
+
if (!this._device || needed <= this._shaderInstCapacity)
|
|
515
|
+
return;
|
|
516
|
+
this._shaderInstCapacity = this._growCapacity(this._shaderInstCapacity, needed);
|
|
517
|
+
const oldData = this._shaderInstData;
|
|
518
|
+
const carry = this._shaderQuadCount * shaderStrideBytes;
|
|
519
|
+
this._shaderInstData = new ArrayBuffer(this._shaderInstCapacity * shaderStrideBytes);
|
|
520
|
+
if (carry > 0)
|
|
521
|
+
new Uint8Array(this._shaderInstData).set(new Uint8Array(oldData, 0, carry));
|
|
522
|
+
this._shaderInstF32 = new Float32Array(this._shaderInstData);
|
|
523
|
+
this._shaderInstU32 = new Uint32Array(this._shaderInstData);
|
|
524
|
+
this._shaderInstBuf?.destroy();
|
|
525
|
+
this._shaderInstBuf = this._device.createBuffer({
|
|
526
|
+
size: this._shaderInstData.byteLength,
|
|
527
|
+
usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST,
|
|
528
|
+
});
|
|
529
|
+
}
|
|
530
|
+
_ensureGeoCapacity(needed) {
|
|
531
|
+
if (!this._device || needed <= this._geoInstCapacity)
|
|
532
|
+
return;
|
|
533
|
+
this._geoInstCapacity = this._growCapacity(this._geoInstCapacity, needed);
|
|
534
|
+
const oldData = this._geoInstData;
|
|
535
|
+
const carry = this._geoQuadCount * geoStrideBytes;
|
|
536
|
+
this._geoInstData = new ArrayBuffer(this._geoInstCapacity * geoStrideBytes);
|
|
537
|
+
if (carry > 0)
|
|
538
|
+
new Uint8Array(this._geoInstData).set(new Uint8Array(oldData, 0, carry));
|
|
539
|
+
this._geoInstF32 = new Float32Array(this._geoInstData);
|
|
540
|
+
this._geoInstU32 = new Uint32Array(this._geoInstData);
|
|
541
|
+
this._geoInstBuf?.destroy();
|
|
542
|
+
this._geoInstBuf = this._device.createBuffer({
|
|
543
|
+
size: this._geoInstData.byteLength,
|
|
544
|
+
usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST,
|
|
545
|
+
});
|
|
546
|
+
}
|
|
547
|
+
_growCapacity(current, needed) {
|
|
548
|
+
let cap = Math.max(current, initialBatchCapacity);
|
|
549
|
+
while (cap < needed)
|
|
550
|
+
cap *= 2;
|
|
551
|
+
return cap;
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
|
|
555
|
+
export { WebGpuRepeatingSpriteRenderer };
|
|
556
|
+
//# sourceMappingURL=WebGpuRepeatingSpriteRenderer.js.map
|