@shopify/react-native-skia 2.3.0 → 2.3.4
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/android/CMakeLists.txt +0 -3
 - package/android/cpp/rnskia-android/RNSkAndroidPlatformContext.h +4 -1
 - package/apple/RNSkApplePlatformContext.mm +21 -12
 - package/apple/SkiaCVPixelBufferUtils.mm +8 -4
 - package/cpp/api/JsiSkCanvas.h +0 -21
 - package/cpp/api/JsiSkImage.h +1 -5
 - package/cpp/api/JsiSkPath.h +1 -1
 - package/cpp/api/JsiSkPathFactory.h +1 -1
 - package/cpp/skia/include/android/AHardwareBufferUtils.h +3 -0
 - package/cpp/skia/include/android/GrAHardwareBufferUtils.h +0 -4
 - package/cpp/skia/include/android/SkAndroidFrameworkUtils.h +0 -4
 - package/cpp/skia/include/android/SkImageAndroid.h +1 -0
 - package/cpp/skia/include/codec/SkCodec.h +23 -2
 - package/cpp/skia/include/codec/SkPngRustDecoder.h +30 -0
 - package/cpp/skia/include/core/SkBitmap.h +1 -1
 - package/cpp/skia/include/core/SkCPURecorder.h +5 -0
 - package/cpp/skia/include/core/SkCanvas.h +2 -0
 - package/cpp/skia/include/core/SkColorSpace.h +11 -12
 - package/cpp/skia/include/core/SkContourMeasure.h +6 -2
 - package/cpp/skia/include/core/SkExecutor.h +18 -0
 - package/cpp/skia/include/core/SkFont.h +26 -19
 - package/cpp/skia/include/core/SkImage.h +4 -66
 - package/cpp/skia/include/core/SkImageGenerator.h +0 -5
 - package/cpp/skia/include/core/SkMatrix.h +84 -120
 - package/cpp/skia/include/core/SkMilestone.h +1 -1
 - package/cpp/skia/include/core/SkPath.h +390 -395
 - package/cpp/skia/include/core/SkPathBuilder.h +64 -34
 - package/cpp/skia/include/core/SkPathEffect.h +12 -5
 - package/cpp/skia/include/core/SkPathIter.h +90 -0
 - package/cpp/skia/include/core/SkPathMeasure.h +5 -1
 - package/cpp/skia/include/core/SkPathTypes.h +7 -3
 - package/cpp/skia/include/core/SkPathUtils.h +20 -13
 - package/cpp/skia/include/core/SkRRect.h +7 -11
 - package/cpp/skia/include/core/SkRecorder.h +12 -0
 - package/cpp/skia/include/core/SkRect.h +33 -8
 - package/cpp/skia/include/core/SkRegion.h +14 -3
 - package/cpp/skia/include/core/SkScalar.h +0 -12
 - package/cpp/skia/include/core/SkShader.h +20 -7
 - package/cpp/skia/include/core/SkStrokeRec.h +2 -1
 - package/cpp/skia/include/core/SkTypeface.h +8 -10
 - package/cpp/skia/include/core/SkTypes.h +4 -0
 - package/cpp/skia/include/encode/SkJpegEncoder.h +5 -10
 - package/cpp/skia/include/encode/SkPngEncoder.h +8 -7
 - package/cpp/skia/include/encode/SkPngRustEncoder.h +88 -0
 - package/cpp/skia/include/encode/SkWebpEncoder.h +5 -10
 - package/cpp/skia/include/gpu/graphite/BackendSemaphore.h +5 -2
 - package/cpp/skia/include/gpu/graphite/BackendTexture.h +5 -2
 - package/cpp/skia/include/gpu/graphite/Context.h +15 -2
 - package/cpp/skia/include/gpu/graphite/ContextOptions.h +26 -0
 - package/cpp/skia/include/gpu/graphite/GraphiteTypes.h +75 -0
 - package/cpp/skia/include/gpu/graphite/Recorder.h +15 -6
 - package/cpp/skia/include/gpu/graphite/Recording.h +0 -3
 - package/cpp/skia/include/gpu/graphite/mtl/MtlBackendContext.h +2 -0
 - package/cpp/skia/include/gpu/graphite/precompile/PaintOptions.h +3 -7
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileBase.h +2 -10
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileImageFilter.h +1 -6
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileMaskFilter.h +1 -5
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileShader.h +16 -3
 - package/cpp/skia/include/gpu/vk/VulkanPreferredFeatures.h +3 -0
 - package/cpp/skia/{modules/pathops/include → include/pathops}/SkPathOps.h +49 -20
 - package/cpp/skia/include/ports/SkFontMgr_FontConfigInterface.h +2 -1
 - package/cpp/skia/include/ports/SkFontMgr_android.h +0 -4
 - package/cpp/skia/include/ports/SkFontMgr_android_ndk.h +4 -2
 - package/cpp/skia/include/ports/SkFontMgr_fontconfig.h +0 -3
 - package/cpp/skia/include/private/SkEncodedInfo.h +73 -54
 - package/cpp/skia/include/private/SkHdrMetadata.h +173 -0
 - package/cpp/skia/include/private/SkPathRef.h +117 -146
 - package/cpp/skia/include/private/base/SkTemplates.h +74 -32
 - package/cpp/skia/include/utils/SkParsePath.h +9 -1
 - package/cpp/skia/modules/skcms/src/Transform_inl.h +53 -7
 - package/cpp/skia/modules/skcms/src/skcms_Transform.h +2 -0
 - package/cpp/skia/modules/skcms/src/skcms_internals.h +8 -0
 - package/cpp/skia/modules/skottie/include/TextShaper.h +4 -0
 - package/cpp/skia/modules/skparagraph/include/FontCollection.h +1 -1
 - package/cpp/skia/modules/skparagraph/include/ParagraphStyle.h +7 -1
 - package/cpp/skia/modules/skparagraph/include/TextStyle.h +12 -0
 - package/cpp/skia/modules/sksg/include/SkSGGeometryEffect.h +26 -0
 - package/cpp/skia/modules/sksg/include/SkSGPath.h +1 -1
 - package/cpp/skia/modules/skunicode/include/SkUnicode.h +11 -1
 - package/cpp/skia/modules/svg/include/SkSVGAttributeParser.h +7 -11
 - package/cpp/skia/modules/svg/include/SkSVGCircle.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGEllipse.h +1 -2
 - package/cpp/skia/modules/svg/include/SkSVGFe.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGFeLightSource.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGFeLighting.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGLine.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGNode.h +11 -10
 - package/cpp/skia/modules/svg/include/SkSVGPath.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGPattern.h +4 -3
 - package/cpp/skia/modules/svg/include/SkSVGPoly.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGRadialGradient.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGRect.h +1 -2
 - package/cpp/skia/modules/svg/include/SkSVGRenderContext.h +5 -5
 - package/cpp/skia/modules/svg/include/SkSVGSVG.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGShape.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGTransformableNode.h +2 -2
 - package/cpp/skia/src/base/SkTLazy.h +8 -0
 - package/cpp/skia/src/core/SkLRUCache.h +17 -13
 - package/package.json +9 -8
 - package/react-native-skia.podspec +1 -2
 - package/scripts/install-skia.mjs +360 -0
 - package/cpp/skia/include/android/SkHeifDecoder.h +0 -50
 - package/lib/commonjs/__tests__/globalSetup.d.ts +0 -9
 - package/lib/commonjs/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/commonjs/__tests__/setup.d.ts +0 -36
 - package/lib/commonjs/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/commonjs/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/commonjs/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/commonjs/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/commonjs/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/commonjs/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/commonjs/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/commonjs/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/setup.d.ts +0 -16
 - package/lib/commonjs/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/module/__tests__/globalSetup.d.ts +0 -9
 - package/lib/module/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/module/__tests__/setup.d.ts +0 -36
 - package/lib/module/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/module/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/module/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/module/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/module/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/module/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/module/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/module/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/setup.d.ts +0 -16
 - package/lib/module/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/typescript/src/__tests__/globalSetup.d.ts +0 -9
 - package/lib/typescript/src/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/typescript/src/__tests__/setup.d.ts +0 -36
 - package/lib/typescript/src/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/typescript/src/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/typescript/src/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/typescript/src/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/typescript/src/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/setup.d.ts +0 -16
 - package/lib/typescript/src/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/libs/android/arm64-v8a/libjsonreader.a +0 -0
 - package/libs/android/arm64-v8a/libpathops.a +0 -0
 - package/libs/android/arm64-v8a/libskia.a +0 -0
 - package/libs/android/arm64-v8a/libskottie.a +0 -0
 - package/libs/android/arm64-v8a/libskparagraph.a +0 -0
 - package/libs/android/arm64-v8a/libsksg.a +0 -0
 - package/libs/android/arm64-v8a/libskshaper.a +0 -0
 - package/libs/android/arm64-v8a/libskunicode_core.a +0 -0
 - package/libs/android/arm64-v8a/libskunicode_icu.a +0 -0
 - package/libs/android/arm64-v8a/libsvg.a +0 -0
 - package/libs/android/armeabi-v7a/libjsonreader.a +0 -0
 - package/libs/android/armeabi-v7a/libpathops.a +0 -0
 - package/libs/android/armeabi-v7a/libskia.a +0 -0
 - package/libs/android/armeabi-v7a/libskottie.a +0 -0
 - package/libs/android/armeabi-v7a/libskparagraph.a +0 -0
 - package/libs/android/armeabi-v7a/libsksg.a +0 -0
 - package/libs/android/armeabi-v7a/libskshaper.a +0 -0
 - package/libs/android/armeabi-v7a/libskunicode_core.a +0 -0
 - package/libs/android/armeabi-v7a/libskunicode_icu.a +0 -0
 - package/libs/android/armeabi-v7a/libsvg.a +0 -0
 - package/libs/android/x86/libjsonreader.a +0 -0
 - package/libs/android/x86/libpathops.a +0 -0
 - package/libs/android/x86/libskia.a +0 -0
 - package/libs/android/x86/libskottie.a +0 -0
 - package/libs/android/x86/libskparagraph.a +0 -0
 - package/libs/android/x86/libsksg.a +0 -0
 - package/libs/android/x86/libskshaper.a +0 -0
 - package/libs/android/x86/libskunicode_core.a +0 -0
 - package/libs/android/x86/libskunicode_icu.a +0 -0
 - package/libs/android/x86/libsvg.a +0 -0
 - package/libs/android/x86_64/libjsonreader.a +0 -0
 - package/libs/android/x86_64/libpathops.a +0 -0
 - package/libs/android/x86_64/libskia.a +0 -0
 - package/libs/android/x86_64/libskottie.a +0 -0
 - package/libs/android/x86_64/libskparagraph.a +0 -0
 - package/libs/android/x86_64/libsksg.a +0 -0
 - package/libs/android/x86_64/libskshaper.a +0 -0
 - package/libs/android/x86_64/libskunicode_core.a +0 -0
 - package/libs/android/x86_64/libskunicode_icu.a +0 -0
 - package/libs/android/x86_64/libsvg.a +0 -0
 - package/libs/apple/libpathops.xcframework/Info.plist +0 -111
 - package/libs/apple/libpathops.xcframework/ios-arm64_arm64e/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/ios-arm64_arm64e_x86_64-simulator/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/ios-arm64_x86_64-maccatalyst/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/macos-arm64_x86_64/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/tvos-arm64_arm64e/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/tvos-arm64_arm64e_x86_64-simulator/libpathops.a +0 -0
 - package/libs/apple/libskia.xcframework/Info.plist +0 -111
 - package/libs/apple/libskia.xcframework/ios-arm64_arm64e/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/ios-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/ios-arm64_x86_64-maccatalyst/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/macos-arm64_x86_64/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/tvos-arm64_arm64e/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
 - package/libs/apple/libskottie.xcframework/Info.plist +0 -111
 - package/libs/apple/libskottie.xcframework/ios-arm64_arm64e/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/ios-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/ios-arm64_x86_64-maccatalyst/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/macos-arm64_x86_64/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/tvos-arm64_arm64e/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/Info.plist +0 -111
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_arm64e/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_x86_64-maccatalyst/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/macos-arm64_x86_64/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/tvos-arm64_arm64e/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
 - package/libs/apple/libsksg.xcframework/Info.plist +0 -111
 - package/libs/apple/libsksg.xcframework/ios-arm64_arm64e/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/ios-arm64_x86_64-maccatalyst/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/macos-arm64_x86_64/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/tvos-arm64_arm64e/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/tvos-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
 - package/libs/apple/libskshaper.xcframework/Info.plist +0 -111
 - package/libs/apple/libskshaper.xcframework/ios-arm64_arm64e/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/ios-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/ios-arm64_x86_64-maccatalyst/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/macos-arm64_x86_64/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/tvos-arm64_arm64e/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/Info.plist +0 -111
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_arm64e/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_x86_64-maccatalyst/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/macos-arm64_x86_64/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/tvos-arm64_arm64e/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/Info.plist +0 -111
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_arm64e/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_x86_64-maccatalyst/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/macos-arm64_x86_64/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/tvos-arm64_arm64e/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libsvg.xcframework/Info.plist +0 -111
 - package/libs/apple/libsvg.xcframework/ios-arm64_arm64e/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/ios-arm64_x86_64-maccatalyst/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/macos-arm64_x86_64/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/tvos-arm64_arm64e/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/tvos-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
 - package/src/__tests__/globalSetup.ts +0 -53
 - package/src/__tests__/globalTeardown.ts +0 -11
 - package/src/__tests__/setup.ts +0 -192
 - package/src/__tests__/snapshots/animated-images/bird.png +0 -0
 - package/src/__tests__/snapshots/animations/green.png +0 -0
 - package/src/__tests__/snapshots/animations/lightblue.png +0 -0
 - package/src/__tests__/snapshots/animations/quarter-lightblue.png +0 -0
 - package/src/__tests__/snapshots/animations/red.png +0 -0
 - package/src/__tests__/snapshots/atlas/identity.png +0 -0
 - package/src/__tests__/snapshots/atlas/rsxform.png +0 -0
 - package/src/__tests__/snapshots/atlas/rsxform1.png +0 -0
 - package/src/__tests__/snapshots/atlas/simple.png +0 -0
 - package/src/__tests__/snapshots/atlas/simple2.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow-opacity.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow2.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow3.png +0 -0
 - package/src/__tests__/snapshots/box/box-stroke.png +0 -0
 - package/src/__tests__/snapshots/color-filter/color-filter-composition.png +0 -0
 - package/src/__tests__/snapshots/color-filter/matrix1.png +0 -0
 - package/src/__tests__/snapshots/color-filter/matrix3.png +0 -0
 - package/src/__tests__/snapshots/color-filter/zurich-sepia.png +0 -0
 - package/src/__tests__/snapshots/coons-patch/patch-with-opacity.png +0 -0
 - package/src/__tests__/snapshots/coons-patch/simple.png +0 -0
 - package/src/__tests__/snapshots/cyan-buffer.png +0 -0
 - package/src/__tests__/snapshots/data/oslo.png +0 -0
 - package/src/__tests__/snapshots/data/red.png +0 -0
 - package/src/__tests__/snapshots/data/zurich.png +0 -0
 - package/src/__tests__/snapshots/demos/apple-breathe.png +0 -0
 - package/src/__tests__/snapshots/demos/apple-breathe1.png +0 -0
 - package/src/__tests__/snapshots/demos/breathe.png +0 -0
 - package/src/__tests__/snapshots/demos/breathe2.png +0 -0
 - package/src/__tests__/snapshots/demos/product.png +0 -0
 - package/src/__tests__/snapshots/demos/product2.png +0 -0
 - package/src/__tests__/snapshots/demos/skia-neon.png +0 -0
 - package/src/__tests__/snapshots/demos/skia-neon1.png +0 -0
 - package/src/__tests__/snapshots/drawings/arc.png +0 -0
 - package/src/__tests__/snapshots/drawings/blend-mode-multiply.png +0 -0
 - package/src/__tests__/snapshots/drawings/blend-modes.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur-node.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur2.png +0 -0
 - package/src/__tests__/snapshots/drawings/custom-drawing.png +0 -0
 - package/src/__tests__/snapshots/drawings/cyan-circle.png +0 -0
 - package/src/__tests__/snapshots/drawings/cyan.png +0 -0
 - package/src/__tests__/snapshots/drawings/default-props.png +0 -0
 - package/src/__tests__/snapshots/drawings/hello-world.png +0 -0
 - package/src/__tests__/snapshots/drawings/image-default-props.png +0 -0
 - package/src/__tests__/snapshots/drawings/lightblue-quarter-circle.png +0 -0
 - package/src/__tests__/snapshots/drawings/lightblue-rect.png +0 -0
 - package/src/__tests__/snapshots/drawings/line.png +0 -0
 - package/src/__tests__/snapshots/drawings/multiple-paints.png +0 -0
 - package/src/__tests__/snapshots/drawings/nested-shader.png +0 -0
 - package/src/__tests__/snapshots/drawings/nested-shader2.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-multiplication.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-multiplication2.png +0 -0
 - package/src/__tests__/snapshots/drawings/points.png +0 -0
 - package/src/__tests__/snapshots/drawings/purple.png +0 -0
 - package/src/__tests__/snapshots/drawings/rotated-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/rotated-scaled-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/rrect-aa.png +0 -0
 - package/src/__tests__/snapshots/drawings/rrect-no-aa.png +0 -0
 - package/src/__tests__/snapshots/drawings/scaled-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/scaled-image2.png +0 -0
 - package/src/__tests__/snapshots/drawings/semi-transparent-layer.png +0 -0
 - package/src/__tests__/snapshots/drawings/shader-opacity-reference.png +0 -0
 - package/src/__tests__/snapshots/drawings/skew-transform.png +0 -0
 - package/src/__tests__/snapshots/drawings/skew-transform2.png +0 -0
 - package/src/__tests__/snapshots/drawings/small-lightblue-rect.png +0 -0
 - package/src/__tests__/snapshots/drawings/stroke.png +0 -0
 - package/src/__tests__/snapshots/drawings/transform-origin.png +0 -0
 - package/src/__tests__/snapshots/drawings/transparent-layer.png +0 -0
 - package/src/__tests__/snapshots/drawings/transparent.png +0 -0
 - package/src/__tests__/snapshots/drawings/violet.png +0 -0
 - package/src/__tests__/snapshots/font/green.png +0 -0
 - package/src/__tests__/snapshots/font/red.png +0 -0
 - package/src/__tests__/snapshots/glyphs/simple.png +0 -0
 - package/src/__tests__/snapshots/gradient/linear-with-opacity.png +0 -0
 - package/src/__tests__/snapshots/gradient/linear.png +0 -0
 - package/src/__tests__/snapshots/green.png +0 -0
 - package/src/__tests__/snapshots/image-filter/blur.png +0 -0
 - package/src/__tests__/snapshots/image-filter/test-shadow.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-android.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-ios.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-node.png +0 -0
 - package/src/__tests__/snapshots/images/bundle.png +0 -0
 - package/src/__tests__/snapshots/images/filter.png +0 -0
 - package/src/__tests__/snapshots/leak.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-corner.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-offset.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-top-left-center.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-zoom-out.png +0 -0
 - package/src/__tests__/snapshots/matrix4/full-rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/perspective.png +0 -0
 - package/src/__tests__/snapshots/matrix4/rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/scaled-rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/test-perspective.png +0 -0
 - package/src/__tests__/snapshots/matrix4/test-perspective2.png +0 -0
 - package/src/__tests__/snapshots/paint/blend-mode.png +0 -0
 - package/src/__tests__/snapshots/paint/circle.png +0 -0
 - package/src/__tests__/snapshots/paint/colors.png +0 -0
 - package/src/__tests__/snapshots/paint/dither.png +0 -0
 - package/src/__tests__/snapshots/paint/path-paint.png +0 -0
 - package/src/__tests__/snapshots/paint/without-dither.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-node.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-ellipse-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-ellipse-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android-box.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios-box.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-node.png +0 -0
 - package/src/__tests__/snapshots/path/interpolate.png +0 -0
 - package/src/__tests__/snapshots/path/logo.png +0 -0
 - package/src/__tests__/snapshots/path-effects/discrete.png +0 -0
 - package/src/__tests__/snapshots/path-effects/sum.png +0 -0
 - package/src/__tests__/snapshots/path-effects/sum2.png +0 -0
 - package/src/__tests__/snapshots/paths/arc.png +0 -0
 - package/src/__tests__/snapshots/paths/emptyPath.png +0 -0
 - package/src/__tests__/snapshots/paths/interpolation1.png +0 -0
 - package/src/__tests__/snapshots/paths/oval.png +0 -0
 - package/src/__tests__/snapshots/paths/pattern.png +0 -0
 - package/src/__tests__/snapshots/paths/poly.png +0 -0
 - package/src/__tests__/snapshots/paths/rrect.png +0 -0
 - package/src/__tests__/snapshots/paths/skia-trimmed.png +0 -0
 - package/src/__tests__/snapshots/paths/skia.png +0 -0
 - package/src/__tests__/snapshots/pictures/create-picture.png +0 -0
 - package/src/__tests__/snapshots/pictures/green.png +0 -0
 - package/src/__tests__/snapshots/pictures/hello-world.png +0 -0
 - package/src/__tests__/snapshots/pictures/red.png +0 -0
 - package/src/__tests__/snapshots/pictures/simple-picture.png +0 -0
 - package/src/__tests__/snapshots/platform-buffer-bgra.png +0 -0
 - package/src/__tests__/snapshots/platform-buffer.png +0 -0
 - package/src/__tests__/snapshots/points/points.png +0 -0
 - package/src/__tests__/snapshots/points/points2.png +0 -0
 - package/src/__tests__/snapshots/render-nodes/simple.png +0 -0
 - package/src/__tests__/snapshots/render-nodes/simple2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn3.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-dodge.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-multiply.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/int-uniform.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/linear-gradient.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/linear-gradient2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/small-spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/scaled-circle.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/scaled-circle2.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/simple.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/unscaled-image.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot5-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot5-ios.png +0 -0
 - package/src/__tests__/snapshots/sdf/circle.png +0 -0
 - package/src/__tests__/snapshots/sdf/heart.png +0 -0
 - package/src/__tests__/snapshots/sdf/line.png +0 -0
 - package/src/__tests__/snapshots/sdf/rectangle.png +0 -0
 - package/src/__tests__/snapshots/shader/bilinear-interpolation.png +0 -0
 - package/src/__tests__/snapshots/shader/hue.png +0 -0
 - package/src/__tests__/snapshots/shader/hue2.png +0 -0
 - package/src/__tests__/snapshots/shader/shader1.png +0 -0
 - package/src/__tests__/snapshots/shader/shader2.png +0 -0
 - package/src/__tests__/snapshots/shader/sweep-gradient.png +0 -0
 - package/src/__tests__/snapshots/sksg/breathe-0.png +0 -0
 - package/src/__tests__/snapshots/sksg/breathe.png +0 -0
 - package/src/__tests__/snapshots/sksg/simple.png +0 -0
 - package/src/__tests__/snapshots/sksg/simple2.png +0 -0
 - package/src/__tests__/snapshots/text/text-bounds-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-bounds-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-default-font-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-default-font-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-node.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-node.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-node.png +0 -0
 - package/src/__tests__/snapshots/transform/rectangles.png +0 -0
 - package/src/__tests__/snapshots/transform/rotate-radiants.png +0 -0
 - package/src/__tests__/snapshots/transform/rotate.png +0 -0
 - package/src/__tests__/snapshots/transform/scale-origin.png +0 -0
 - package/src/__tests__/snapshots/transform/scale.png +0 -0
 - package/src/__tests__/snapshots/transform/skew.png +0 -0
 - package/src/__tests__/snapshots/transparent.png +0 -0
 - package/src/__tests__/snapshots/vertices/billinear-gradient.png +0 -0
 - package/src/__tests__/snapshots/vertices/strip.png +0 -0
 - package/src/__tests__/snapshots/vertices/vertices.png +0 -0
 - package/src/mock/__tests__/mock.spec.ts +0 -47
 - package/src/renderer/__tests__/Data.spec.tsx +0 -66
 - package/src/renderer/__tests__/Drawings.spec.tsx +0 -96
 - package/src/renderer/__tests__/FitBox.spec.tsx +0 -677
 - package/src/renderer/__tests__/Glyphs.spec.tsx +0 -46
 - package/src/renderer/__tests__/Image.spec.tsx +0 -45
 - package/src/renderer/__tests__/Paths.spec.tsx +0 -75
 - package/src/renderer/__tests__/Picture.spec.tsx +0 -83
 - package/src/renderer/__tests__/Simple.spec.tsx +0 -81
 - package/src/renderer/__tests__/Surfaces.spec.tsx +0 -68
 - package/src/renderer/__tests__/Text.spec.tsx +0 -134
 - package/src/renderer/__tests__/Transform.spec.tsx +0 -72
 - package/src/renderer/__tests__/documentation/Group.spec.tsx +0 -170
 - package/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.tsx +0 -51
 - package/src/renderer/__tests__/documentation/paint/Overview.spec.tsx +0 -84
 - package/src/renderer/__tests__/documentation/shapes/Box.spec.tsx +0 -46
 - package/src/renderer/__tests__/e2e/AdvancedImageFilters.spec.tsx +0 -492
 - package/src/renderer/__tests__/e2e/AnimatedImages.spec.tsx +0 -87
 - package/src/renderer/__tests__/e2e/Atlas.spec.tsx +0 -358
 - package/src/renderer/__tests__/e2e/BackdropFilters.spec.tsx +0 -164
 - package/src/renderer/__tests__/e2e/Blending.spec.tsx +0 -115
 - package/src/renderer/__tests__/e2e/Blur.spec.tsx +0 -56
 - package/src/renderer/__tests__/e2e/Box.spec.tsx +0 -105
 - package/src/renderer/__tests__/e2e/Camera.spec.tsx +0 -475
 - package/src/renderer/__tests__/e2e/ColorFilters.spec.tsx +0 -227
 - package/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.tsx +0 -102
 - package/src/renderer/__tests__/e2e/CoonPatch.spec.tsx +0 -74
 - package/src/renderer/__tests__/e2e/DataEncoding.spec.tsx +0 -79
 - package/src/renderer/__tests__/e2e/Drawings.spec.tsx +0 -254
 - package/src/renderer/__tests__/e2e/FontMgr.spec.tsx +0 -150
 - package/src/renderer/__tests__/e2e/Gradient.spec.tsx +0 -40
 - package/src/renderer/__tests__/e2e/Group.spec.tsx +0 -128
 - package/src/renderer/__tests__/e2e/Image.spec.tsx +0 -77
 - package/src/renderer/__tests__/e2e/ImageEncoding.spec.tsx +0 -255
 - package/src/renderer/__tests__/e2e/ImageFilter.spec.tsx +0 -99
 - package/src/renderer/__tests__/e2e/ImageFilters.spec.tsx +0 -320
 - package/src/renderer/__tests__/e2e/LightingImageFilters.spec.tsx +0 -1478
 - package/src/renderer/__tests__/e2e/Mask.spec.tsx +0 -85
 - package/src/renderer/__tests__/e2e/Matrix4.spec.tsx +0 -367
 - package/src/renderer/__tests__/e2e/NativeBuffer.spec.tsx +0 -158
 - package/src/renderer/__tests__/e2e/Offscreen.spec.tsx +0 -109
 - package/src/renderer/__tests__/e2e/Opacity.spec.tsx +0 -301
 - package/src/renderer/__tests__/e2e/Paint.spec.tsx +0 -230
 - package/src/renderer/__tests__/e2e/ParagraphMethods.spec.tsx +0 -388
 - package/src/renderer/__tests__/e2e/ParagraphPaint.spec.tsx +0 -262
 - package/src/renderer/__tests__/e2e/Paragraphs.spec.tsx +0 -615
 - package/src/renderer/__tests__/e2e/PathEffects.spec.tsx +0 -73
 - package/src/renderer/__tests__/e2e/Paths.spec.tsx +0 -394
 - package/src/renderer/__tests__/e2e/Picture.spec.tsx +0 -134
 - package/src/renderer/__tests__/e2e/Point.spec.tsx +0 -35
 - package/src/renderer/__tests__/e2e/Rect.spec.tsx +0 -139
 - package/src/renderer/__tests__/e2e/RuntimeShader.spec.tsx +0 -323
 - package/src/renderer/__tests__/e2e/SDF.spec.tsx +0 -148
 - package/src/renderer/__tests__/e2e/SVG.spec.tsx +0 -192
 - package/src/renderer/__tests__/e2e/Shader.spec.tsx +0 -353
 - package/src/renderer/__tests__/e2e/Skottie.spec.tsx +0 -463
 - package/src/renderer/__tests__/e2e/Snapshot.spec.tsx +0 -29
 - package/src/renderer/__tests__/e2e/Surfaces.spec.tsx +0 -17
 - package/src/renderer/__tests__/e2e/Text.spec.tsx +0 -109
 - package/src/renderer/__tests__/e2e/TextPath.spec.tsx +0 -43
 - package/src/renderer/__tests__/e2e/Transforms.spec.tsx +0 -63
 - package/src/renderer/__tests__/e2e/Vertices.spec.tsx +0 -30
 - package/src/renderer/__tests__/e2e/Video.ts +0 -68
 - package/src/renderer/__tests__/e2e/setup/Paragraph.ts +0 -60
 - package/src/renderer/__tests__/e2e/setup/SVG.ts +0 -31
 - package/src/renderer/__tests__/e2e/setup/SkiaObject.ts +0 -31
 - package/src/renderer/__tests__/e2e/setup/index.ts +0 -3
 - package/src/renderer/__tests__/e2e/setup/skottie/basic_slots.json +0 -1118
 - package/src/renderer/__tests__/e2e/setup/skottie/color-props.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/confetti.json +0 -5899
 - package/src/renderer/__tests__/e2e/setup/skottie/drinks.json +0 -43857
 - package/src/renderer/__tests__/e2e/setup/skottie/fingerprint.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/lego_loader.json +0 -29540
 - package/src/renderer/__tests__/e2e/setup/skottie/new-drop.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/onboarding.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/text-layer.json +0 -1
 - package/src/renderer/__tests__/examples/BlendModes.spec.tsx +0 -123
 - package/src/renderer/__tests__/setup.tsx +0 -525
 - package/src/skia/__tests__/ColorFilter.spec.ts +0 -67
 - package/src/skia/__tests__/Data.spec.ts +0 -29
 - package/src/skia/__tests__/Drawings.spec.ts +0 -119
 - package/src/skia/__tests__/Enums.spec.ts +0 -136
 - package/src/skia/__tests__/Geometry.spec.ts +0 -39
 - package/src/skia/__tests__/ImageFilter.spec.ts +0 -19
 - package/src/skia/__tests__/Mock.spec.ts +0 -7
 - package/src/skia/__tests__/Paint.spec.ts +0 -25
 - package/src/skia/__tests__/Path.spec.ts +0 -384
 - package/src/skia/__tests__/RuntimeEffect.spec.ts +0 -66
 - package/src/skia/__tests__/Shader.spec.ts +0 -96
 - package/src/skia/__tests__/Text.spec.ts +0 -32
 - package/src/skia/__tests__/Transform.spec.ts +0 -89
 - package/src/skia/__tests__/Vertices.spec.ts +0 -40
 - package/src/skia/__tests__/assets/Avenir-Heavy.ttf +0 -0
 - package/src/skia/__tests__/assets/DIN-Medium.ttf +0 -0
 - package/src/skia/__tests__/assets/NotoColorEmoji.ttf +0 -0
 - package/src/skia/__tests__/assets/NotoSansSC-Regular.otf +0 -0
 - package/src/skia/__tests__/assets/Pacifico-Regular.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-BlackItalic.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Bold.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Italic.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Medium.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Regular.ttf +0 -0
 - package/src/skia/__tests__/assets/UberMove-Medium_mono.ttf +0 -0
 - package/src/skia/__tests__/assets/bird.gif +0 -0
 - package/src/skia/__tests__/assets/box.png +0 -0
 - package/src/skia/__tests__/assets/box2.png +0 -0
 - package/src/skia/__tests__/assets/card.png +0 -0
 - package/src/skia/__tests__/assets/mask.png +0 -0
 - package/src/skia/__tests__/assets/oslo-mini.jpg +0 -0
 - package/src/skia/__tests__/assets/oslo.jpg +0 -0
 - package/src/skia/__tests__/assets/product.png +0 -0
 - package/src/skia/__tests__/assets/skia_logo.png +0 -0
 - package/src/skia/__tests__/assets/skia_logo_jpeg.jpg +0 -0
 - package/src/skia/__tests__/assets/tiger.svg +0 -724
 - package/src/skia/__tests__/assets/zurich.jpg +0 -0
 - package/src/skia/__tests__/setup.ts +0 -27
 - package/src/sksg/__tests__/Simple.spec.tsx +0 -148
 
| 
         @@ -1,105 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { checkImage, docPath } from "../../../__tests__/setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import { Box, BoxShadow, Fill, FitBox } from "../../components";
         
     | 
| 
       5 
     | 
    
         
            -
            import { surface, importSkia, PIXEL_RATIO } from "../setup";
         
     | 
| 
       6 
     | 
    
         
            -
             
     | 
| 
       7 
     | 
    
         
            -
            describe("Box", () => {
         
     | 
| 
       8 
     | 
    
         
            -
              it("should draw a box with inner and outer shadow", async () => {
         
     | 
| 
       9 
     | 
    
         
            -
                const { rect, rrect } = importSkia();
         
     | 
| 
       10 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       11 
     | 
    
         
            -
                const size = width / 2;
         
     | 
| 
       12 
     | 
    
         
            -
                const d = 10 * PIXEL_RATIO;
         
     | 
| 
       13 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       14 
     | 
    
         
            -
                  <>
         
     | 
| 
       15 
     | 
    
         
            -
                    <Fill color="#add8e6" />
         
     | 
| 
       16 
     | 
    
         
            -
                    <Box
         
     | 
| 
       17 
     | 
    
         
            -
                      box={rrect(rect(size / 2, size / 2, size, size), 24, 24)}
         
     | 
| 
       18 
     | 
    
         
            -
                      color="#add8e6"
         
     | 
| 
       19 
     | 
    
         
            -
                    >
         
     | 
| 
       20 
     | 
    
         
            -
                      <BoxShadow dx={d} dy={d} blur={d} color="#93b8c4" inner />
         
     | 
| 
       21 
     | 
    
         
            -
                      <BoxShadow dx={-d} dy={-d} blur={d} color="#c7f8ff" inner />
         
     | 
| 
       22 
     | 
    
         
            -
                      <BoxShadow dx={d} dy={d} blur={d} color="#93b8c4" />
         
     | 
| 
       23 
     | 
    
         
            -
                      <BoxShadow dx={-d} dy={-d} blur={d} color="#c7f8ff" />
         
     | 
| 
       24 
     | 
    
         
            -
                    </Box>
         
     | 
| 
       25 
     | 
    
         
            -
                  </>
         
     | 
| 
       26 
     | 
    
         
            -
                );
         
     | 
| 
       27 
     | 
    
         
            -
                checkImage(img, docPath("box/box-shadow.png"));
         
     | 
| 
       28 
     | 
    
         
            -
              });
         
     | 
| 
       29 
     | 
    
         
            -
              it("should render negative values", async () => {
         
     | 
| 
       30 
     | 
    
         
            -
                const { rect } = importSkia();
         
     | 
| 
       31 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       32 
     | 
    
         
            -
                const w = width;
         
     | 
| 
       33 
     | 
    
         
            -
                const h = width;
         
     | 
| 
       34 
     | 
    
         
            -
                const src = { x: 15, y: 15, width: w - 30, height: h - 30 };
         
     | 
| 
       35 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       36 
     | 
    
         
            -
                  <FitBox src={src} dst={rect(30, 15, w - 30, h - 10)}>
         
     | 
| 
       37 
     | 
    
         
            -
                    <Box box={src} color={"white"}>
         
     | 
| 
       38 
     | 
    
         
            -
                      <BoxShadow dx={5} dy={12} blur={5} color={"red"} />
         
     | 
| 
       39 
     | 
    
         
            -
                      <BoxShadow dx={5} dy={12} blur={5} color={"red"} />
         
     | 
| 
       40 
     | 
    
         
            -
                      <BoxShadow dx={-5} dy={-12} blur={5} color={"green"} />
         
     | 
| 
       41 
     | 
    
         
            -
                      <BoxShadow dx={-5} dy={-12} blur={5} color={"green"} />
         
     | 
| 
       42 
     | 
    
         
            -
                    </Box>
         
     | 
| 
       43 
     | 
    
         
            -
                  </FitBox>
         
     | 
| 
       44 
     | 
    
         
            -
                );
         
     | 
| 
       45 
     | 
    
         
            -
                checkImage(img, "snapshots/box/box-shadow2.png");
         
     | 
| 
       46 
     | 
    
         
            -
              });
         
     | 
| 
       47 
     | 
    
         
            -
              it("should render have rounded corners", async () => {
         
     | 
| 
       48 
     | 
    
         
            -
                const { rect } = importSkia();
         
     | 
| 
       49 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       50 
     | 
    
         
            -
                const w = width;
         
     | 
| 
       51 
     | 
    
         
            -
                const h = width;
         
     | 
| 
       52 
     | 
    
         
            -
                const src = { x: 15, y: 15, width: w - 30, height: h - 30 };
         
     | 
| 
       53 
     | 
    
         
            -
                const border = { rect: src, rx: 10, ry: 10 };
         
     | 
| 
       54 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       55 
     | 
    
         
            -
                  <FitBox src={src} dst={rect(30, 15, w - 30, h - 10)}>
         
     | 
| 
       56 
     | 
    
         
            -
                    <Box box={border} color={"white"}>
         
     | 
| 
       57 
     | 
    
         
            -
                      <BoxShadow dx={5} dy={12} blur={5} color={"red"} />
         
     | 
| 
       58 
     | 
    
         
            -
                      <BoxShadow dx={5} dy={12} blur={5} color={"red"} />
         
     | 
| 
       59 
     | 
    
         
            -
                      <BoxShadow dx={-5} dy={-12} blur={5} color={"green"} />
         
     | 
| 
       60 
     | 
    
         
            -
                      <BoxShadow dx={-5} dy={-12} blur={5} color={"green"} />
         
     | 
| 
       61 
     | 
    
         
            -
                    </Box>
         
     | 
| 
       62 
     | 
    
         
            -
                  </FitBox>
         
     | 
| 
       63 
     | 
    
         
            -
                );
         
     | 
| 
       64 
     | 
    
         
            -
                checkImage(img, "snapshots/box/box-shadow3.png");
         
     | 
| 
       65 
     | 
    
         
            -
              });
         
     | 
| 
       66 
     | 
    
         
            -
             
     | 
| 
       67 
     | 
    
         
            -
              it("should draw a box with red stroke", async () => {
         
     | 
| 
       68 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       69 
     | 
    
         
            -
                const size = width / 2;
         
     | 
| 
       70 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       71 
     | 
    
         
            -
                  <>
         
     | 
| 
       72 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       73 
     | 
    
         
            -
                    <Box
         
     | 
| 
       74 
     | 
    
         
            -
                      box={{ width: size, height: size, x: 1 / 3, y: 1 / 3 }}
         
     | 
| 
       75 
     | 
    
         
            -
                      color="red"
         
     | 
| 
       76 
     | 
    
         
            -
                      style="stroke"
         
     | 
| 
       77 
     | 
    
         
            -
                      strokeWidth={2 / 3}
         
     | 
| 
       78 
     | 
    
         
            -
                    />
         
     | 
| 
       79 
     | 
    
         
            -
                  </>
         
     | 
| 
       80 
     | 
    
         
            -
                );
         
     | 
| 
       81 
     | 
    
         
            -
                checkImage(img, "snapshots/box/box-stroke.png");
         
     | 
| 
       82 
     | 
    
         
            -
              });
         
     | 
| 
       83 
     | 
    
         
            -
             
     | 
| 
       84 
     | 
    
         
            -
              it("should draw a shadow with opacity", async () => {
         
     | 
| 
       85 
     | 
    
         
            -
                const { rect } = importSkia();
         
     | 
| 
       86 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       87 
     | 
    
         
            -
                const size = width / 2;
         
     | 
| 
       88 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       89 
     | 
    
         
            -
                  <>
         
     | 
| 
       90 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       91 
     | 
    
         
            -
                    <Box box={rect(size / 2, size / 2, size, size)} color="red">
         
     | 
| 
       92 
     | 
    
         
            -
                      <BoxShadow
         
     | 
| 
       93 
     | 
    
         
            -
                        dx={0}
         
     | 
| 
       94 
     | 
    
         
            -
                        dy={0}
         
     | 
| 
       95 
     | 
    
         
            -
                        blur={5}
         
     | 
| 
       96 
     | 
    
         
            -
                        spread={10}
         
     | 
| 
       97 
     | 
    
         
            -
                        inner
         
     | 
| 
       98 
     | 
    
         
            -
                        color={"rgba(0, 0, 255, 0.5)"}
         
     | 
| 
       99 
     | 
    
         
            -
                      />
         
     | 
| 
       100 
     | 
    
         
            -
                    </Box>
         
     | 
| 
       101 
     | 
    
         
            -
                  </>
         
     | 
| 
       102 
     | 
    
         
            -
                );
         
     | 
| 
       103 
     | 
    
         
            -
                checkImage(img, "snapshots/box/box-shadow-opacity.png");
         
     | 
| 
       104 
     | 
    
         
            -
              });
         
     | 
| 
       105 
     | 
    
         
            -
            });
         
     | 
| 
         @@ -1,475 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { checkImage } from "../../../__tests__/setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import type { SkPath, SkRect, Vec3, Vec4 } from "../../../skia/types";
         
     | 
| 
       5 
     | 
    
         
            -
            import {
         
     | 
| 
       6 
     | 
    
         
            -
              mapPoint3d,
         
     | 
| 
       7 
     | 
    
         
            -
              processTransform3d,
         
     | 
| 
       8 
     | 
    
         
            -
              Matrix4,
         
     | 
| 
       9 
     | 
    
         
            -
              setupCamera,
         
     | 
| 
       10 
     | 
    
         
            -
            } from "../../../skia/types";
         
     | 
| 
       11 
     | 
    
         
            -
            import { Group, Path, Rect } from "../../components";
         
     | 
| 
       12 
     | 
    
         
            -
            import { importSkia, surface } from "../setup";
         
     | 
| 
       13 
     | 
    
         
            -
             
     | 
| 
       14 
     | 
    
         
            -
            const pickPoint = (p: number[], index = 0, offset = 3) =>
         
     | 
| 
       15 
     | 
    
         
            -
              [
         
     | 
| 
       16 
     | 
    
         
            -
                p[0 + index * offset],
         
     | 
| 
       17 
     | 
    
         
            -
                p[1 + index * offset],
         
     | 
| 
       18 
     | 
    
         
            -
                p[2 + index * offset],
         
     | 
| 
       19 
     | 
    
         
            -
              ] as const;
         
     | 
| 
       20 
     | 
    
         
            -
             
     | 
| 
       21 
     | 
    
         
            -
            enum Path3Command {
         
     | 
| 
       22 
     | 
    
         
            -
              Move,
         
     | 
| 
       23 
     | 
    
         
            -
              Line,
         
     | 
| 
       24 
     | 
    
         
            -
              Quad,
         
     | 
| 
       25 
     | 
    
         
            -
              Cubic,
         
     | 
| 
       26 
     | 
    
         
            -
              Close,
         
     | 
| 
       27 
     | 
    
         
            -
            }
         
     | 
| 
       28 
     | 
    
         
            -
             
     | 
| 
       29 
     | 
    
         
            -
            export class Path3 {
         
     | 
| 
       30 
     | 
    
         
            -
              commands: [Path3Command, ...number[]][] = [];
         
     | 
| 
       31 
     | 
    
         
            -
             
     | 
| 
       32 
     | 
    
         
            -
              constructor() {}
         
     | 
| 
       33 
     | 
    
         
            -
             
     | 
| 
       34 
     | 
    
         
            -
              moveTo(to: Vec3) {
         
     | 
| 
       35 
     | 
    
         
            -
                this.commands.push([Path3Command.Move, ...to]);
         
     | 
| 
       36 
     | 
    
         
            -
                return this;
         
     | 
| 
       37 
     | 
    
         
            -
              }
         
     | 
| 
       38 
     | 
    
         
            -
             
     | 
| 
       39 
     | 
    
         
            -
              lineTo(to: Vec3) {
         
     | 
| 
       40 
     | 
    
         
            -
                this.commands.push([Path3Command.Line, ...to]);
         
     | 
| 
       41 
     | 
    
         
            -
                return this;
         
     | 
| 
       42 
     | 
    
         
            -
              }
         
     | 
| 
       43 
     | 
    
         
            -
             
     | 
| 
       44 
     | 
    
         
            -
              quadTo(control: Vec3, to: Vec3) {
         
     | 
| 
       45 
     | 
    
         
            -
                this.commands.push([Path3Command.Quad, ...control, ...to]);
         
     | 
| 
       46 
     | 
    
         
            -
                return this;
         
     | 
| 
       47 
     | 
    
         
            -
              }
         
     | 
| 
       48 
     | 
    
         
            -
             
     | 
| 
       49 
     | 
    
         
            -
              cubicTo(control1: Vec3, control2: Vec3, to: Vec3) {
         
     | 
| 
       50 
     | 
    
         
            -
                this.commands.push([Path3Command.Cubic, ...control1, ...control2, ...to]);
         
     | 
| 
       51 
     | 
    
         
            -
                return this;
         
     | 
| 
       52 
     | 
    
         
            -
              }
         
     | 
| 
       53 
     | 
    
         
            -
             
     | 
| 
       54 
     | 
    
         
            -
              close() {
         
     | 
| 
       55 
     | 
    
         
            -
                this.commands.push([Path3Command.Close]);
         
     | 
| 
       56 
     | 
    
         
            -
                return this;
         
     | 
| 
       57 
     | 
    
         
            -
              }
         
     | 
| 
       58 
     | 
    
         
            -
             
     | 
| 
       59 
     | 
    
         
            -
              addHRect(rect: SkRect, z: number) {
         
     | 
| 
       60 
     | 
    
         
            -
                const { x, y, width, height } = rect;
         
     | 
| 
       61 
     | 
    
         
            -
                const p0: Vec3 = [x, y, z];
         
     | 
| 
       62 
     | 
    
         
            -
                const p1: Vec3 = [x + width, y, z];
         
     | 
| 
       63 
     | 
    
         
            -
                const p2: Vec3 = [x + width, y + height, z];
         
     | 
| 
       64 
     | 
    
         
            -
                const p3: Vec3 = [x, y + height, z];
         
     | 
| 
       65 
     | 
    
         
            -
                this.moveTo(p0);
         
     | 
| 
       66 
     | 
    
         
            -
                this.lineTo(p1);
         
     | 
| 
       67 
     | 
    
         
            -
                this.lineTo(p2);
         
     | 
| 
       68 
     | 
    
         
            -
                this.lineTo(p3);
         
     | 
| 
       69 
     | 
    
         
            -
                this.close();
         
     | 
| 
       70 
     | 
    
         
            -
                return this;
         
     | 
| 
       71 
     | 
    
         
            -
              }
         
     | 
| 
       72 
     | 
    
         
            -
             
     | 
| 
       73 
     | 
    
         
            -
              project(output: SkPath, tr?: Matrix4) {
         
     | 
| 
       74 
     | 
    
         
            -
                const transform = tr ?? Matrix4();
         
     | 
| 
       75 
     | 
    
         
            -
                this.commands.forEach(([cmd, ...args]) => {
         
     | 
| 
       76 
     | 
    
         
            -
                  switch (cmd) {
         
     | 
| 
       77 
     | 
    
         
            -
                    case Path3Command.Move: {
         
     | 
| 
       78 
     | 
    
         
            -
                      const to = mapPoint3d(transform, pickPoint(args));
         
     | 
| 
       79 
     | 
    
         
            -
                      output.moveTo(to[0], to[1]);
         
     | 
| 
       80 
     | 
    
         
            -
                      break;
         
     | 
| 
       81 
     | 
    
         
            -
                    }
         
     | 
| 
       82 
     | 
    
         
            -
                    case Path3Command.Line: {
         
     | 
| 
       83 
     | 
    
         
            -
                      const to = mapPoint3d(transform, pickPoint(args));
         
     | 
| 
       84 
     | 
    
         
            -
                      output.lineTo(to[0], to[1]);
         
     | 
| 
       85 
     | 
    
         
            -
                      break;
         
     | 
| 
       86 
     | 
    
         
            -
                    }
         
     | 
| 
       87 
     | 
    
         
            -
                    case Path3Command.Quad: {
         
     | 
| 
       88 
     | 
    
         
            -
                      const control = mapPoint3d(transform, pickPoint(args));
         
     | 
| 
       89 
     | 
    
         
            -
                      const to = mapPoint3d(transform, pickPoint(args, 1));
         
     | 
| 
       90 
     | 
    
         
            -
                      output.quadTo(control[0], control[1], to[0], to[1]);
         
     | 
| 
       91 
     | 
    
         
            -
                      break;
         
     | 
| 
       92 
     | 
    
         
            -
                    }
         
     | 
| 
       93 
     | 
    
         
            -
                    case Path3Command.Cubic: {
         
     | 
| 
       94 
     | 
    
         
            -
                      const control1 = mapPoint3d(transform, pickPoint(args));
         
     | 
| 
       95 
     | 
    
         
            -
                      const control2 = mapPoint3d(transform, pickPoint(args, 1));
         
     | 
| 
       96 
     | 
    
         
            -
                      const to = mapPoint3d(transform, pickPoint(args, 2));
         
     | 
| 
       97 
     | 
    
         
            -
                      output.cubicTo(
         
     | 
| 
       98 
     | 
    
         
            -
                        control1[0],
         
     | 
| 
       99 
     | 
    
         
            -
                        control1[1],
         
     | 
| 
       100 
     | 
    
         
            -
                        control2[0],
         
     | 
| 
       101 
     | 
    
         
            -
                        control2[1],
         
     | 
| 
       102 
     | 
    
         
            -
                        to[0],
         
     | 
| 
       103 
     | 
    
         
            -
                        to[1]
         
     | 
| 
       104 
     | 
    
         
            -
                      );
         
     | 
| 
       105 
     | 
    
         
            -
                      break;
         
     | 
| 
       106 
     | 
    
         
            -
                    }
         
     | 
| 
       107 
     | 
    
         
            -
                    case Path3Command.Close: {
         
     | 
| 
       108 
     | 
    
         
            -
                      output.close();
         
     | 
| 
       109 
     | 
    
         
            -
                      break;
         
     | 
| 
       110 
     | 
    
         
            -
                    }
         
     | 
| 
       111 
     | 
    
         
            -
                    default:
         
     | 
| 
       112 
     | 
    
         
            -
                      throw new Error(`Unknown command: ${cmd}`);
         
     | 
| 
       113 
     | 
    
         
            -
                  }
         
     | 
| 
       114 
     | 
    
         
            -
                });
         
     | 
| 
       115 
     | 
    
         
            -
                return this;
         
     | 
| 
       116 
     | 
    
         
            -
              }
         
     | 
| 
       117 
     | 
    
         
            -
            }
         
     | 
| 
       118 
     | 
    
         
            -
             
     | 
| 
       119 
     | 
    
         
            -
            describe("Camera", () => {
         
     | 
| 
       120 
     | 
    
         
            -
              it("Should do a perspective transformation", async () => {
         
     | 
| 
       121 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       122 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       123 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       124 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       125 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       126 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       127 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       128 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       129 
     | 
    
         
            -
                };
         
     | 
| 
       130 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       131 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       132 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       133 
     | 
    
         
            -
                path3.project(
         
     | 
| 
       134 
     | 
    
         
            -
                  path,
         
     | 
| 
       135 
     | 
    
         
            -
                  processTransform3d([
         
     | 
| 
       136 
     | 
    
         
            -
                    { translate: [width / 2, height / 2] },
         
     | 
| 
       137 
     | 
    
         
            -
                    { perspective: 300 },
         
     | 
| 
       138 
     | 
    
         
            -
                    { rotateX: 1 },
         
     | 
| 
       139 
     | 
    
         
            -
                    { translate: [-width / 2, -height / 2] },
         
     | 
| 
       140 
     | 
    
         
            -
                  ])
         
     | 
| 
       141 
     | 
    
         
            -
                );
         
     | 
| 
       142 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       143 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       144 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       145 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       146 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       147 
     | 
    
         
            -
                );
         
     | 
| 
       148 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/perspective.png");
         
     | 
| 
       149 
     | 
    
         
            -
              });
         
     | 
| 
       150 
     | 
    
         
            -
              it("Camera movement", async () => {
         
     | 
| 
       151 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       152 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       153 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       154 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       155 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       156 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       157 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       158 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       159 
     | 
    
         
            -
                };
         
     | 
| 
       160 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       161 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       162 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       163 
     | 
    
         
            -
                path3.project(path);
         
     | 
| 
       164 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       165 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       166 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       167 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       168 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       169 
     | 
    
         
            -
                );
         
     | 
| 
       170 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/rect.png");
         
     | 
| 
       171 
     | 
    
         
            -
              });
         
     | 
| 
       172 
     | 
    
         
            -
              it("Camera movement (2)", async () => {
         
     | 
| 
       173 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       174 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       175 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       176 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       177 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       178 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       179 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       180 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       181 
     | 
    
         
            -
                };
         
     | 
| 
       182 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       183 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       184 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       185 
     | 
    
         
            -
             
     | 
| 
       186 
     | 
    
         
            -
                // Sensible camera defaults based on surface dimensions
         
     | 
| 
       187 
     | 
    
         
            -
                const camAngle = Math.PI / 4; // 45 degrees for dramatic perspective
         
     | 
| 
       188 
     | 
    
         
            -
             
     | 
| 
       189 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       190 
     | 
    
         
            -
                  eye: [0, 0, 1] as const,
         
     | 
| 
       191 
     | 
    
         
            -
                  coa: [0, 0, 0] as const, // Look at origin (setupCamera handles viewport translation)
         
     | 
| 
       192 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       193 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       194 
     | 
    
         
            -
                  far: 4,
         
     | 
| 
       195 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       196 
     | 
    
         
            -
                };
         
     | 
| 
       197 
     | 
    
         
            -
             
     | 
| 
       198 
     | 
    
         
            -
                // Setup camera with surface-based viewport
         
     | 
| 
       199 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       200 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       201 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       202 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       203 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       204 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       205 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       206 
     | 
    
         
            -
                );
         
     | 
| 
       207 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/full-rect.png");
         
     | 
| 
       208 
     | 
    
         
            -
              });
         
     | 
| 
       209 
     | 
    
         
            -
              it("Camera movement (3)", async () => {
         
     | 
| 
       210 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       211 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       212 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       213 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       214 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       215 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       216 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       217 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       218 
     | 
    
         
            -
                };
         
     | 
| 
       219 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       220 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       221 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       222 
     | 
    
         
            -
             
     | 
| 
       223 
     | 
    
         
            -
                // Sensible camera defaults based on surface dimensions
         
     | 
| 
       224 
     | 
    
         
            -
                const camAngle = Math.PI / 4; // 45 degrees for dramatic perspective
         
     | 
| 
       225 
     | 
    
         
            -
             
     | 
| 
       226 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       227 
     | 
    
         
            -
                  eye: [0, 0, 4] as const,
         
     | 
| 
       228 
     | 
    
         
            -
                  coa: [0, 0, 0] as const, // Look at origin (setupCamera handles viewport translation)
         
     | 
| 
       229 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       230 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       231 
     | 
    
         
            -
                  far: 4,
         
     | 
| 
       232 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       233 
     | 
    
         
            -
                };
         
     | 
| 
       234 
     | 
    
         
            -
             
     | 
| 
       235 
     | 
    
         
            -
                // Setup camera with surface-based viewport
         
     | 
| 
       236 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       237 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       238 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       239 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       240 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       241 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       242 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       243 
     | 
    
         
            -
                );
         
     | 
| 
       244 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/scaled-rect.png");
         
     | 
| 
       245 
     | 
    
         
            -
              });
         
     | 
| 
       246 
     | 
    
         
            -
              it("Camera coordinate system visualization", async () => {
         
     | 
| 
       247 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       248 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       249 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       250 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       251 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       252 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       253 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       254 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       255 
     | 
    
         
            -
                };
         
     | 
| 
       256 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       257 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       258 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       259 
     | 
    
         
            -
             
     | 
| 
       260 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       261 
     | 
    
         
            -
             
     | 
| 
       262 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       263 
     | 
    
         
            -
                  eye: [0.5, 0.5, 1] as const, // Offset right and up in 3D space
         
     | 
| 
       264 
     | 
    
         
            -
                  coa: [0, 0, 0] as const, // Still look at center
         
     | 
| 
       265 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       266 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       267 
     | 
    
         
            -
                  far: 4,
         
     | 
| 
       268 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       269 
     | 
    
         
            -
                };
         
     | 
| 
       270 
     | 
    
         
            -
             
     | 
| 
       271 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       272 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       273 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       274 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       275 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       276 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       277 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       278 
     | 
    
         
            -
                );
         
     | 
| 
       279 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/camera-offset.png");
         
     | 
| 
       280 
     | 
    
         
            -
              });
         
     | 
| 
       281 
     | 
    
         
            -
             
     | 
| 
       282 
     | 
    
         
            -
              it("Camera zoom out - rectangle appears half size", async () => {
         
     | 
| 
       283 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       284 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       285 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       286 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       287 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       288 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       289 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       290 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       291 
     | 
    
         
            -
                };
         
     | 
| 
       292 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       293 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       294 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       295 
     | 
    
         
            -
             
     | 
| 
       296 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       297 
     | 
    
         
            -
             
     | 
| 
       298 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       299 
     | 
    
         
            -
                  eye: [0, 0, 2] as const, // Move camera twice as far away
         
     | 
| 
       300 
     | 
    
         
            -
                  coa: [0, 0, 0] as const, // Look at center
         
     | 
| 
       301 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       302 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       303 
     | 
    
         
            -
                  far: 8, // Increase far plane since camera is further
         
     | 
| 
       304 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       305 
     | 
    
         
            -
                };
         
     | 
| 
       306 
     | 
    
         
            -
             
     | 
| 
       307 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       308 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       309 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       310 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       311 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       312 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       313 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       314 
     | 
    
         
            -
                );
         
     | 
| 
       315 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/camera-zoom-out.png");
         
     | 
| 
       316 
     | 
    
         
            -
              });
         
     | 
| 
       317 
     | 
    
         
            -
             
     | 
| 
       318 
     | 
    
         
            -
              it("Camera positioned at corner - look at corner", async () => {
         
     | 
| 
       319 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       320 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       321 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       322 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       323 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       324 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       325 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       326 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       327 
     | 
    
         
            -
                };
         
     | 
| 
       328 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       329 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       330 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       331 
     | 
    
         
            -
             
     | 
| 
       332 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       333 
     | 
    
         
            -
             
     | 
| 
       334 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       335 
     | 
    
         
            -
                  eye: [-0.5, -0.5, 1] as const, // Position at corner in normalized coords
         
     | 
| 
       336 
     | 
    
         
            -
                  coa: [-0.5, -0.5, 0] as const, // Look at same corner
         
     | 
| 
       337 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       338 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       339 
     | 
    
         
            -
                  far: 4,
         
     | 
| 
       340 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       341 
     | 
    
         
            -
                };
         
     | 
| 
       342 
     | 
    
         
            -
             
     | 
| 
       343 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       344 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       345 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       346 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       347 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       348 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       349 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       350 
     | 
    
         
            -
                );
         
     | 
| 
       351 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/camera-corner.png");
         
     | 
| 
       352 
     | 
    
         
            -
              });
         
     | 
| 
       353 
     | 
    
         
            -
             
     | 
| 
       354 
     | 
    
         
            -
              it("Camera centered - top-left corner at center", async () => {
         
     | 
| 
       355 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       356 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       357 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       358 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       359 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       360 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       361 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       362 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       363 
     | 
    
         
            -
                };
         
     | 
| 
       364 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       365 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       366 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       367 
     | 
    
         
            -
             
     | 
| 
       368 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       369 
     | 
    
         
            -
             
     | 
| 
       370 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       371 
     | 
    
         
            -
                  eye: [-1, -1, 1] as const, // Camera centered
         
     | 
| 
       372 
     | 
    
         
            -
                  coa: [-1, -1, 0] as const, // Look at top-left corner of rectangle
         
     | 
| 
       373 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       374 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       375 
     | 
    
         
            -
                  far: 4,
         
     | 
| 
       376 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       377 
     | 
    
         
            -
                };
         
     | 
| 
       378 
     | 
    
         
            -
             
     | 
| 
       379 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       380 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       381 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       382 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       383 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       384 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       385 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       386 
     | 
    
         
            -
                );
         
     | 
| 
       387 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/camera-top-left-center.png");
         
     | 
| 
       388 
     | 
    
         
            -
              });
         
     | 
| 
       389 
     | 
    
         
            -
              it("test perspective (1)", async () => {
         
     | 
| 
       390 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       391 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       392 
     | 
    
         
            -
                const pad = 0;
         
     | 
| 
       393 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       394 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       395 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       396 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       397 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       398 
     | 
    
         
            -
                };
         
     | 
| 
       399 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       400 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       401 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       402 
     | 
    
         
            -
             
     | 
| 
       403 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       404 
     | 
    
         
            -
             
     | 
| 
       405 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       406 
     | 
    
         
            -
                  eye: [-1.5, 0, 0.25] as const, // Camera centered
         
     | 
| 
       407 
     | 
    
         
            -
                  coa: [-1, 0, 0] as const, // Look at top-left corner of rectangle
         
     | 
| 
       408 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       409 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       410 
     | 
    
         
            -
                  far: 10,
         
     | 
| 
       411 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       412 
     | 
    
         
            -
                };
         
     | 
| 
       413 
     | 
    
         
            -
             
     | 
| 
       414 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       415 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       416 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       417 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       418 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       419 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       420 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       421 
     | 
    
         
            -
                );
         
     | 
| 
       422 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/test-perspective.png");
         
     | 
| 
       423 
     | 
    
         
            -
              });
         
     | 
| 
       424 
     | 
    
         
            -
              it("test perspective (2)", async () => {
         
     | 
| 
       425 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       426 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       427 
     | 
    
         
            -
                let pad = 0;
         
     | 
| 
       428 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       429 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       430 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       431 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       432 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       433 
     | 
    
         
            -
                };
         
     | 
| 
       434 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       435 
     | 
    
         
            -
                const path3 = new Path3();
         
     | 
| 
       436 
     | 
    
         
            -
                path3.addHRect(rct, 0);
         
     | 
| 
       437 
     | 
    
         
            -
             
     | 
| 
       438 
     | 
    
         
            -
                const path3a = new Path3();
         
     | 
| 
       439 
     | 
    
         
            -
                pad = 20;
         
     | 
| 
       440 
     | 
    
         
            -
                path3a.addHRect(
         
     | 
| 
       441 
     | 
    
         
            -
                  {
         
     | 
| 
       442 
     | 
    
         
            -
                    x: pad,
         
     | 
| 
       443 
     | 
    
         
            -
                    y: pad,
         
     | 
| 
       444 
     | 
    
         
            -
                    width: width - pad * 2,
         
     | 
| 
       445 
     | 
    
         
            -
                    height: height - pad * 2,
         
     | 
| 
       446 
     | 
    
         
            -
                  },
         
     | 
| 
       447 
     | 
    
         
            -
                  0.5
         
     | 
| 
       448 
     | 
    
         
            -
                );
         
     | 
| 
       449 
     | 
    
         
            -
             
     | 
| 
       450 
     | 
    
         
            -
                const camAngle = Math.PI / 4;
         
     | 
| 
       451 
     | 
    
         
            -
             
     | 
| 
       452 
     | 
    
         
            -
                const cam = {
         
     | 
| 
       453 
     | 
    
         
            -
                  eye: [-1.5, 0, 0.5] as const, // Camera centered
         
     | 
| 
       454 
     | 
    
         
            -
                  coa: [-1, 0, 0] as const, // Look at top-left corner of rectangle
         
     | 
| 
       455 
     | 
    
         
            -
                  up: [0, 1, 0] as const,
         
     | 
| 
       456 
     | 
    
         
            -
                  near: 0.02,
         
     | 
| 
       457 
     | 
    
         
            -
                  far: 10,
         
     | 
| 
       458 
     | 
    
         
            -
                  angle: camAngle,
         
     | 
| 
       459 
     | 
    
         
            -
                };
         
     | 
| 
       460 
     | 
    
         
            -
             
     | 
| 
       461 
     | 
    
         
            -
                const area: Vec4 = [0, 0, width, height];
         
     | 
| 
       462 
     | 
    
         
            -
                const mat = setupCamera(area, Math.min(width, height) / 2, cam);
         
     | 
| 
       463 
     | 
    
         
            -
                path3.project(path, mat);
         
     | 
| 
       464 
     | 
    
         
            -
                const path1 = Skia.Path.Make();
         
     | 
| 
       465 
     | 
    
         
            -
             
     | 
| 
       466 
     | 
    
         
            -
                path3a.project(path1, mat);
         
     | 
| 
       467 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       468 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       469 
     | 
    
         
            -
                    <Path path={path} color="cyan" opacity={0.5} />
         
     | 
| 
       470 
     | 
    
         
            -
                    <Path path={path1} color="red" opacity={0.5} />
         
     | 
| 
       471 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       472 
     | 
    
         
            -
                );
         
     | 
| 
       473 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/test-perspective2.png");
         
     | 
| 
       474 
     | 
    
         
            -
              });
         
     | 
| 
       475 
     | 
    
         
            -
            });
         
     |