@shopify/react-native-skia 2.3.0 → 2.3.5
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 +341 -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,85 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { docPath, checkImage } from "../../../__tests__/setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import { Group, Mask, Circle, Rect, Image, Paint } from "../../components";
         
     | 
| 
       5 
     | 
    
         
            -
            import { importSkia, surface, images } from "../setup";
         
     | 
| 
       6 
     | 
    
         
            -
             
     | 
| 
       7 
     | 
    
         
            -
            describe("Mask Documentation Examples", () => {
         
     | 
| 
       8 
     | 
    
         
            -
              it("should draw an alpha mask", async () => {
         
     | 
| 
       9 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       10 
     | 
    
         
            -
                const r = width / 2;
         
     | 
| 
       11 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       12 
     | 
    
         
            -
                  <>
         
     | 
| 
       13 
     | 
    
         
            -
                    <Mask
         
     | 
| 
       14 
     | 
    
         
            -
                      mask={
         
     | 
| 
       15 
     | 
    
         
            -
                        <Group>
         
     | 
| 
       16 
     | 
    
         
            -
                          <Circle cx={r} cy={r} r={r} opacity={0.5} />
         
     | 
| 
       17 
     | 
    
         
            -
                          <Circle cx={r} cy={r} r={r / 2} />
         
     | 
| 
       18 
     | 
    
         
            -
                        </Group>
         
     | 
| 
       19 
     | 
    
         
            -
                      }
         
     | 
| 
       20 
     | 
    
         
            -
                    >
         
     | 
| 
       21 
     | 
    
         
            -
                      <Rect x={0} y={0} width={r * 2} height={r * 2} color="lightblue" />
         
     | 
| 
       22 
     | 
    
         
            -
                    </Mask>
         
     | 
| 
       23 
     | 
    
         
            -
                  </>
         
     | 
| 
       24 
     | 
    
         
            -
                );
         
     | 
| 
       25 
     | 
    
         
            -
                checkImage(image, docPath("mask/alpha-mask.png"));
         
     | 
| 
       26 
     | 
    
         
            -
              });
         
     | 
| 
       27 
     | 
    
         
            -
              it("should draw an luminance mask", async () => {
         
     | 
| 
       28 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       29 
     | 
    
         
            -
                const r = width / 2;
         
     | 
| 
       30 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       31 
     | 
    
         
            -
                  <>
         
     | 
| 
       32 
     | 
    
         
            -
                    <Mask
         
     | 
| 
       33 
     | 
    
         
            -
                      mode="luminance"
         
     | 
| 
       34 
     | 
    
         
            -
                      mask={
         
     | 
| 
       35 
     | 
    
         
            -
                        <Group>
         
     | 
| 
       36 
     | 
    
         
            -
                          <Circle cx={r} cy={r} r={r} color="white" />
         
     | 
| 
       37 
     | 
    
         
            -
                          <Circle cx={r} cy={r} r={r / 2} color="black" />
         
     | 
| 
       38 
     | 
    
         
            -
                        </Group>
         
     | 
| 
       39 
     | 
    
         
            -
                      }
         
     | 
| 
       40 
     | 
    
         
            -
                    >
         
     | 
| 
       41 
     | 
    
         
            -
                      <Rect x={0} y={0} width={r * 2} height={r * 2} color="lightblue" />
         
     | 
| 
       42 
     | 
    
         
            -
                    </Mask>
         
     | 
| 
       43 
     | 
    
         
            -
                  </>
         
     | 
| 
       44 
     | 
    
         
            -
                );
         
     | 
| 
       45 
     | 
    
         
            -
                checkImage(image, docPath("mask/luminance-mask.png"));
         
     | 
| 
       46 
     | 
    
         
            -
              });
         
     | 
| 
       47 
     | 
    
         
            -
              it("should blend a mask", async () => {
         
     | 
| 
       48 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       49 
     | 
    
         
            -
                const { rect } = importSkia();
         
     | 
| 
       50 
     | 
    
         
            -
                const rct = rect(0, 0, width, height);
         
     | 
| 
       51 
     | 
    
         
            -
                const { mask } = images;
         
     | 
| 
       52 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       53 
     | 
    
         
            -
                  <>
         
     | 
| 
       54 
     | 
    
         
            -
                    <Rect rect={rct} color={"cyan"} />
         
     | 
| 
       55 
     | 
    
         
            -
                    <Group layer={<Paint blendMode="multiply" />}>
         
     | 
| 
       56 
     | 
    
         
            -
                      <Mask
         
     | 
| 
       57 
     | 
    
         
            -
                        mode="luminance"
         
     | 
| 
       58 
     | 
    
         
            -
                        mask={
         
     | 
| 
       59 
     | 
    
         
            -
                          <Group>
         
     | 
| 
       60 
     | 
    
         
            -
                            <Rect x={0} y={0} width={120} height={256} color={"white"} />
         
     | 
| 
       61 
     | 
    
         
            -
                            <Rect
         
     | 
| 
       62 
     | 
    
         
            -
                              x={120}
         
     | 
| 
       63 
     | 
    
         
            -
                              y={0}
         
     | 
| 
       64 
     | 
    
         
            -
                              width={256 - 120}
         
     | 
| 
       65 
     | 
    
         
            -
                              height={256}
         
     | 
| 
       66 
     | 
    
         
            -
                              color={"black"}
         
     | 
| 
       67 
     | 
    
         
            -
                            />
         
     | 
| 
       68 
     | 
    
         
            -
                          </Group>
         
     | 
| 
       69 
     | 
    
         
            -
                        }
         
     | 
| 
       70 
     | 
    
         
            -
                      >
         
     | 
| 
       71 
     | 
    
         
            -
                        <Image
         
     | 
| 
       72 
     | 
    
         
            -
                          image={mask}
         
     | 
| 
       73 
     | 
    
         
            -
                          fit="cover"
         
     | 
| 
       74 
     | 
    
         
            -
                          x={0}
         
     | 
| 
       75 
     | 
    
         
            -
                          y={0}
         
     | 
| 
       76 
     | 
    
         
            -
                          width={256}
         
     | 
| 
       77 
     | 
    
         
            -
                          height={256}
         
     | 
| 
       78 
     | 
    
         
            -
                        />
         
     | 
| 
       79 
     | 
    
         
            -
                      </Mask>
         
     | 
| 
       80 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       81 
     | 
    
         
            -
                  </>
         
     | 
| 
       82 
     | 
    
         
            -
                );
         
     | 
| 
       83 
     | 
    
         
            -
                checkImage(image, docPath("mask/blend-mode-mask.png"));
         
     | 
| 
       84 
     | 
    
         
            -
              });
         
     | 
| 
       85 
     | 
    
         
            -
            });
         
     | 
| 
         @@ -1,367 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { checkImage } from "../../../__tests__/setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import { Group, Rect } from "../../components";
         
     | 
| 
       5 
     | 
    
         
            -
            import { surface } from "../setup";
         
     | 
| 
       6 
     | 
    
         
            -
            import {
         
     | 
| 
       7 
     | 
    
         
            -
              multiply4,
         
     | 
| 
       8 
     | 
    
         
            -
              perspective,
         
     | 
| 
       9 
     | 
    
         
            -
              processTransform3d,
         
     | 
| 
       10 
     | 
    
         
            -
              rotateX,
         
     | 
| 
       11 
     | 
    
         
            -
              translate,
         
     | 
| 
       12 
     | 
    
         
            -
              toMatrix3,
         
     | 
| 
       13 
     | 
    
         
            -
              Matrix4,
         
     | 
| 
       14 
     | 
    
         
            -
              mapPoint3d,
         
     | 
| 
       15 
     | 
    
         
            -
              invert4,
         
     | 
| 
       16 
     | 
    
         
            -
              scale,
         
     | 
| 
       17 
     | 
    
         
            -
              rotateZ,
         
     | 
| 
       18 
     | 
    
         
            -
            } from "../../../skia/types";
         
     | 
| 
       19 
     | 
    
         
            -
             
     | 
| 
       20 
     | 
    
         
            -
            const ckPerspective = (d: number) => [
         
     | 
| 
       21 
     | 
    
         
            -
              1,
         
     | 
| 
       22 
     | 
    
         
            -
              0,
         
     | 
| 
       23 
     | 
    
         
            -
              0,
         
     | 
| 
       24 
     | 
    
         
            -
              0,
         
     | 
| 
       25 
     | 
    
         
            -
              0,
         
     | 
| 
       26 
     | 
    
         
            -
              1,
         
     | 
| 
       27 
     | 
    
         
            -
              0,
         
     | 
| 
       28 
     | 
    
         
            -
              0,
         
     | 
| 
       29 
     | 
    
         
            -
              0,
         
     | 
| 
       30 
     | 
    
         
            -
              0,
         
     | 
| 
       31 
     | 
    
         
            -
              1,
         
     | 
| 
       32 
     | 
    
         
            -
              0,
         
     | 
| 
       33 
     | 
    
         
            -
              0,
         
     | 
| 
       34 
     | 
    
         
            -
              0,
         
     | 
| 
       35 
     | 
    
         
            -
              -1 / d,
         
     | 
| 
       36 
     | 
    
         
            -
              1,
         
     | 
| 
       37 
     | 
    
         
            -
            ];
         
     | 
| 
       38 
     | 
    
         
            -
             
     | 
| 
       39 
     | 
    
         
            -
            const concat = (a: number[], b: number[]) => CanvasKit.M44.multiply(a, b);
         
     | 
| 
       40 
     | 
    
         
            -
             
     | 
| 
       41 
     | 
    
         
            -
            describe("Matrix4", () => {
         
     | 
| 
       42 
     | 
    
         
            -
              it("should be a row major matix", () => {
         
     | 
| 
       43 
     | 
    
         
            -
                const m4 = CanvasKit.M44.identity();
         
     | 
| 
       44 
     | 
    
         
            -
                expect(processTransform3d([])).toEqual(m4);
         
     | 
| 
       45 
     | 
    
         
            -
              });
         
     | 
| 
       46 
     | 
    
         
            -
              it("should match identity matrix", () => {
         
     | 
| 
       47 
     | 
    
         
            -
                const m4 = CanvasKit.M44.identity();
         
     | 
| 
       48 
     | 
    
         
            -
                expect(
         
     | 
| 
       49 
     | 
    
         
            -
                  processTransform3d([
         
     | 
| 
       50 
     | 
    
         
            -
                    { translateX: 256 / 2 },
         
     | 
| 
       51 
     | 
    
         
            -
                    { translateY: 256 / 2 },
         
     | 
| 
       52 
     | 
    
         
            -
                    { translateX: -256 / 2 },
         
     | 
| 
       53 
     | 
    
         
            -
                    { translateY: -256 / 2 },
         
     | 
| 
       54 
     | 
    
         
            -
                  ])
         
     | 
| 
       55 
     | 
    
         
            -
                ).toEqual(m4);
         
     | 
| 
       56 
     | 
    
         
            -
              });
         
     | 
| 
       57 
     | 
    
         
            -
              it("Identity should match identity matrix", () => {
         
     | 
| 
       58 
     | 
    
         
            -
                const m4 = CanvasKit.M44.identity();
         
     | 
| 
       59 
     | 
    
         
            -
                expect(
         
     | 
| 
       60 
     | 
    
         
            -
                  processTransform3d([
         
     | 
| 
       61 
     | 
    
         
            -
                    { translateX: 256 / 2 },
         
     | 
| 
       62 
     | 
    
         
            -
                    { translateY: 256 / 2 },
         
     | 
| 
       63 
     | 
    
         
            -
                    { translateX: -256 / 2 },
         
     | 
| 
       64 
     | 
    
         
            -
                    { translateY: -256 / 2 },
         
     | 
| 
       65 
     | 
    
         
            -
                  ])
         
     | 
| 
       66 
     | 
    
         
            -
                ).toEqual(m4);
         
     | 
| 
       67 
     | 
    
         
            -
              });
         
     | 
| 
       68 
     | 
    
         
            -
              it("should match perspective matrix", () => {
         
     | 
| 
       69 
     | 
    
         
            -
                let m4 = CanvasKit.M44.identity();
         
     | 
| 
       70 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.translated([256 / 2, 256 / 2, 0]));
         
     | 
| 
       71 
     | 
    
         
            -
                m4 = concat(m4, ckPerspective(300));
         
     | 
| 
       72 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.translated([-256 / 2, -256 / 2, 0]));
         
     | 
| 
       73 
     | 
    
         
            -
                expect(
         
     | 
| 
       74 
     | 
    
         
            -
                  processTransform3d([
         
     | 
| 
       75 
     | 
    
         
            -
                    { translateX: 256 / 2 },
         
     | 
| 
       76 
     | 
    
         
            -
                    { translateY: 256 / 2 },
         
     | 
| 
       77 
     | 
    
         
            -
                    { perspective: 300 },
         
     | 
| 
       78 
     | 
    
         
            -
                    { translateX: -256 / 2 },
         
     | 
| 
       79 
     | 
    
         
            -
                    { translateY: -256 / 2 },
         
     | 
| 
       80 
     | 
    
         
            -
                  ])
         
     | 
| 
       81 
     | 
    
         
            -
                ).toEqual(m4);
         
     | 
| 
       82 
     | 
    
         
            -
              });
         
     | 
| 
       83 
     | 
    
         
            -
              it("should match rotation matrix (1)", () => {
         
     | 
| 
       84 
     | 
    
         
            -
                let m4 = CanvasKit.M44.identity();
         
     | 
| 
       85 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.rotated([1, 0, 0], 1));
         
     | 
| 
       86 
     | 
    
         
            -
                expect(processTransform3d([{ rotateX: 1 }])).toEqual(m4);
         
     | 
| 
       87 
     | 
    
         
            -
                m4 = CanvasKit.M44.identity();
         
     | 
| 
       88 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.rotated([0, 1, 0], Math.PI));
         
     | 
| 
       89 
     | 
    
         
            -
                expect(processTransform3d([{ rotateY: Math.PI }])).toEqual(m4);
         
     | 
| 
       90 
     | 
    
         
            -
              });
         
     | 
| 
       91 
     | 
    
         
            -
              it("should match rotation matrix (2)", () => {
         
     | 
| 
       92 
     | 
    
         
            -
                let m4 = CanvasKit.M44.identity();
         
     | 
| 
       93 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.translated([256 / 2, 256 / 2, 0]));
         
     | 
| 
       94 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.rotated([1, 0, 0], 1));
         
     | 
| 
       95 
     | 
    
         
            -
                m4 = concat(m4, CanvasKit.M44.translated([-256 / 2, -256 / 2, 0]));
         
     | 
| 
       96 
     | 
    
         
            -
                expect(
         
     | 
| 
       97 
     | 
    
         
            -
                  processTransform3d([
         
     | 
| 
       98 
     | 
    
         
            -
                    { translateX: 256 / 2 },
         
     | 
| 
       99 
     | 
    
         
            -
                    { translateY: 256 / 2 },
         
     | 
| 
       100 
     | 
    
         
            -
                    { rotateX: 1 },
         
     | 
| 
       101 
     | 
    
         
            -
                    { translateX: -256 / 2 },
         
     | 
| 
       102 
     | 
    
         
            -
                    { translateY: -256 / 2 },
         
     | 
| 
       103 
     | 
    
         
            -
                  ])
         
     | 
| 
       104 
     | 
    
         
            -
                ).toEqual(m4);
         
     | 
| 
       105 
     | 
    
         
            -
              });
         
     | 
| 
       106 
     | 
    
         
            -
              it("Should do a perspective transformation (1)", async () => {
         
     | 
| 
       107 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       108 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       109 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       110 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       111 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       112 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       113 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       114 
     | 
    
         
            -
                };
         
     | 
| 
       115 
     | 
    
         
            -
                const m3 = processTransform3d([
         
     | 
| 
       116 
     | 
    
         
            -
                  { translate: [width / 2, height / 2] },
         
     | 
| 
       117 
     | 
    
         
            -
                  { perspective: 300 },
         
     | 
| 
       118 
     | 
    
         
            -
                  { rotateX: 1 },
         
     | 
| 
       119 
     | 
    
         
            -
                  { translate: [-width / 2, -height / 2] },
         
     | 
| 
       120 
     | 
    
         
            -
                ]);
         
     | 
| 
       121 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       122 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       123 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       124 
     | 
    
         
            -
                    <Rect rect={rct} color="cyan" opacity={0.5} matrix={m3} />
         
     | 
| 
       125 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       126 
     | 
    
         
            -
                );
         
     | 
| 
       127 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/perspective.png");
         
     | 
| 
       128 
     | 
    
         
            -
              });
         
     | 
| 
       129 
     | 
    
         
            -
              it("Should do a perspective transformation (2)", async () => {
         
     | 
| 
       130 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       131 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       132 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       133 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       134 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       135 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       136 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       137 
     | 
    
         
            -
                };
         
     | 
| 
       138 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       139 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       140 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       141 
     | 
    
         
            -
                    <Rect
         
     | 
| 
       142 
     | 
    
         
            -
                      rect={rct}
         
     | 
| 
       143 
     | 
    
         
            -
                      color="cyan"
         
     | 
| 
       144 
     | 
    
         
            -
                      opacity={0.5}
         
     | 
| 
       145 
     | 
    
         
            -
                      transform={[
         
     | 
| 
       146 
     | 
    
         
            -
                        { translate: [width / 2, height / 2] },
         
     | 
| 
       147 
     | 
    
         
            -
                        { perspective: 300 },
         
     | 
| 
       148 
     | 
    
         
            -
                        { rotateX: 1 },
         
     | 
| 
       149 
     | 
    
         
            -
                        { translate: [-width / 2, -height / 2] },
         
     | 
| 
       150 
     | 
    
         
            -
                      ]}
         
     | 
| 
       151 
     | 
    
         
            -
                    />
         
     | 
| 
       152 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       153 
     | 
    
         
            -
                );
         
     | 
| 
       154 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/perspective.png");
         
     | 
| 
       155 
     | 
    
         
            -
              });
         
     | 
| 
       156 
     | 
    
         
            -
              it("Should do a perspective transformation (4)", async () => {
         
     | 
| 
       157 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       158 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       159 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       160 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       161 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       162 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       163 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       164 
     | 
    
         
            -
                };
         
     | 
| 
       165 
     | 
    
         
            -
                let matrix = translate(width / 2, height / 2);
         
     | 
| 
       166 
     | 
    
         
            -
                matrix = multiply4(matrix, perspective(300));
         
     | 
| 
       167 
     | 
    
         
            -
                matrix = multiply4(matrix, rotateX(1));
         
     | 
| 
       168 
     | 
    
         
            -
                matrix = multiply4(matrix, translate(-width / 2, -height / 2));
         
     | 
| 
       169 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       170 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       171 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       172 
     | 
    
         
            -
                    <Rect rect={rct} color="cyan" opacity={0.5} matrix={matrix} />
         
     | 
| 
       173 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       174 
     | 
    
         
            -
                );
         
     | 
| 
       175 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/perspective.png");
         
     | 
| 
       176 
     | 
    
         
            -
              });
         
     | 
| 
       177 
     | 
    
         
            -
              it("Should do a perspective transformation (5)", async () => {
         
     | 
| 
       178 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       179 
     | 
    
         
            -
                const pad = 32;
         
     | 
| 
       180 
     | 
    
         
            -
                const rct = {
         
     | 
| 
       181 
     | 
    
         
            -
                  x: pad,
         
     | 
| 
       182 
     | 
    
         
            -
                  y: pad,
         
     | 
| 
       183 
     | 
    
         
            -
                  width: width - pad * 2,
         
     | 
| 
       184 
     | 
    
         
            -
                  height: height - pad * 2,
         
     | 
| 
       185 
     | 
    
         
            -
                };
         
     | 
| 
       186 
     | 
    
         
            -
                let matrix = translate(width / 2, height / 2);
         
     | 
| 
       187 
     | 
    
         
            -
                matrix = multiply4(matrix, perspective(300));
         
     | 
| 
       188 
     | 
    
         
            -
                matrix = multiply4(matrix, rotateX(1));
         
     | 
| 
       189 
     | 
    
         
            -
                matrix = multiply4(matrix, translate(-width / 2, -height / 2));
         
     | 
| 
       190 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       191 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       192 
     | 
    
         
            -
                    <Rect rect={rct} color="magenta" />
         
     | 
| 
       193 
     | 
    
         
            -
                    <Rect rect={rct} color="cyan" opacity={0.5} matrix={matrix} />
         
     | 
| 
       194 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       195 
     | 
    
         
            -
                );
         
     | 
| 
       196 
     | 
    
         
            -
                checkImage(image, "snapshots/matrix4/perspective.png");
         
     | 
| 
       197 
     | 
    
         
            -
              });
         
     | 
| 
       198 
     | 
    
         
            -
              it("concat() should accept 4x4 matrices (1)", async () => {
         
     | 
| 
       199 
     | 
    
         
            -
                const result = await surface.eval((Skia) => {
         
     | 
| 
       200 
     | 
    
         
            -
                  const m3 = Skia.Matrix();
         
     | 
| 
       201 
     | 
    
         
            -
                  return m3.get();
         
     | 
| 
       202 
     | 
    
         
            -
                });
         
     | 
| 
       203 
     | 
    
         
            -
                expect(result).toEqual([1, 0, 0, 0, 1, 0, 0, 0, 1]);
         
     | 
| 
       204 
     | 
    
         
            -
              });
         
     | 
| 
       205 
     | 
    
         
            -
              it("concat() should accept 4x4 matrices (2)", async () => {
         
     | 
| 
       206 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       207 
     | 
    
         
            -
                let matrix = translate(width / 2, height / 2);
         
     | 
| 
       208 
     | 
    
         
            -
                matrix = multiply4(matrix, perspective(300));
         
     | 
| 
       209 
     | 
    
         
            -
                matrix = multiply4(matrix, rotateX(1));
         
     | 
| 
       210 
     | 
    
         
            -
                matrix = multiply4(matrix, translate(-width / 2, -height / 2));
         
     | 
| 
       211 
     | 
    
         
            -
             
     | 
| 
       212 
     | 
    
         
            -
                const result = await surface.eval(
         
     | 
| 
       213 
     | 
    
         
            -
                  (Skia, ctx) => {
         
     | 
| 
       214 
     | 
    
         
            -
                    const m3 = Skia.Matrix();
         
     | 
| 
       215 
     | 
    
         
            -
                    m3.concat(ctx.matrix);
         
     | 
| 
       216 
     | 
    
         
            -
                    return m3.get();
         
     | 
| 
       217 
     | 
    
         
            -
                  },
         
     | 
| 
       218 
     | 
    
         
            -
                  { matrix }
         
     | 
| 
       219 
     | 
    
         
            -
                );
         
     | 
| 
       220 
     | 
    
         
            -
                expect(result).toBeApproximatelyEqual(
         
     | 
| 
       221 
     | 
    
         
            -
                  toMatrix3(
         
     | 
| 
       222 
     | 
    
         
            -
                    processTransform3d([
         
     | 
| 
       223 
     | 
    
         
            -
                      { translate: [width / 2, height / 2] },
         
     | 
| 
       224 
     | 
    
         
            -
                      { perspective: 300 },
         
     | 
| 
       225 
     | 
    
         
            -
                      { rotateX: 1 },
         
     | 
| 
       226 
     | 
    
         
            -
                      { translate: [-width / 2, -height / 2] },
         
     | 
| 
       227 
     | 
    
         
            -
                    ])
         
     | 
| 
       228 
     | 
    
         
            -
                  ),
         
     | 
| 
       229 
     | 
    
         
            -
                  0.1
         
     | 
| 
       230 
     | 
    
         
            -
                );
         
     | 
| 
       231 
     | 
    
         
            -
              });
         
     | 
| 
       232 
     | 
    
         
            -
             
     | 
| 
       233 
     | 
    
         
            -
              it("Path.transform() should accept 4x4 (1)", async () => {
         
     | 
| 
       234 
     | 
    
         
            -
                let result = await surface.eval((Skia) => {
         
     | 
| 
       235 
     | 
    
         
            -
                  const path = Skia.Path.MakeFromSVGString("M150 0L75 200L225 200L150 0Z")!;
         
     | 
| 
       236 
     | 
    
         
            -
                  path.transform([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]);
         
     | 
| 
       237 
     | 
    
         
            -
                  return path.toSVGString();
         
     | 
| 
       238 
     | 
    
         
            -
                });
         
     | 
| 
       239 
     | 
    
         
            -
                expect(result).toEqual("M150 0L75 200L225 200L150 0Z");
         
     | 
| 
       240 
     | 
    
         
            -
             
     | 
| 
       241 
     | 
    
         
            -
                result = await surface.eval((Skia) => {
         
     | 
| 
       242 
     | 
    
         
            -
                  const path = Skia.Path.MakeFromSVGString("M150 0L75 200L225 200L150 0Z")!;
         
     | 
| 
       243 
     | 
    
         
            -
                  path.transform([1, 0, 0, 0, 0, 1, 0, 0, 0]);
         
     | 
| 
       244 
     | 
    
         
            -
                  return path.toSVGString();
         
     | 
| 
       245 
     | 
    
         
            -
                });
         
     | 
| 
       246 
     | 
    
         
            -
                expect(result).not.toEqual("M150 0L75 200L225 200L150 0Z");
         
     | 
| 
       247 
     | 
    
         
            -
              });
         
     | 
| 
       248 
     | 
    
         
            -
              it("Path.transform() should accept 4x4 (2)", async () => {
         
     | 
| 
       249 
     | 
    
         
            -
                let result = await surface.eval((Skia) => {
         
     | 
| 
       250 
     | 
    
         
            -
                  const path = Skia.Path.MakeFromSVGString("M150 0L75 200L225 200L150 0Z")!;
         
     | 
| 
       251 
     | 
    
         
            -
                  const m = [1, 0, 0, 100, 0, 1, 0, 100, 0, 0, 1, 0, 0, 0, 0, 1];
         
     | 
| 
       252 
     | 
    
         
            -
                  path.transform([m[0], m[1], m[3], m[4], m[5], m[7], m[12], m[13], m[15]]);
         
     | 
| 
       253 
     | 
    
         
            -
                  return path.toSVGString();
         
     | 
| 
       254 
     | 
    
         
            -
                });
         
     | 
| 
       255 
     | 
    
         
            -
                expect(result).toEqual("M250 100L175 300L325 300L250 100Z");
         
     | 
| 
       256 
     | 
    
         
            -
             
     | 
| 
       257 
     | 
    
         
            -
                result = await surface.eval((Skia) => {
         
     | 
| 
       258 
     | 
    
         
            -
                  const path = Skia.Path.MakeFromSVGString("M150 0L75 200L225 200L150 0Z")!;
         
     | 
| 
       259 
     | 
    
         
            -
                  path.transform([1, 0, 0, 100, 0, 1, 0, 100, 0, 0, 1, 0, 0, 0, 0, 1]);
         
     | 
| 
       260 
     | 
    
         
            -
                  return path.toSVGString();
         
     | 
| 
       261 
     | 
    
         
            -
                });
         
     | 
| 
       262 
     | 
    
         
            -
                expect(result).toEqual("M250 100L175 300L325 300L250 100Z");
         
     | 
| 
       263 
     | 
    
         
            -
              });
         
     | 
| 
       264 
     | 
    
         
            -
              it("should correctly transform a point with an identity matrix", () => {
         
     | 
| 
       265 
     | 
    
         
            -
                const identityMatrix = Matrix4();
         
     | 
| 
       266 
     | 
    
         
            -
                const point = [100, -100, 200] as const; // Define some test point
         
     | 
| 
       267 
     | 
    
         
            -
                const result = mapPoint3d(identityMatrix, point);
         
     | 
| 
       268 
     | 
    
         
            -
                expect(result).toEqual(point);
         
     | 
| 
       269 
     | 
    
         
            -
              });
         
     | 
| 
       270 
     | 
    
         
            -
              it("should correctly transform a point with a translation matrix", () => {
         
     | 
| 
       271 
     | 
    
         
            -
                const translationMatrix = translate(100, 100, 100);
         
     | 
| 
       272 
     | 
    
         
            -
                const point = [100, -100, 200] as const; // Define some test point
         
     | 
| 
       273 
     | 
    
         
            -
                const expectedResult = [200, 0, 300] as const;
         
     | 
| 
       274 
     | 
    
         
            -
                const result = mapPoint3d(translationMatrix, point);
         
     | 
| 
       275 
     | 
    
         
            -
                expect(result).toEqual(expectedResult);
         
     | 
| 
       276 
     | 
    
         
            -
              });
         
     | 
| 
       277 
     | 
    
         
            -
             
     | 
| 
       278 
     | 
    
         
            -
              const almostEqual = (
         
     | 
| 
       279 
     | 
    
         
            -
                a: number[] | Matrix4 | readonly [number, number, number],
         
     | 
| 
       280 
     | 
    
         
            -
                b: number[] | Matrix4 | readonly [number, number, number],
         
     | 
| 
       281 
     | 
    
         
            -
                epsilon = 1e-10
         
     | 
| 
       282 
     | 
    
         
            -
              ) => {
         
     | 
| 
       283 
     | 
    
         
            -
                expect(a.length).toBe(b.length);
         
     | 
| 
       284 
     | 
    
         
            -
                a.forEach((val, idx) => {
         
     | 
| 
       285 
     | 
    
         
            -
                  expect(Math.abs(val - b[idx])).toBeLessThan(epsilon);
         
     | 
| 
       286 
     | 
    
         
            -
                });
         
     | 
| 
       287 
     | 
    
         
            -
              };
         
     | 
| 
       288 
     | 
    
         
            -
             
     | 
| 
       289 
     | 
    
         
            -
              const matrixEqual = (a: number[] | Matrix4, b: number[] | Matrix4) => {
         
     | 
| 
       290 
     | 
    
         
            -
                expect(a.length).toBe(b.length);
         
     | 
| 
       291 
     | 
    
         
            -
                a.forEach((val, idx) => {
         
     | 
| 
       292 
     | 
    
         
            -
                  // Object.is will distinguish -0 from 0, so we use === instead
         
     | 
| 
       293 
     | 
    
         
            -
                  const equal = val === b[idx] || (val === 0 && b[idx] === 0);
         
     | 
| 
       294 
     | 
    
         
            -
                  expect(equal).toBe(true);
         
     | 
| 
       295 
     | 
    
         
            -
                });
         
     | 
| 
       296 
     | 
    
         
            -
              };
         
     | 
| 
       297 
     | 
    
         
            -
             
     | 
| 
       298 
     | 
    
         
            -
              it("should return the identity matrix when inverting the identity matrix", () => {
         
     | 
| 
       299 
     | 
    
         
            -
                const identityMatrix = Matrix4();
         
     | 
| 
       300 
     | 
    
         
            -
                const result = invert4(identityMatrix);
         
     | 
| 
       301 
     | 
    
         
            -
                matrixEqual(result, identityMatrix);
         
     | 
| 
       302 
     | 
    
         
            -
              });
         
     | 
| 
       303 
     | 
    
         
            -
             
     | 
| 
       304 
     | 
    
         
            -
              it("should correctly invert a translation matrix", () => {
         
     | 
| 
       305 
     | 
    
         
            -
                const translationMatrix = translate(100, -50, 25);
         
     | 
| 
       306 
     | 
    
         
            -
                const inverse = invert4(translationMatrix);
         
     | 
| 
       307 
     | 
    
         
            -
                // Inverse of translation(x,y,z) should be translation(-x,-y,-z)
         
     | 
| 
       308 
     | 
    
         
            -
                const expectedInverse = translate(-100, 50, -25);
         
     | 
| 
       309 
     | 
    
         
            -
                matrixEqual(inverse, expectedInverse);
         
     | 
| 
       310 
     | 
    
         
            -
              });
         
     | 
| 
       311 
     | 
    
         
            -
             
     | 
| 
       312 
     | 
    
         
            -
              it("should correctly invert a scale matrix", () => {
         
     | 
| 
       313 
     | 
    
         
            -
                const scaleMatrix = scale(2, 4, 8);
         
     | 
| 
       314 
     | 
    
         
            -
                const inverse = invert4(scaleMatrix);
         
     | 
| 
       315 
     | 
    
         
            -
                // Inverse of scale(x,y,z) should be scale(1/x,1/y,1/z)
         
     | 
| 
       316 
     | 
    
         
            -
                const expectedInverse = scale(1 / 2, 1 / 4, 1 / 8);
         
     | 
| 
       317 
     | 
    
         
            -
                matrixEqual(inverse, expectedInverse);
         
     | 
| 
       318 
     | 
    
         
            -
              });
         
     | 
| 
       319 
     | 
    
         
            -
             
     | 
| 
       320 
     | 
    
         
            -
              it("should return identity matrix for non-invertible matrix", () => {
         
     | 
| 
       321 
     | 
    
         
            -
                // A matrix of all zeros is not invertible
         
     | 
| 
       322 
     | 
    
         
            -
                const nonInvertibleMatrix = [
         
     | 
| 
       323 
     | 
    
         
            -
                  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
         
     | 
| 
       324 
     | 
    
         
            -
                ] as Matrix4;
         
     | 
| 
       325 
     | 
    
         
            -
                const result = invert4(nonInvertibleMatrix);
         
     | 
| 
       326 
     | 
    
         
            -
                matrixEqual(result, Matrix4());
         
     | 
| 
       327 
     | 
    
         
            -
              });
         
     | 
| 
       328 
     | 
    
         
            -
             
     | 
| 
       329 
     | 
    
         
            -
              it("multiplying a matrix by its inverse should give the identity matrix", () => {
         
     | 
| 
       330 
     | 
    
         
            -
                // Create a complex transformation matrix
         
     | 
| 
       331 
     | 
    
         
            -
                const complexMatrix = processTransform3d([
         
     | 
| 
       332 
     | 
    
         
            -
                  { scale: 2 },
         
     | 
| 
       333 
     | 
    
         
            -
                  { rotateZ: Math.PI / 4 },
         
     | 
| 
       334 
     | 
    
         
            -
                  { translate: [100, 100, 50] as const },
         
     | 
| 
       335 
     | 
    
         
            -
                ]);
         
     | 
| 
       336 
     | 
    
         
            -
             
     | 
| 
       337 
     | 
    
         
            -
                const inverse = invert4(complexMatrix);
         
     | 
| 
       338 
     | 
    
         
            -
                const result = multiply4(complexMatrix, inverse);
         
     | 
| 
       339 
     | 
    
         
            -
             
     | 
| 
       340 
     | 
    
         
            -
                // Due to floating point arithmetic, we use almostEqual instead of exact equality
         
     | 
| 
       341 
     | 
    
         
            -
                almostEqual(result, Matrix4());
         
     | 
| 
       342 
     | 
    
         
            -
              });
         
     | 
| 
       343 
     | 
    
         
            -
             
     | 
| 
       344 
     | 
    
         
            -
              it("should correctly transform points when using inverse matrix", () => {
         
     | 
| 
       345 
     | 
    
         
            -
                const transformMatrix = translate(100, 100, 100);
         
     | 
| 
       346 
     | 
    
         
            -
                const inverse = invert4(transformMatrix);
         
     | 
| 
       347 
     | 
    
         
            -
             
     | 
| 
       348 
     | 
    
         
            -
                const point = [200, 0, 300] as const;
         
     | 
| 
       349 
     | 
    
         
            -
                const transformedPoint = mapPoint3d(inverse, point);
         
     | 
| 
       350 
     | 
    
         
            -
                const expectedPoint = [100, -100, 200] as const;
         
     | 
| 
       351 
     | 
    
         
            -
             
     | 
| 
       352 
     | 
    
         
            -
                // Using almostEqual for floating point comparison
         
     | 
| 
       353 
     | 
    
         
            -
                almostEqual(transformedPoint, expectedPoint);
         
     | 
| 
       354 
     | 
    
         
            -
              });
         
     | 
| 
       355 
     | 
    
         
            -
             
     | 
| 
       356 
     | 
    
         
            -
              it("should maintain inverse relationship for rotations", () => {
         
     | 
| 
       357 
     | 
    
         
            -
                const rotationMatrix = rotateZ(Math.PI / 3); // 60 degrees rotation
         
     | 
| 
       358 
     | 
    
         
            -
                const inverse = invert4(rotationMatrix);
         
     | 
| 
       359 
     | 
    
         
            -
                const point = [100, 100, 0] as const;
         
     | 
| 
       360 
     | 
    
         
            -
             
     | 
| 
       361 
     | 
    
         
            -
                // Transform point forward then backward should give original point
         
     | 
| 
       362 
     | 
    
         
            -
                const transformed = mapPoint3d(rotationMatrix, point);
         
     | 
| 
       363 
     | 
    
         
            -
                const backTransformed = mapPoint3d(inverse, transformed);
         
     | 
| 
       364 
     | 
    
         
            -
             
     | 
| 
       365 
     | 
    
         
            -
                almostEqual(backTransformed, point);
         
     | 
| 
       366 
     | 
    
         
            -
              });
         
     | 
| 
       367 
     | 
    
         
            -
            });
         
     | 
| 
         @@ -1,158 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import { checkImage } from "../../../__tests__/setup";
         
     | 
| 
       2 
     | 
    
         
            -
            import type { NativeBufferAddr } from "../../../skia/types";
         
     | 
| 
       3 
     | 
    
         
            -
            import { AlphaType, ColorType } from "../../../skia/types";
         
     | 
| 
       4 
     | 
    
         
            -
            import { setupSkia } from "../../../skia/__tests__/setup";
         
     | 
| 
       5 
     | 
    
         
            -
            import { surface } from "../setup";
         
     | 
| 
       6 
     | 
    
         
            -
             
     | 
| 
       7 
     | 
    
         
            -
            const shouldNativeBufferTestRun = () => {
         
     | 
| 
       8 
     | 
    
         
            -
              // Skip outside iOS and Android
         
     | 
| 
       9 
     | 
    
         
            -
              if (surface.OS !== "ios" && surface.OS !== "android") {
         
     | 
| 
       10 
     | 
    
         
            -
                return false;
         
     | 
| 
       11 
     | 
    
         
            -
              }
         
     | 
| 
       12 
     | 
    
         
            -
              // Skip test on Fabric (it runs on API Level 21 which doesn't support native buffers)
         
     | 
| 
       13 
     | 
    
         
            -
              if (surface.arch === "fabric" && surface.OS === "android") {
         
     | 
| 
       14 
     | 
    
         
            -
                return false;
         
     | 
| 
       15 
     | 
    
         
            -
              }
         
     | 
| 
       16 
     | 
    
         
            -
              return true;
         
     | 
| 
       17 
     | 
    
         
            -
            };
         
     | 
| 
       18 
     | 
    
         
            -
             
     | 
| 
       19 
     | 
    
         
            -
            const rgbaPixels = new Array(256 * 256 * 4).fill(0);
         
     | 
| 
       20 
     | 
    
         
            -
            rgbaPixels.fill(255);
         
     | 
| 
       21 
     | 
    
         
            -
            let i = 0;
         
     | 
| 
       22 
     | 
    
         
            -
            for (let x = 0; x < 256 * 4; x++) {
         
     | 
| 
       23 
     | 
    
         
            -
              for (let y = 0; y < 256 * 4; y++) {
         
     | 
| 
       24 
     | 
    
         
            -
                rgbaPixels[i++] = (x * y) % 255;
         
     | 
| 
       25 
     | 
    
         
            -
              }
         
     | 
| 
       26 
     | 
    
         
            -
            }
         
     | 
| 
       27 
     | 
    
         
            -
             
     | 
| 
       28 
     | 
    
         
            -
            const bgraPixels = new Array(256 * 256 * 4).fill(0);
         
     | 
| 
       29 
     | 
    
         
            -
            bgraPixels.fill(255);
         
     | 
| 
       30 
     | 
    
         
            -
            // Conversion from RGBA to BGRA
         
     | 
| 
       31 
     | 
    
         
            -
            for (let j = 0; j < rgbaPixels.length; j += 4) {
         
     | 
| 
       32 
     | 
    
         
            -
              const r = rgbaPixels[j];
         
     | 
| 
       33 
     | 
    
         
            -
              const g = rgbaPixels[j + 1];
         
     | 
| 
       34 
     | 
    
         
            -
              const b = rgbaPixels[j + 2];
         
     | 
| 
       35 
     | 
    
         
            -
              const a = rgbaPixels[j + 3];
         
     | 
| 
       36 
     | 
    
         
            -
             
     | 
| 
       37 
     | 
    
         
            -
              // In BGRA, the blue and red channels are swapped
         
     | 
| 
       38 
     | 
    
         
            -
              bgraPixels[j] = b; // Blue
         
     | 
| 
       39 
     | 
    
         
            -
              bgraPixels[j + 1] = g; // Green remains the same
         
     | 
| 
       40 
     | 
    
         
            -
              bgraPixels[j + 2] = r; // Red
         
     | 
| 
       41 
     | 
    
         
            -
              bgraPixels[j + 3] = a; // Alpha remains the same
         
     | 
| 
       42 
     | 
    
         
            -
            }
         
     | 
| 
       43 
     | 
    
         
            -
             
     | 
| 
       44 
     | 
    
         
            -
            describe("Native Buffers", () => {
         
     | 
| 
       45 
     | 
    
         
            -
              it("On non supported platforms MakeImageFromNativeBuffer() should throw", async () => {
         
     | 
| 
       46 
     | 
    
         
            -
                const { Skia: Sk } = setupSkia();
         
     | 
| 
       47 
     | 
    
         
            -
                if (!shouldNativeBufferTestRun()) {
         
     | 
| 
       48 
     | 
    
         
            -
                  return;
         
     | 
| 
       49 
     | 
    
         
            -
                }
         
     | 
| 
       50 
     | 
    
         
            -
                const result = await surface.eval((Skia) => {
         
     | 
| 
       51 
     | 
    
         
            -
                  const sur = Skia.Surface.Make(256, 256)!;
         
     | 
| 
       52 
     | 
    
         
            -
                  const canvas = sur.getCanvas();
         
     | 
| 
       53 
     | 
    
         
            -
                  canvas.drawColor(Skia.Color("cyan"));
         
     | 
| 
       54 
     | 
    
         
            -
                  const nativeBuffer = Skia.NativeBuffer.MakeFromImage(
         
     | 
| 
       55 
     | 
    
         
            -
                    sur.makeImageSnapshot()
         
     | 
| 
       56 
     | 
    
         
            -
                  );
         
     | 
| 
       57 
     | 
    
         
            -
                  return (nativeBuffer as NativeBufferAddr).toString();
         
     | 
| 
       58 
     | 
    
         
            -
                });
         
     | 
| 
       59 
     | 
    
         
            -
                const pointer = BigInt(result);
         
     | 
| 
       60 
     | 
    
         
            -
                expect(pointer).not.toBe(BigInt(0));
         
     | 
| 
       61 
     | 
    
         
            -
                const t = () => {
         
     | 
| 
       62 
     | 
    
         
            -
                  Sk.Image.MakeImageFromNativeBuffer(pointer);
         
     | 
| 
       63 
     | 
    
         
            -
                };
         
     | 
| 
       64 
     | 
    
         
            -
                expect(t).toThrow(Error);
         
     | 
| 
       65 
     | 
    
         
            -
                // Now we need to release the native buffer
         
     | 
| 
       66 
     | 
    
         
            -
                const success = await surface.eval(
         
     | 
| 
       67 
     | 
    
         
            -
                  (Skia, ctx) => {
         
     | 
| 
       68 
     | 
    
         
            -
                    Skia.NativeBuffer.Release(BigInt(ctx.pointer));
         
     | 
| 
       69 
     | 
    
         
            -
                    return true;
         
     | 
| 
       70 
     | 
    
         
            -
                  },
         
     | 
| 
       71 
     | 
    
         
            -
                  { pointer: pointer.toString() }
         
     | 
| 
       72 
     | 
    
         
            -
                );
         
     | 
| 
       73 
     | 
    
         
            -
                expect(success).toBe(true);
         
     | 
| 
       74 
     | 
    
         
            -
              });
         
     | 
| 
       75 
     | 
    
         
            -
             
     | 
| 
       76 
     | 
    
         
            -
              it("creates a native buffer from an image", async () => {
         
     | 
| 
       77 
     | 
    
         
            -
                if (!shouldNativeBufferTestRun()) {
         
     | 
| 
       78 
     | 
    
         
            -
                  return;
         
     | 
| 
       79 
     | 
    
         
            -
                }
         
     | 
| 
       80 
     | 
    
         
            -
                const result = await surface.eval((Skia) => {
         
     | 
| 
       81 
     | 
    
         
            -
                  const sur = Skia.Surface.Make(256, 256)!;
         
     | 
| 
       82 
     | 
    
         
            -
                  const canvas = sur.getCanvas();
         
     | 
| 
       83 
     | 
    
         
            -
                  const paint = Skia.Paint();
         
     | 
| 
       84 
     | 
    
         
            -
                  paint.setColor(Skia.Color("cyan"));
         
     | 
| 
       85 
     | 
    
         
            -
                  canvas.drawCircle(128, 128, 128, paint);
         
     | 
| 
       86 
     | 
    
         
            -
                  const nativeBuffer = Skia.NativeBuffer.MakeFromImage(
         
     | 
| 
       87 
     | 
    
         
            -
                    sur.makeImageSnapshot()
         
     | 
| 
       88 
     | 
    
         
            -
                  );
         
     | 
| 
       89 
     | 
    
         
            -
                  const r = (nativeBuffer as NativeBufferAddr).toString();
         
     | 
| 
       90 
     | 
    
         
            -
                  Skia.NativeBuffer.Release(nativeBuffer);
         
     | 
| 
       91 
     | 
    
         
            -
                  return r;
         
     | 
| 
       92 
     | 
    
         
            -
                });
         
     | 
| 
       93 
     | 
    
         
            -
                expect(BigInt(result)).not.toBe(BigInt(0));
         
     | 
| 
       94 
     | 
    
         
            -
              });
         
     | 
| 
       95 
     | 
    
         
            -
              it("creates an image from a native buffer", async () => {
         
     | 
| 
       96 
     | 
    
         
            -
                const { Skia: Sk } = setupSkia();
         
     | 
| 
       97 
     | 
    
         
            -
                // Skip outside iOS and Android
         
     | 
| 
       98 
     | 
    
         
            -
                if (!shouldNativeBufferTestRun()) {
         
     | 
| 
       99 
     | 
    
         
            -
                  return;
         
     | 
| 
       100 
     | 
    
         
            -
                }
         
     | 
| 
       101 
     | 
    
         
            -
                const result = await surface.eval((Skia) => {
         
     | 
| 
       102 
     | 
    
         
            -
                  const sur = Skia.Surface.Make(256, 256)!;
         
     | 
| 
       103 
     | 
    
         
            -
                  const canvas = sur.getCanvas();
         
     | 
| 
       104 
     | 
    
         
            -
                  canvas.drawColor(Skia.Color("cyan"));
         
     | 
| 
       105 
     | 
    
         
            -
                  const nativeBuffer = Skia.NativeBuffer.MakeFromImage(
         
     | 
| 
       106 
     | 
    
         
            -
                    sur.makeImageSnapshot()
         
     | 
| 
       107 
     | 
    
         
            -
                  );
         
     | 
| 
       108 
     | 
    
         
            -
                  const image = Skia.Image.MakeImageFromNativeBuffer(nativeBuffer);
         
     | 
| 
       109 
     | 
    
         
            -
                  Skia.NativeBuffer.Release(nativeBuffer);
         
     | 
| 
       110 
     | 
    
         
            -
                  return Array.from(image.encodeToBytes());
         
     | 
| 
       111 
     | 
    
         
            -
                });
         
     | 
| 
       112 
     | 
    
         
            -
                const image = Sk.Image.MakeImageFromEncoded(
         
     | 
| 
       113 
     | 
    
         
            -
                  Sk.Data.fromBytes(new Uint8Array(result))
         
     | 
| 
       114 
     | 
    
         
            -
                )!;
         
     | 
| 
       115 
     | 
    
         
            -
                expect(image).not.toBeNull();
         
     | 
| 
       116 
     | 
    
         
            -
                checkImage(image, "snapshots/cyan-buffer.png");
         
     | 
| 
       117 
     | 
    
         
            -
              });
         
     | 
| 
       118 
     | 
    
         
            -
             
     | 
| 
       119 
     | 
    
         
            -
              it("creates an image from native color type", async () => {
         
     | 
| 
       120 
     | 
    
         
            -
                const { Skia: Sk } = setupSkia();
         
     | 
| 
       121 
     | 
    
         
            -
                // Skip outside iOS and Android
         
     | 
| 
       122 
     | 
    
         
            -
                if (!shouldNativeBufferTestRun()) {
         
     | 
| 
       123 
     | 
    
         
            -
                  return;
         
     | 
| 
       124 
     | 
    
         
            -
                }
         
     | 
| 
       125 
     | 
    
         
            -
                const result = await surface.eval(
         
     | 
| 
       126 
     | 
    
         
            -
                  (Skia, { alphaType, colorType, ...ctx }) => {
         
     | 
| 
       127 
     | 
    
         
            -
                    const pixels = new Uint8Array(ctx.originalPixels);
         
     | 
| 
       128 
     | 
    
         
            -
                    const data = Skia.Data.fromBytes(pixels);
         
     | 
| 
       129 
     | 
    
         
            -
                    const img = Skia.Image.MakeImage(
         
     | 
| 
       130 
     | 
    
         
            -
                      {
         
     | 
| 
       131 
     | 
    
         
            -
                        width: 256,
         
     | 
| 
       132 
     | 
    
         
            -
                        height: 256,
         
     | 
| 
       133 
     | 
    
         
            -
                        alphaType,
         
     | 
| 
       134 
     | 
    
         
            -
                        colorType,
         
     | 
| 
       135 
     | 
    
         
            -
                      },
         
     | 
| 
       136 
     | 
    
         
            -
                      data,
         
     | 
| 
       137 
     | 
    
         
            -
                      256 * 4
         
     | 
| 
       138 
     | 
    
         
            -
                    )!;
         
     | 
| 
       139 
     | 
    
         
            -
             
     | 
| 
       140 
     | 
    
         
            -
                    const nativeBuffer = Skia.NativeBuffer.MakeFromImage(img);
         
     | 
| 
       141 
     | 
    
         
            -
                    const image = Skia.Image.MakeImageFromNativeBuffer(nativeBuffer);
         
     | 
| 
       142 
     | 
    
         
            -
                    Skia.NativeBuffer.Release(nativeBuffer);
         
     | 
| 
       143 
     | 
    
         
            -
                    return Array.from(image.encodeToBytes());
         
     | 
| 
       144 
     | 
    
         
            -
                  },
         
     | 
| 
       145 
     | 
    
         
            -
                  {
         
     | 
| 
       146 
     | 
    
         
            -
                    alphaType: AlphaType.Unpremul,
         
     | 
| 
       147 
     | 
    
         
            -
                    colorType:
         
     | 
| 
       148 
     | 
    
         
            -
                      surface.OS === "android" ? ColorType.RGBA_8888 : ColorType.BGRA_8888,
         
     | 
| 
       149 
     | 
    
         
            -
                    originalPixels: surface.OS === "android" ? rgbaPixels : bgraPixels,
         
     | 
| 
       150 
     | 
    
         
            -
                  }
         
     | 
| 
       151 
     | 
    
         
            -
                );
         
     | 
| 
       152 
     | 
    
         
            -
                const image = Sk.Image.MakeImageFromEncoded(
         
     | 
| 
       153 
     | 
    
         
            -
                  Sk.Data.fromBytes(new Uint8Array(result))
         
     | 
| 
       154 
     | 
    
         
            -
                )!;
         
     | 
| 
       155 
     | 
    
         
            -
                expect(image).not.toBeNull();
         
     | 
| 
       156 
     | 
    
         
            -
                checkImage(image, "snapshots/platform-buffer.png", { overwrite: true });
         
     | 
| 
       157 
     | 
    
         
            -
              });
         
     | 
| 
       158 
     | 
    
         
            -
            });
         
     |