@shopify/react-native-skia 2.2.21 → 2.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/CMakeLists.txt +0 -3
- package/android/cpp/rnskia-android/RNSkAndroidPlatformContext.h +4 -1
- package/apple/RNSkApplePlatformContext.mm +21 -12
- package/cpp/api/JsiSkCanvas.h +3 -21
- package/cpp/api/JsiSkImage.h +8 -2
- package/cpp/api/JsiSkPath.h +1 -1
- package/cpp/api/JsiSkPathFactory.h +1 -1
- package/cpp/api/JsiSkSVG.h +4 -1
- package/cpp/api/JsiSkSVGFactory.h +127 -8
- 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/lib/commonjs/skia/types/SVG/SVGFactory.d.ts +3 -2
- package/lib/commonjs/skia/types/SVG/SVGFactory.js.map +1 -1
- package/lib/module/skia/types/SVG/SVGFactory.d.ts +3 -2
- package/lib/module/skia/types/SVG/SVGFactory.js.map +1 -1
- package/lib/typescript/src/skia/types/SVG/SVGFactory.d.ts +3 -2
- package/package.json +9 -8
- package/react-native-skia.podspec +1 -2
- package/scripts/install-skia.mjs +360 -0
- package/src/skia/types/SVG/SVGFactory.ts +11 -2
- 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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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 -94
- 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/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
|
-
});
|