@lightningjs/renderer 3.0.0-beta4 → 3.0.0-beta5
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/LICENSE +202 -202
- package/NOTICE +3 -3
- package/README.md +147 -147
- package/dist/exports/core-api.d.ts +74 -0
- package/dist/exports/core-api.js +96 -0
- package/dist/exports/core-api.js.map +1 -0
- package/dist/exports/main-api.d.ts +30 -0
- package/dist/exports/main-api.js +45 -0
- package/dist/exports/main-api.js.map +1 -0
- package/dist/src/core/CoreExtension.d.ts +12 -0
- package/dist/src/core/CoreExtension.js +29 -0
- package/dist/src/core/CoreExtension.js.map +1 -0
- package/dist/src/core/CoreNode.js +1 -1
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreStuff.js +138 -0
- package/dist/src/core/CoreStuff.js.map +1 -0
- package/dist/src/core/CoreTextNode.js +1 -0
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTexturizer.d.ts +14 -0
- package/dist/src/core/CoreTexturizer.js +47 -0
- package/dist/src/core/CoreTexturizer.js.map +1 -0
- package/dist/src/core/LngNode.d.ts +736 -0
- package/dist/src/core/LngNode.js +1174 -0
- package/dist/src/core/LngNode.js.map +1 -0
- package/dist/src/core/Matrix2DContext.d.ts +15 -0
- package/dist/src/core/Matrix2DContext.js +45 -0
- package/dist/src/core/Matrix2DContext.js.map +1 -0
- package/dist/src/core/ShaderNode.d.ts +10 -0
- package/dist/src/core/ShaderNode.js +30 -0
- package/dist/src/core/ShaderNode.js.map +1 -0
- package/dist/src/core/TextNode.d.ts +103 -0
- package/dist/src/core/TextNode.js +331 -0
- package/dist/src/core/TextNode.js.map +1 -0
- package/dist/src/core/lib/Coords.d.ts +14 -0
- package/dist/src/core/lib/Coords.js +55 -0
- package/dist/src/core/lib/Coords.js.map +1 -0
- package/dist/src/core/lib/glm/common.d.ts +162 -0
- package/dist/src/core/lib/glm/common.js +81 -0
- package/dist/src/core/lib/glm/common.js.map +1 -0
- package/dist/src/core/lib/glm/index.d.ts +11 -0
- package/dist/src/core/lib/glm/index.js +30 -0
- package/dist/src/core/lib/glm/index.js.map +1 -0
- package/dist/src/core/lib/glm/mat2.d.ts +219 -0
- package/dist/src/core/lib/glm/mat2.js +396 -0
- package/dist/src/core/lib/glm/mat2.js.map +1 -0
- package/dist/src/core/lib/glm/mat2d.d.ts +237 -0
- package/dist/src/core/lib/glm/mat2d.js +442 -0
- package/dist/src/core/lib/glm/mat2d.js.map +1 -0
- package/dist/src/core/lib/glm/mat3.d.ts +283 -0
- package/dist/src/core/lib/glm/mat3.js +680 -0
- package/dist/src/core/lib/glm/mat3.js.map +1 -0
- package/dist/src/core/lib/glm/mat4.d.ts +550 -0
- package/dist/src/core/lib/glm/mat4.js +1802 -0
- package/dist/src/core/lib/glm/mat4.js.map +1 -0
- package/dist/src/core/lib/glm/quat.d.ts +363 -0
- package/dist/src/core/lib/glm/quat.js +693 -0
- package/dist/src/core/lib/glm/quat.js.map +1 -0
- package/dist/src/core/lib/glm/quat2.d.ts +356 -0
- package/dist/src/core/lib/glm/quat2.js +754 -0
- package/dist/src/core/lib/glm/quat2.js.map +1 -0
- package/dist/src/core/lib/glm/vec2.d.ts +365 -0
- package/dist/src/core/lib/glm/vec2.js +569 -0
- package/dist/src/core/lib/glm/vec2.js.map +1 -0
- package/dist/src/core/lib/glm/vec3.d.ts +406 -0
- package/dist/src/core/lib/glm/vec3.js +720 -0
- package/dist/src/core/lib/glm/vec3.js.map +1 -0
- package/dist/src/core/lib/glm/vec4.d.ts +330 -0
- package/dist/src/core/lib/glm/vec4.js +608 -0
- package/dist/src/core/lib/glm/vec4.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderManager.d.ts +19 -0
- package/dist/src/core/renderers/CoreShaderManager.js +33 -0
- package/dist/src/core/renderers/CoreShaderManager.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +27 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +82 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +11 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +34 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +1 -0
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +35 -35
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +45 -45
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +62 -62
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +6 -6
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +22 -22
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +28 -28
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +10 -10
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
- package/dist/src/core/scene/Scene.d.ts +59 -0
- package/dist/src/core/scene/Scene.js +106 -0
- package/dist/src/core/scene/Scene.js.map +1 -0
- package/dist/src/core/shaders/webgl/Border.js +59 -59
- package/dist/src/core/shaders/webgl/Default.js +47 -47
- package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
- package/dist/src/core/shaders/webgl/HolePunch.js +32 -32
- package/dist/src/core/shaders/webgl/LinearGradient.js +36 -36
- package/dist/src/core/shaders/webgl/RadialGradient.js +33 -33
- package/dist/src/core/shaders/webgl/Rounded.js +71 -71
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +66 -66
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +79 -79
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +54 -54
- package/dist/src/core/shaders/webgl/SdfShader.js +62 -62
- package/dist/src/core/shaders/webgl/Shadow.js +83 -83
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +20 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +55 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +1 -0
- package/dist/src/main-api/ICoreDriver.d.ts +27 -0
- package/dist/src/main-api/ICoreDriver.js +20 -0
- package/dist/src/main-api/ICoreDriver.js.map +1 -0
- package/dist/src/main-api/IRenderDriver.d.ts +20 -0
- package/dist/src/main-api/IRenderDriver.js +20 -0
- package/dist/src/main-api/IRenderDriver.js.map +1 -0
- package/dist/src/main-api/IShaderController.d.ts +14 -0
- package/dist/src/main-api/IShaderController.js +30 -0
- package/dist/src/main-api/IShaderController.js.map +1 -0
- package/dist/src/main-api/IShaderNode.d.ts +17 -0
- package/dist/src/main-api/IShaderNode.js +19 -0
- package/dist/src/main-api/IShaderNode.js.map +1 -0
- package/dist/src/main-api/RendererMain.d.ts +375 -0
- package/dist/src/main-api/RendererMain.js +365 -0
- package/dist/src/main-api/RendererMain.js.map +1 -0
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +9 -0
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +38 -0
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +1 -0
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +56 -0
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +101 -0
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +1 -0
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +32 -0
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +28 -0
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +1 -0
- package/dist/src/render-drivers/main/MainCoreDriver.d.ts +24 -0
- package/dist/src/render-drivers/main/MainCoreDriver.js +118 -0
- package/dist/src/render-drivers/main/MainCoreDriver.js.map +1 -0
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +99 -0
- package/dist/src/render-drivers/main/MainOnlyNode.js +396 -0
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -0
- package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +6 -0
- package/dist/src/render-drivers/main/MainOnlyShaderController.js +15 -0
- package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +1 -0
- package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +7 -0
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js +34 -0
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +1 -0
- package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +47 -0
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +205 -0
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +1 -0
- package/dist/src/render-drivers/main/MainRenderDriver.d.ts +17 -0
- package/dist/src/render-drivers/main/MainRenderDriver.js +88 -0
- package/dist/src/render-drivers/main/MainRenderDriver.js.map +1 -0
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +90 -0
- package/dist/src/render-drivers/threadx/NodeStruct.js +281 -0
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +1 -0
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +39 -0
- package/dist/src/render-drivers/threadx/SharedNode.js +60 -0
- package/dist/src/render-drivers/threadx/SharedNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +44 -0
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +201 -0
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +28 -0
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +234 -0
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +20 -0
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +84 -0
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +44 -0
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +154 -0
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +6 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +16 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +7 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +15 -0
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +28 -0
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +55 -0
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +21 -0
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +198 -0
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +1 -0
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +70 -0
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +32 -0
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +1 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +19 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +177 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +27 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +108 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +1 -0
- package/dist/src/render-drivers/threadx/worker/renderer.d.ts +1 -0
- package/dist/src/render-drivers/threadx/worker/renderer.js +145 -0
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -0
- package/dist/src/render-drivers/utils.d.ts +12 -0
- package/dist/src/render-drivers/utils.js +69 -0
- package/dist/src/render-drivers/utils.js.map +1 -0
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/exports/canvas-shaders.ts +28 -28
- package/exports/canvas.ts +45 -45
- package/exports/index.ts +90 -90
- package/exports/inspector.ts +24 -24
- package/exports/utils.ts +44 -44
- package/exports/webgl-shaders.ts +28 -28
- package/exports/webgl.ts +50 -50
- package/package.json +2 -1
- package/scripts/please-use-pnpm.js +13 -13
- package/src/common/CommonTypes.ts +146 -146
- package/src/common/EventEmitter.ts +77 -77
- package/src/common/IAnimationController.ts +92 -92
- package/src/common/IEventEmitter.ts +28 -28
- package/src/core/CoreNode.test.ts +203 -203
- package/src/core/CoreNode.ts +2494 -2494
- package/src/core/CoreShaderManager.ts +188 -188
- package/src/core/CoreTextNode.ts +449 -448
- package/src/core/CoreTextureManager.ts +601 -601
- package/src/core/Stage.ts +754 -754
- package/src/core/TextureMemoryManager.ts +395 -395
- package/src/core/animations/AnimationManager.ts +38 -38
- package/src/core/animations/CoreAnimation.ts +284 -284
- package/src/core/animations/CoreAnimationController.ts +157 -157
- package/src/core/lib/ContextSpy.ts +41 -41
- package/src/core/lib/ImageWorker.ts +280 -280
- package/src/core/lib/Matrix3d.ts +244 -244
- package/src/core/lib/RenderCoords.ts +71 -71
- package/src/core/lib/WebGlContextWrapper.ts +1374 -1374
- package/src/core/lib/textureCompression.ts +152 -152
- package/src/core/lib/textureSvg.ts +78 -78
- package/src/core/lib/utils.ts +386 -386
- package/src/core/lib/validateImageBitmap.ts +87 -87
- package/src/core/platform.ts +64 -64
- package/src/core/platforms/Platform.ts +77 -77
- package/src/core/platforms/web/WebPlatform.ts +84 -84
- package/src/core/renderers/CoreContextTexture.ts +43 -43
- package/src/core/renderers/CoreRenderOp.ts +22 -22
- package/src/core/renderers/CoreRenderer.ts +109 -109
- package/src/core/renderers/CoreShaderNode.ts +165 -165
- package/src/core/renderers/CoreShaderProgram.ts +23 -23
- package/src/core/renderers/canvas/CanvasRenderer.ts +298 -298
- package/src/core/renderers/canvas/CanvasShaderNode.ts +99 -99
- package/src/core/renderers/canvas/CanvasTexture.ts +156 -156
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +220 -220
- package/src/core/renderers/canvas/internal/ColorUtils.ts +85 -85
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +86 -86
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -50
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +301 -301
- package/src/core/renderers/webgl/WebGlRenderOp.ts +161 -161
- package/src/core/renderers/webgl/WebGlRenderer.ts +750 -750
- package/src/core/renderers/webgl/WebGlShaderNode.ts +437 -437
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +318 -318
- package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
- package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -281
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
- package/src/core/shaders/canvas/Border.ts +78 -78
- package/src/core/shaders/canvas/HolePunch.ts +62 -62
- package/src/core/shaders/canvas/LinearGradient.ts +69 -69
- package/src/core/shaders/canvas/RadialGradient.ts +113 -113
- package/src/core/shaders/canvas/Rounded.ts +55 -55
- package/src/core/shaders/canvas/RoundedWithBorder.ts +68 -68
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +88 -88
- package/src/core/shaders/canvas/RoundedWithShadow.ts +69 -69
- package/src/core/shaders/canvas/Shadow.ts +52 -52
- package/src/core/shaders/canvas/utils/render.ts +151 -151
- package/src/core/shaders/templates/BorderTemplate.ts +115 -115
- package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
- package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
- package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -81
- package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
- package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
- package/src/core/shaders/templates/shaderUtils.ts +47 -47
- package/src/core/shaders/webgl/Border.ts +96 -96
- package/src/core/shaders/webgl/Default.ts +89 -89
- package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
- package/src/core/shaders/webgl/HolePunch.ts +78 -78
- package/src/core/shaders/webgl/LinearGradient.ts +81 -81
- package/src/core/shaders/webgl/RadialGradient.ts +84 -84
- package/src/core/shaders/webgl/Rounded.ts +117 -117
- package/src/core/shaders/webgl/RoundedWithBorder.ts +114 -114
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +133 -133
- package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -98
- package/src/core/shaders/webgl/SdfShader.ts +134 -134
- package/src/core/shaders/webgl/Shadow.ts +115 -115
- package/src/core/text-rendering/TextRenderingUtils.ts +36 -36
- package/src/core/text-rendering/TextTextureRendererUtils.ts +263 -263
- package/src/core/text-rendering/TrFontManager.ts +183 -183
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +176 -176
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +171 -171
- package/src/core/text-rendering/font-face-types/TrFontFace.ts +187 -187
- package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +94 -94
- package/src/core/text-rendering/font-face-types/utils.ts +39 -39
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +514 -514
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +863 -863
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +846 -846
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +117 -117
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +497 -497
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +52 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
- package/src/core/text-rendering/renderers/TextRenderer.ts +567 -567
- package/src/core/textures/ColorTexture.ts +102 -102
- package/src/core/textures/ImageTexture.ts +410 -410
- package/src/core/textures/NoiseTexture.ts +104 -104
- package/src/core/textures/RenderTexture.ts +85 -85
- package/src/core/textures/SubTexture.ts +205 -205
- package/src/core/textures/Texture.ts +358 -358
- package/src/core/utils.ts +227 -227
- package/src/env.d.ts +7 -7
- package/src/main-api/INode.ts +100 -100
- package/src/main-api/Inspector.ts +522 -522
- package/src/main-api/Renderer.ts +675 -675
- package/src/main-api/utils.ts +45 -45
- package/src/utils.ts +267 -267
- package/COPYING +0 -1
- package/dist/src/core/temp.js +0 -77
- package/dist/src/core/temp.js.map +0 -1
- /package/dist/src/core/{temp.d.ts → CoreStuff.d.ts} +0 -0
|
@@ -0,0 +1,693 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
+
* following copyright and licenses apply:
|
|
4
|
+
*
|
|
5
|
+
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
+
*
|
|
7
|
+
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
+
* you may not use this file except in compliance with the License.
|
|
9
|
+
* You may obtain a copy of the License at
|
|
10
|
+
*
|
|
11
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
*
|
|
13
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
* See the License for the specific language governing permissions and
|
|
17
|
+
* limitations under the License.
|
|
18
|
+
*/
|
|
19
|
+
import { ANGLE_ORDER, EPSILON, getMatrixArrayType, RANDOM, } from './common.js';
|
|
20
|
+
import * as mat3 from './mat3.js';
|
|
21
|
+
import * as vec3 from './vec3.js';
|
|
22
|
+
import * as vec4 from './vec4.js';
|
|
23
|
+
/**
|
|
24
|
+
* Quaternion in the format XYZW
|
|
25
|
+
* @module quat
|
|
26
|
+
*/
|
|
27
|
+
/**
|
|
28
|
+
* Creates a new identity quat
|
|
29
|
+
*
|
|
30
|
+
* @returns {quat} a new quaternion
|
|
31
|
+
*/
|
|
32
|
+
export function create() {
|
|
33
|
+
const out = getMatrixArrayType(4);
|
|
34
|
+
if (!(out instanceof Float32Array)) {
|
|
35
|
+
out[0] = 0;
|
|
36
|
+
out[1] = 0;
|
|
37
|
+
out[2] = 0;
|
|
38
|
+
}
|
|
39
|
+
out[3] = 1;
|
|
40
|
+
return out;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Set a quat to the identity quaternion
|
|
44
|
+
*
|
|
45
|
+
* @param {quat} out the receiving quaternion
|
|
46
|
+
* @returns {quat} out
|
|
47
|
+
*/
|
|
48
|
+
export function identity(out) {
|
|
49
|
+
out[0] = 0;
|
|
50
|
+
out[1] = 0;
|
|
51
|
+
out[2] = 0;
|
|
52
|
+
out[3] = 1;
|
|
53
|
+
return out;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Sets a quat from the given angle and rotation axis,
|
|
57
|
+
* then returns it.
|
|
58
|
+
*
|
|
59
|
+
* @param {quat} out the receiving quaternion
|
|
60
|
+
* @param {Vec3} axis the axis around which to rotate
|
|
61
|
+
* @param {Number} rad the angle in radians
|
|
62
|
+
* @returns {quat} out
|
|
63
|
+
**/
|
|
64
|
+
export function setAxisAngle(out, axis, rad) {
|
|
65
|
+
rad = rad * 0.5;
|
|
66
|
+
const s = Math.sin(rad);
|
|
67
|
+
out[0] = s * axis[0];
|
|
68
|
+
out[1] = s * axis[1];
|
|
69
|
+
out[2] = s * axis[2];
|
|
70
|
+
out[3] = Math.cos(rad);
|
|
71
|
+
return out;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Gets the rotation axis and angle for a given
|
|
75
|
+
* quaternion. If a quaternion is created with
|
|
76
|
+
* setAxisAngle, this method will return the same
|
|
77
|
+
* values as providied in the original parameter list
|
|
78
|
+
* OR functionally equivalent values.
|
|
79
|
+
* Example: The quaternion formed by axis [0, 0, 1] and
|
|
80
|
+
* angle -90 is the same as the quaternion formed by
|
|
81
|
+
* [0, 0, 1] and 270. This method favors the latter.
|
|
82
|
+
* @param {Vec3} out_axis Vector receiving the axis of rotation
|
|
83
|
+
* @param {Quat} q Quaternion to be decomposed
|
|
84
|
+
* @return {Number} Angle, in radians, of the rotation
|
|
85
|
+
*/
|
|
86
|
+
export function getAxisAngle(out_axis, q) {
|
|
87
|
+
const rad = Math.acos(q[3]) * 2.0;
|
|
88
|
+
const s = Math.sin(rad / 2.0);
|
|
89
|
+
if (s > EPSILON) {
|
|
90
|
+
out_axis[0] = q[0] / s;
|
|
91
|
+
out_axis[1] = q[1] / s;
|
|
92
|
+
out_axis[2] = q[2] / s;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
// If s is zero, return any axis (no rotation - axis does not matter)
|
|
96
|
+
out_axis[0] = 1;
|
|
97
|
+
out_axis[1] = 0;
|
|
98
|
+
out_axis[2] = 0;
|
|
99
|
+
}
|
|
100
|
+
return rad;
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Gets the angular distance between two unit quaternions
|
|
104
|
+
*
|
|
105
|
+
* @param {Quat} a Origin unit quaternion
|
|
106
|
+
* @param {Quat} b Destination unit quaternion
|
|
107
|
+
* @return {Number} Angle, in radians, between the two quaternions
|
|
108
|
+
*/
|
|
109
|
+
export function getAngle(a, b) {
|
|
110
|
+
const dotproduct = dot(a, b);
|
|
111
|
+
return Math.acos(2 * dotproduct * dotproduct - 1);
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Multiplies two quat's
|
|
115
|
+
*
|
|
116
|
+
* @param {quat} out the receiving quaternion
|
|
117
|
+
* @param {Quat} a the first operand
|
|
118
|
+
* @param {Quat} b the second operand
|
|
119
|
+
* @returns {quat} out
|
|
120
|
+
*/
|
|
121
|
+
export function multiply(out, a, b) {
|
|
122
|
+
const ax = a[0], ay = a[1], az = a[2], aw = a[3];
|
|
123
|
+
const bx = b[0], by = b[1], bz = b[2], bw = b[3];
|
|
124
|
+
out[0] = ax * bw + aw * bx + ay * bz - az * by;
|
|
125
|
+
out[1] = ay * bw + aw * by + az * bx - ax * bz;
|
|
126
|
+
out[2] = az * bw + aw * bz + ax * by - ay * bx;
|
|
127
|
+
out[3] = aw * bw - ax * bx - ay * by - az * bz;
|
|
128
|
+
return out;
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Rotates a quaternion by the given angle about the X axis
|
|
132
|
+
*
|
|
133
|
+
* @param {quat} out quat receiving operation result
|
|
134
|
+
* @param {Quat} a quat to rotate
|
|
135
|
+
* @param {number} rad angle (in radians) to rotate
|
|
136
|
+
* @returns {quat} out
|
|
137
|
+
*/
|
|
138
|
+
export function rotateX(out, a, rad) {
|
|
139
|
+
rad *= 0.5;
|
|
140
|
+
const ax = a[0], ay = a[1], az = a[2], aw = a[3];
|
|
141
|
+
const bx = Math.sin(rad), bw = Math.cos(rad);
|
|
142
|
+
out[0] = ax * bw + aw * bx;
|
|
143
|
+
out[1] = ay * bw + az * bx;
|
|
144
|
+
out[2] = az * bw - ay * bx;
|
|
145
|
+
out[3] = aw * bw - ax * bx;
|
|
146
|
+
return out;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Rotates a quaternion by the given angle about the Y axis
|
|
150
|
+
*
|
|
151
|
+
* @param {quat} out quat receiving operation result
|
|
152
|
+
* @param {Quat} a quat to rotate
|
|
153
|
+
* @param {number} rad angle (in radians) to rotate
|
|
154
|
+
* @returns {quat} out
|
|
155
|
+
*/
|
|
156
|
+
export function rotateY(out, a, rad) {
|
|
157
|
+
rad *= 0.5;
|
|
158
|
+
const ax = a[0], ay = a[1], az = a[2], aw = a[3];
|
|
159
|
+
const by = Math.sin(rad), bw = Math.cos(rad);
|
|
160
|
+
out[0] = ax * bw - az * by;
|
|
161
|
+
out[1] = ay * bw + aw * by;
|
|
162
|
+
out[2] = az * bw + ax * by;
|
|
163
|
+
out[3] = aw * bw - ay * by;
|
|
164
|
+
return out;
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* Rotates a quaternion by the given angle about the Z axis
|
|
168
|
+
*
|
|
169
|
+
* @param {quat} out quat receiving operation result
|
|
170
|
+
* @param {Quat} a quat to rotate
|
|
171
|
+
* @param {number} rad angle (in radians) to rotate
|
|
172
|
+
* @returns {quat} out
|
|
173
|
+
*/
|
|
174
|
+
export function rotateZ(out, a, rad) {
|
|
175
|
+
rad *= 0.5;
|
|
176
|
+
const ax = a[0], ay = a[1], az = a[2], aw = a[3];
|
|
177
|
+
const bz = Math.sin(rad), bw = Math.cos(rad);
|
|
178
|
+
out[0] = ax * bw + ay * bz;
|
|
179
|
+
out[1] = ay * bw - ax * bz;
|
|
180
|
+
out[2] = az * bw + aw * bz;
|
|
181
|
+
out[3] = aw * bw - az * bz;
|
|
182
|
+
return out;
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Calculates the W component of a quat from the X, Y, and Z components.
|
|
186
|
+
* Assumes that quaternion is 1 unit in length.
|
|
187
|
+
* Any existing W component will be ignored.
|
|
188
|
+
*
|
|
189
|
+
* @param {quat} out the receiving quaternion
|
|
190
|
+
* @param {Quat} a quat to calculate W component of
|
|
191
|
+
* @returns {quat} out
|
|
192
|
+
*/
|
|
193
|
+
export function calculateW(out, a) {
|
|
194
|
+
const x = a[0], y = a[1], z = a[2];
|
|
195
|
+
out[0] = x;
|
|
196
|
+
out[1] = y;
|
|
197
|
+
out[2] = z;
|
|
198
|
+
out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));
|
|
199
|
+
return out;
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Calculate the exponential of a unit quaternion.
|
|
203
|
+
*
|
|
204
|
+
* @param {quat} out the receiving quaternion
|
|
205
|
+
* @param {Quat} a quat to calculate the exponential of
|
|
206
|
+
* @returns {quat} out
|
|
207
|
+
*/
|
|
208
|
+
export function exp(out, a) {
|
|
209
|
+
const x = a[0], y = a[1], z = a[2], w = a[3];
|
|
210
|
+
const r = Math.sqrt(x * x + y * y + z * z);
|
|
211
|
+
const et = Math.exp(w);
|
|
212
|
+
const s = r > 0 ? (et * Math.sin(r)) / r : 0;
|
|
213
|
+
out[0] = x * s;
|
|
214
|
+
out[1] = y * s;
|
|
215
|
+
out[2] = z * s;
|
|
216
|
+
out[3] = et * Math.cos(r);
|
|
217
|
+
return out;
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Calculate the natural logarithm of a unit quaternion.
|
|
221
|
+
*
|
|
222
|
+
* @param {quat} out the receiving quaternion
|
|
223
|
+
* @param {Quat} a quat to calculate the exponential of
|
|
224
|
+
* @returns {quat} out
|
|
225
|
+
*/
|
|
226
|
+
export function ln(out, a) {
|
|
227
|
+
const x = a[0], y = a[1], z = a[2], w = a[3];
|
|
228
|
+
const r = Math.sqrt(x * x + y * y + z * z);
|
|
229
|
+
const t = r > 0 ? Math.atan2(r, w) / r : 0;
|
|
230
|
+
out[0] = x * t;
|
|
231
|
+
out[1] = y * t;
|
|
232
|
+
out[2] = z * t;
|
|
233
|
+
out[3] = 0.5 * Math.log(x * x + y * y + z * z + w * w);
|
|
234
|
+
return out;
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Calculate the scalar power of a unit quaternion.
|
|
238
|
+
*
|
|
239
|
+
* @param {quat} out the receiving quaternion
|
|
240
|
+
* @param {Quat} a quat to calculate the exponential of
|
|
241
|
+
* @param {Number} b amount to scale the quaternion by
|
|
242
|
+
* @returns {quat} out
|
|
243
|
+
*/
|
|
244
|
+
export function pow(out, a, b) {
|
|
245
|
+
ln(out, a);
|
|
246
|
+
scale(out, out, b);
|
|
247
|
+
exp(out, out);
|
|
248
|
+
return out;
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Performs a spherical linear interpolation between two quat
|
|
252
|
+
*
|
|
253
|
+
* @param {quat} out the receiving quaternion
|
|
254
|
+
* @param {Quat} a the first operand
|
|
255
|
+
* @param {Quat} b the second operand
|
|
256
|
+
* @param {Number} t interpolation amount, in the range [0-1], between the two inputs
|
|
257
|
+
* @returns {quat} out
|
|
258
|
+
*/
|
|
259
|
+
export function slerp(out, a, b, t) {
|
|
260
|
+
// benchmarks:
|
|
261
|
+
// http://jsperf.com/quaternion-slerp-implementations
|
|
262
|
+
const ax = a[0], ay = a[1], az = a[2], aw = a[3];
|
|
263
|
+
let bx = b[0], by = b[1], bz = b[2], bw = b[3];
|
|
264
|
+
let omega, cosom, sinom, scale0, scale1; // calc cosine
|
|
265
|
+
cosom = ax * bx + ay * by + az * bz + aw * bw; // adjust signs (if necessary)
|
|
266
|
+
if (cosom < 0.0) {
|
|
267
|
+
cosom = -cosom;
|
|
268
|
+
bx = -bx;
|
|
269
|
+
by = -by;
|
|
270
|
+
bz = -bz;
|
|
271
|
+
bw = -bw;
|
|
272
|
+
} // calculate coefficients
|
|
273
|
+
if (1.0 - cosom > EPSILON) {
|
|
274
|
+
// standard case (slerp)
|
|
275
|
+
omega = Math.acos(cosom);
|
|
276
|
+
sinom = Math.sin(omega);
|
|
277
|
+
scale0 = Math.sin((1.0 - t) * omega) / sinom;
|
|
278
|
+
scale1 = Math.sin(t * omega) / sinom;
|
|
279
|
+
}
|
|
280
|
+
else {
|
|
281
|
+
// "from" and "to" quaternions are very close
|
|
282
|
+
// ... so we can do a linear interpolation
|
|
283
|
+
scale0 = 1.0 - t;
|
|
284
|
+
scale1 = t;
|
|
285
|
+
} // calculate final values
|
|
286
|
+
out[0] = scale0 * ax + scale1 * bx;
|
|
287
|
+
out[1] = scale0 * ay + scale1 * by;
|
|
288
|
+
out[2] = scale0 * az + scale1 * bz;
|
|
289
|
+
out[3] = scale0 * aw + scale1 * bw;
|
|
290
|
+
return out;
|
|
291
|
+
}
|
|
292
|
+
/**
|
|
293
|
+
* Generates a random unit quaternion
|
|
294
|
+
*
|
|
295
|
+
* @param {quat} out the receiving quaternion
|
|
296
|
+
* @returns {quat} out
|
|
297
|
+
*/
|
|
298
|
+
export function random(out) {
|
|
299
|
+
// Implementation of http://planning.cs.uiuc.edu/node198.html
|
|
300
|
+
// TODO: Calling random 3 times is probably not the fastest solution
|
|
301
|
+
const u1 = RANDOM();
|
|
302
|
+
const u2 = RANDOM();
|
|
303
|
+
const u3 = RANDOM();
|
|
304
|
+
const sqrt1MinusU1 = Math.sqrt(1 - u1);
|
|
305
|
+
const sqrtU1 = Math.sqrt(u1);
|
|
306
|
+
out[0] = sqrt1MinusU1 * Math.sin(2.0 * Math.PI * u2);
|
|
307
|
+
out[1] = sqrt1MinusU1 * Math.cos(2.0 * Math.PI * u2);
|
|
308
|
+
out[2] = sqrtU1 * Math.sin(2.0 * Math.PI * u3);
|
|
309
|
+
out[3] = sqrtU1 * Math.cos(2.0 * Math.PI * u3);
|
|
310
|
+
return out;
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* Calculates the inverse of a quat
|
|
314
|
+
*
|
|
315
|
+
* @param {quat} out the receiving quaternion
|
|
316
|
+
* @param {Quat} a quat to calculate inverse of
|
|
317
|
+
* @returns {quat} out
|
|
318
|
+
*/
|
|
319
|
+
export function invert(out, a) {
|
|
320
|
+
const a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];
|
|
321
|
+
const dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;
|
|
322
|
+
const invDot = dot ? 1.0 / dot : 0; // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0
|
|
323
|
+
out[0] = -a0 * invDot;
|
|
324
|
+
out[1] = -a1 * invDot;
|
|
325
|
+
out[2] = -a2 * invDot;
|
|
326
|
+
out[3] = a3 * invDot;
|
|
327
|
+
return out;
|
|
328
|
+
}
|
|
329
|
+
/**
|
|
330
|
+
* Calculates the conjugate of a quat
|
|
331
|
+
* If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.
|
|
332
|
+
*
|
|
333
|
+
* @param {quat} out the receiving quaternion
|
|
334
|
+
* @param {Quat} a quat to calculate conjugate of
|
|
335
|
+
* @returns {quat} out
|
|
336
|
+
*/
|
|
337
|
+
export function conjugate(out, a) {
|
|
338
|
+
out[0] = -a[0];
|
|
339
|
+
out[1] = -a[1];
|
|
340
|
+
out[2] = -a[2];
|
|
341
|
+
out[3] = a[3];
|
|
342
|
+
return out;
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* Creates a quaternion from the given 3x3 rotation matrix.
|
|
346
|
+
*
|
|
347
|
+
* NOTE: The resultant quaternion is not normalized, so you should be sure
|
|
348
|
+
* to renormalize the quaternion yourself where necessary.
|
|
349
|
+
*
|
|
350
|
+
* @param {quat} out the receiving quaternion
|
|
351
|
+
* @param {Mat3} m rotation matrix
|
|
352
|
+
* @returns {quat} out
|
|
353
|
+
* @function
|
|
354
|
+
*/
|
|
355
|
+
export function fromMat3(out, m) {
|
|
356
|
+
// Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes
|
|
357
|
+
// article "Quaternion Calculus and Fast Animation".
|
|
358
|
+
const fTrace = m[0] + m[4] + m[8];
|
|
359
|
+
let fRoot;
|
|
360
|
+
if (fTrace > 0.0) {
|
|
361
|
+
// |w| > 1/2, may as well choose w > 1/2
|
|
362
|
+
fRoot = Math.sqrt(fTrace + 1.0); // 2w
|
|
363
|
+
out[3] = 0.5 * fRoot;
|
|
364
|
+
fRoot = 0.5 / fRoot; // 1/(4w)
|
|
365
|
+
out[0] = (m[5] - m[7]) * fRoot;
|
|
366
|
+
out[1] = (m[6] - m[2]) * fRoot;
|
|
367
|
+
out[2] = (m[1] - m[3]) * fRoot;
|
|
368
|
+
}
|
|
369
|
+
else {
|
|
370
|
+
let i = 0;
|
|
371
|
+
if (m[4] > m[0])
|
|
372
|
+
i = 1;
|
|
373
|
+
if (m[8] > m[(i * 3 + i)])
|
|
374
|
+
i = 2;
|
|
375
|
+
const j = ((i + 1) % 3);
|
|
376
|
+
const k = ((i + 2) % 3);
|
|
377
|
+
fRoot = Math.sqrt(m[(i * 3 + i)] -
|
|
378
|
+
m[(j * 3 + j)] -
|
|
379
|
+
m[(k * 3 + k)] +
|
|
380
|
+
1.0);
|
|
381
|
+
out[i] = 0.5 * fRoot;
|
|
382
|
+
fRoot = 0.5 / fRoot;
|
|
383
|
+
out[3] =
|
|
384
|
+
(m[(j * 3 + k)] - m[(k * 3 + j)]) * fRoot;
|
|
385
|
+
out[j] =
|
|
386
|
+
(m[(j * 3 + i)] + m[(i * 3 + j)]) * fRoot;
|
|
387
|
+
out[k] =
|
|
388
|
+
(m[(k * 3 + i)] + m[(i * 3 + k)]) * fRoot;
|
|
389
|
+
}
|
|
390
|
+
return out;
|
|
391
|
+
}
|
|
392
|
+
/**
|
|
393
|
+
* Creates a quaternion from the given euler angle x, y, z using the provided intrinsic order for the conversion.
|
|
394
|
+
*
|
|
395
|
+
* @param {quat} out the receiving quaternion
|
|
396
|
+
* @param {x} x Angle to rotate around X axis in degrees.
|
|
397
|
+
* @param {y} y Angle to rotate around Y axis in degrees.
|
|
398
|
+
* @param {z} z Angle to rotate around Z axis in degrees.
|
|
399
|
+
* @param {'zyx'|'xyz'|'yxz'|'yzx'|'zxy'|'zyx'} order Intrinsic order for conversion, default is zyx.
|
|
400
|
+
* @returns {quat} out
|
|
401
|
+
* @function
|
|
402
|
+
*/
|
|
403
|
+
export function fromEuler(out, x, y, z, order) {
|
|
404
|
+
order = order ?? ANGLE_ORDER;
|
|
405
|
+
const halfToRad = Math.PI / 360;
|
|
406
|
+
x *= halfToRad;
|
|
407
|
+
z *= halfToRad;
|
|
408
|
+
y *= halfToRad;
|
|
409
|
+
const sx = Math.sin(x);
|
|
410
|
+
const cx = Math.cos(x);
|
|
411
|
+
const sy = Math.sin(y);
|
|
412
|
+
const cy = Math.cos(y);
|
|
413
|
+
const sz = Math.sin(z);
|
|
414
|
+
const cz = Math.cos(z);
|
|
415
|
+
switch (order) {
|
|
416
|
+
case 'xyz':
|
|
417
|
+
out[0] = sx * cy * cz + cx * sy * sz;
|
|
418
|
+
out[1] = cx * sy * cz - sx * cy * sz;
|
|
419
|
+
out[2] = cx * cy * sz + sx * sy * cz;
|
|
420
|
+
out[3] = cx * cy * cz - sx * sy * sz;
|
|
421
|
+
break;
|
|
422
|
+
case 'xzy':
|
|
423
|
+
out[0] = sx * cy * cz - cx * sy * sz;
|
|
424
|
+
out[1] = cx * sy * cz - sx * cy * sz;
|
|
425
|
+
out[2] = cx * cy * sz + sx * sy * cz;
|
|
426
|
+
out[3] = cx * cy * cz + sx * sy * sz;
|
|
427
|
+
break;
|
|
428
|
+
case 'yxz':
|
|
429
|
+
out[0] = sx * cy * cz + cx * sy * sz;
|
|
430
|
+
out[1] = cx * sy * cz - sx * cy * sz;
|
|
431
|
+
out[2] = cx * cy * sz - sx * sy * cz;
|
|
432
|
+
out[3] = cx * cy * cz + sx * sy * sz;
|
|
433
|
+
break;
|
|
434
|
+
case 'yzx':
|
|
435
|
+
out[0] = sx * cy * cz + cx * sy * sz;
|
|
436
|
+
out[1] = cx * sy * cz + sx * cy * sz;
|
|
437
|
+
out[2] = cx * cy * sz - sx * sy * cz;
|
|
438
|
+
out[3] = cx * cy * cz - sx * sy * sz;
|
|
439
|
+
break;
|
|
440
|
+
case 'zxy':
|
|
441
|
+
out[0] = sx * cy * cz - cx * sy * sz;
|
|
442
|
+
out[1] = cx * sy * cz + sx * cy * sz;
|
|
443
|
+
out[2] = cx * cy * sz + sx * sy * cz;
|
|
444
|
+
out[3] = cx * cy * cz - sx * sy * sz;
|
|
445
|
+
break;
|
|
446
|
+
case 'zyx':
|
|
447
|
+
out[0] = sx * cy * cz - cx * sy * sz;
|
|
448
|
+
out[1] = cx * sy * cz + sx * cy * sz;
|
|
449
|
+
out[2] = cx * cy * sz - sx * sy * cz;
|
|
450
|
+
out[3] = cx * cy * cz + sx * sy * sz;
|
|
451
|
+
break;
|
|
452
|
+
default:
|
|
453
|
+
throw new Error('Unknown angle order ' + order);
|
|
454
|
+
}
|
|
455
|
+
return out;
|
|
456
|
+
}
|
|
457
|
+
/**
|
|
458
|
+
* Returns a string representation of a quaternion
|
|
459
|
+
*
|
|
460
|
+
* @param {Quat} a vector to represent as a string
|
|
461
|
+
* @returns {String} string representation of the vector
|
|
462
|
+
*/
|
|
463
|
+
export function str(a) {
|
|
464
|
+
return `quat(${a[0]}, ${a[1]}, ${a[2]}, ${a[3]})`;
|
|
465
|
+
}
|
|
466
|
+
/**
|
|
467
|
+
* Creates a new quat initialized with values from an existing quaternion
|
|
468
|
+
*
|
|
469
|
+
* @param {Quat} a quaternion to clone
|
|
470
|
+
* @returns {quat} a new quaternion
|
|
471
|
+
* @function
|
|
472
|
+
*/
|
|
473
|
+
export const clone = vec4.clone;
|
|
474
|
+
/**
|
|
475
|
+
* Creates a new quat initialized with the given values
|
|
476
|
+
*
|
|
477
|
+
* @param {Number} x X component
|
|
478
|
+
* @param {Number} y Y component
|
|
479
|
+
* @param {Number} z Z component
|
|
480
|
+
* @param {Number} w W component
|
|
481
|
+
* @returns {quat} a new quaternion
|
|
482
|
+
* @function
|
|
483
|
+
*/
|
|
484
|
+
export const fromValues = vec4.fromValues;
|
|
485
|
+
/**
|
|
486
|
+
* Copy the values from one quat to another
|
|
487
|
+
*
|
|
488
|
+
* @param {quat} out the receiving quaternion
|
|
489
|
+
* @param {Quat} a the source quaternion
|
|
490
|
+
* @returns {quat} out
|
|
491
|
+
* @function
|
|
492
|
+
*/
|
|
493
|
+
export const copy = vec4.copy;
|
|
494
|
+
/**
|
|
495
|
+
* Set the components of a quat to the given values
|
|
496
|
+
*
|
|
497
|
+
* @param {quat} out the receiving quaternion
|
|
498
|
+
* @param {Number} x X component
|
|
499
|
+
* @param {Number} y Y component
|
|
500
|
+
* @param {Number} z Z component
|
|
501
|
+
* @param {Number} w W component
|
|
502
|
+
* @returns {quat} out
|
|
503
|
+
* @function
|
|
504
|
+
*/
|
|
505
|
+
export const set = vec4.set;
|
|
506
|
+
/**
|
|
507
|
+
* Adds two quat's
|
|
508
|
+
*
|
|
509
|
+
* @param {quat} out the receiving quaternion
|
|
510
|
+
* @param {Quat} a the first operand
|
|
511
|
+
* @param {Quat} b the second operand
|
|
512
|
+
* @returns {quat} out
|
|
513
|
+
* @function
|
|
514
|
+
*/
|
|
515
|
+
export const add = vec4.add;
|
|
516
|
+
/**
|
|
517
|
+
* Alias for {@link quat.multiply}
|
|
518
|
+
* @function
|
|
519
|
+
*/
|
|
520
|
+
export const mul = multiply;
|
|
521
|
+
/**
|
|
522
|
+
* Scales a quat by a scalar number
|
|
523
|
+
*
|
|
524
|
+
* @param {quat} out the receiving vector
|
|
525
|
+
* @param {Quat} a the vector to scale
|
|
526
|
+
* @param {Number} b amount to scale the vector by
|
|
527
|
+
* @returns {quat} out
|
|
528
|
+
* @function
|
|
529
|
+
*/
|
|
530
|
+
export const scale = vec4.scale;
|
|
531
|
+
/**
|
|
532
|
+
* Calculates the dot product of two quat's
|
|
533
|
+
*
|
|
534
|
+
* @param {Quat} a the first operand
|
|
535
|
+
* @param {Quat} b the second operand
|
|
536
|
+
* @returns {Number} dot product of a and b
|
|
537
|
+
* @function
|
|
538
|
+
*/
|
|
539
|
+
export const dot = vec4.dot;
|
|
540
|
+
/**
|
|
541
|
+
* Performs a linear interpolation between two quat's
|
|
542
|
+
*
|
|
543
|
+
* @param {quat} out the receiving quaternion
|
|
544
|
+
* @param {Quat} a the first operand
|
|
545
|
+
* @param {Quat} b the second operand
|
|
546
|
+
* @param {Number} t interpolation amount, in the range [0-1], between the two inputs
|
|
547
|
+
* @returns {quat} out
|
|
548
|
+
* @function
|
|
549
|
+
*/
|
|
550
|
+
export const lerp = vec4.lerp;
|
|
551
|
+
/**
|
|
552
|
+
* Calculates the length of a quat
|
|
553
|
+
*
|
|
554
|
+
* @param {Quat} a vector to calculate length of
|
|
555
|
+
* @returns {Number} length of a
|
|
556
|
+
*/
|
|
557
|
+
export const length = vec4.length;
|
|
558
|
+
/**
|
|
559
|
+
* Alias for {@link length}
|
|
560
|
+
* @function
|
|
561
|
+
*/
|
|
562
|
+
export const len = length;
|
|
563
|
+
/**
|
|
564
|
+
* Calculates the squared length of a quat
|
|
565
|
+
*
|
|
566
|
+
* @param {Quat} a vector to calculate squared length of
|
|
567
|
+
* @returns {Number} squared length of a
|
|
568
|
+
* @function
|
|
569
|
+
*/
|
|
570
|
+
export const squaredLength = vec4.squaredLength;
|
|
571
|
+
/**
|
|
572
|
+
* Alias for {@link squaredLength}
|
|
573
|
+
* @function
|
|
574
|
+
*/
|
|
575
|
+
export const sqrLen = squaredLength;
|
|
576
|
+
/**
|
|
577
|
+
* Normalize a quat
|
|
578
|
+
*
|
|
579
|
+
* @param {quat} out the receiving quaternion
|
|
580
|
+
* @param {Quat} a quaternion to normalize
|
|
581
|
+
* @returns {quat} out
|
|
582
|
+
* @function
|
|
583
|
+
*/
|
|
584
|
+
export const normalize = vec4.normalize;
|
|
585
|
+
/**
|
|
586
|
+
* Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)
|
|
587
|
+
*
|
|
588
|
+
* @param {Quat} a The first quaternion.
|
|
589
|
+
* @param {Quat} b The second quaternion.
|
|
590
|
+
* @returns {Boolean} True if the vectors are equal, false otherwise.
|
|
591
|
+
*/
|
|
592
|
+
export const exactEquals = vec4.exactEquals;
|
|
593
|
+
/**
|
|
594
|
+
* Returns whether or not the quaternions point approximately to the same direction.
|
|
595
|
+
*
|
|
596
|
+
* Both quaternions are assumed to be unit length.
|
|
597
|
+
*
|
|
598
|
+
* @param {Quat} a The first unit quaternion.
|
|
599
|
+
* @param {Quat} b The second unit quaternion.
|
|
600
|
+
* @returns {Boolean} True if the quaternions are equal, false otherwise.
|
|
601
|
+
*/
|
|
602
|
+
export function equals(a, b) {
|
|
603
|
+
return Math.abs(vec4.dot(a, b)) >= 1 - EPSILON;
|
|
604
|
+
}
|
|
605
|
+
/**
|
|
606
|
+
* Sets a quaternion to represent the shortest rotation from one
|
|
607
|
+
* vector to another.
|
|
608
|
+
*
|
|
609
|
+
* Both vectors are assumed to be unit length.
|
|
610
|
+
*
|
|
611
|
+
* @param {quat} out the receiving quaternion.
|
|
612
|
+
* @param {Vec3} a the initial vector
|
|
613
|
+
* @param {Vec3} b the destination vector
|
|
614
|
+
* @returns {quat} out
|
|
615
|
+
*/
|
|
616
|
+
export const rotationTo = (function () {
|
|
617
|
+
const tmpVec3 = vec3.create();
|
|
618
|
+
const xUnitVec3 = vec3.fromValues(1, 0, 0);
|
|
619
|
+
const yUnitVec3 = vec3.fromValues(0, 1, 0);
|
|
620
|
+
return function (out, a, b) {
|
|
621
|
+
const dot = vec3.dot(a, b);
|
|
622
|
+
if (dot < -0.999999) {
|
|
623
|
+
vec3.cross(tmpVec3, xUnitVec3, a);
|
|
624
|
+
if (vec3.len(tmpVec3) < 0.000001)
|
|
625
|
+
vec3.cross(tmpVec3, yUnitVec3, a);
|
|
626
|
+
vec3.normalize(tmpVec3, tmpVec3);
|
|
627
|
+
setAxisAngle(out, tmpVec3, Math.PI);
|
|
628
|
+
return out;
|
|
629
|
+
}
|
|
630
|
+
else if (dot > 0.999999) {
|
|
631
|
+
out[0] = 0;
|
|
632
|
+
out[1] = 0;
|
|
633
|
+
out[2] = 0;
|
|
634
|
+
out[3] = 1;
|
|
635
|
+
return out;
|
|
636
|
+
}
|
|
637
|
+
else {
|
|
638
|
+
vec3.cross(tmpVec3, a, b);
|
|
639
|
+
out[0] = tmpVec3[0];
|
|
640
|
+
out[1] = tmpVec3[1];
|
|
641
|
+
out[2] = tmpVec3[2];
|
|
642
|
+
out[3] = 1 + dot;
|
|
643
|
+
return normalize(out, out);
|
|
644
|
+
}
|
|
645
|
+
};
|
|
646
|
+
})();
|
|
647
|
+
/**
|
|
648
|
+
* Performs a spherical linear interpolation with two control points
|
|
649
|
+
*
|
|
650
|
+
* @param {quat} out the receiving quaternion
|
|
651
|
+
* @param {Quat} a the first operand
|
|
652
|
+
* @param {Quat} b the second operand
|
|
653
|
+
* @param {Quat} c the third operand
|
|
654
|
+
* @param {Quat} d the fourth operand
|
|
655
|
+
* @param {Number} t interpolation amount, in the range [0-1], between the two inputs
|
|
656
|
+
* @returns {quat} out
|
|
657
|
+
*/
|
|
658
|
+
export const sqlerp = (function () {
|
|
659
|
+
const temp1 = create();
|
|
660
|
+
const temp2 = create();
|
|
661
|
+
return function (out, a, b, c, d, t) {
|
|
662
|
+
slerp(temp1, a, d, t);
|
|
663
|
+
slerp(temp2, b, c, t);
|
|
664
|
+
slerp(out, temp1, temp2, 2 * t * (1 - t));
|
|
665
|
+
return out;
|
|
666
|
+
};
|
|
667
|
+
})();
|
|
668
|
+
/**
|
|
669
|
+
* Sets the specified quaternion with values corresponding to the given
|
|
670
|
+
* axes. Each axis is a Vec3 and is expected to be unit length and
|
|
671
|
+
* perpendicular to all other specified axes.
|
|
672
|
+
*
|
|
673
|
+
* @param {Vec3} view the vector representing the viewing direction
|
|
674
|
+
* @param {Vec3} right the vector representing the local "right" direction
|
|
675
|
+
* @param {Vec3} up the vector representing the local "up" direction
|
|
676
|
+
* @returns {quat} out
|
|
677
|
+
*/
|
|
678
|
+
export const setAxes = (function () {
|
|
679
|
+
const matr = mat3.create();
|
|
680
|
+
return function (out, view, right, up) {
|
|
681
|
+
matr[0] = right[0];
|
|
682
|
+
matr[3] = right[1];
|
|
683
|
+
matr[6] = right[2];
|
|
684
|
+
matr[1] = up[0];
|
|
685
|
+
matr[4] = up[1];
|
|
686
|
+
matr[7] = up[2];
|
|
687
|
+
matr[2] = -view[0];
|
|
688
|
+
matr[5] = -view[1];
|
|
689
|
+
matr[8] = -view[2];
|
|
690
|
+
return normalize(out, fromMat3(out, matr));
|
|
691
|
+
};
|
|
692
|
+
})();
|
|
693
|
+
//# sourceMappingURL=quat.js.map
|