@shopify/react-native-skia 2.3.0 → 2.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/CMakeLists.txt +0 -3
 - package/android/cpp/rnskia-android/RNSkAndroidPlatformContext.h +4 -1
 - package/apple/RNSkApplePlatformContext.mm +21 -12
 - package/apple/SkiaCVPixelBufferUtils.mm +8 -4
 - package/cpp/api/JsiSkCanvas.h +0 -21
 - package/cpp/api/JsiSkImage.h +1 -5
 - package/cpp/api/JsiSkPath.h +1 -1
 - package/cpp/api/JsiSkPathFactory.h +1 -1
 - package/cpp/skia/include/android/AHardwareBufferUtils.h +3 -0
 - package/cpp/skia/include/android/GrAHardwareBufferUtils.h +0 -4
 - package/cpp/skia/include/android/SkAndroidFrameworkUtils.h +0 -4
 - package/cpp/skia/include/android/SkImageAndroid.h +1 -0
 - package/cpp/skia/include/codec/SkCodec.h +23 -2
 - package/cpp/skia/include/codec/SkPngRustDecoder.h +30 -0
 - package/cpp/skia/include/core/SkBitmap.h +1 -1
 - package/cpp/skia/include/core/SkCPURecorder.h +5 -0
 - package/cpp/skia/include/core/SkCanvas.h +2 -0
 - package/cpp/skia/include/core/SkColorSpace.h +11 -12
 - package/cpp/skia/include/core/SkContourMeasure.h +6 -2
 - package/cpp/skia/include/core/SkExecutor.h +18 -0
 - package/cpp/skia/include/core/SkFont.h +26 -19
 - package/cpp/skia/include/core/SkImage.h +4 -66
 - package/cpp/skia/include/core/SkImageGenerator.h +0 -5
 - package/cpp/skia/include/core/SkMatrix.h +84 -120
 - package/cpp/skia/include/core/SkMilestone.h +1 -1
 - package/cpp/skia/include/core/SkPath.h +390 -395
 - package/cpp/skia/include/core/SkPathBuilder.h +64 -34
 - package/cpp/skia/include/core/SkPathEffect.h +12 -5
 - package/cpp/skia/include/core/SkPathIter.h +90 -0
 - package/cpp/skia/include/core/SkPathMeasure.h +5 -1
 - package/cpp/skia/include/core/SkPathTypes.h +7 -3
 - package/cpp/skia/include/core/SkPathUtils.h +20 -13
 - package/cpp/skia/include/core/SkRRect.h +7 -11
 - package/cpp/skia/include/core/SkRecorder.h +12 -0
 - package/cpp/skia/include/core/SkRect.h +33 -8
 - package/cpp/skia/include/core/SkRegion.h +14 -3
 - package/cpp/skia/include/core/SkScalar.h +0 -12
 - package/cpp/skia/include/core/SkShader.h +20 -7
 - package/cpp/skia/include/core/SkStrokeRec.h +2 -1
 - package/cpp/skia/include/core/SkTypeface.h +8 -10
 - package/cpp/skia/include/core/SkTypes.h +4 -0
 - package/cpp/skia/include/encode/SkJpegEncoder.h +5 -10
 - package/cpp/skia/include/encode/SkPngEncoder.h +8 -7
 - package/cpp/skia/include/encode/SkPngRustEncoder.h +88 -0
 - package/cpp/skia/include/encode/SkWebpEncoder.h +5 -10
 - package/cpp/skia/include/gpu/graphite/BackendSemaphore.h +5 -2
 - package/cpp/skia/include/gpu/graphite/BackendTexture.h +5 -2
 - package/cpp/skia/include/gpu/graphite/Context.h +15 -2
 - package/cpp/skia/include/gpu/graphite/ContextOptions.h +26 -0
 - package/cpp/skia/include/gpu/graphite/GraphiteTypes.h +75 -0
 - package/cpp/skia/include/gpu/graphite/Recorder.h +15 -6
 - package/cpp/skia/include/gpu/graphite/Recording.h +0 -3
 - package/cpp/skia/include/gpu/graphite/mtl/MtlBackendContext.h +2 -0
 - package/cpp/skia/include/gpu/graphite/precompile/PaintOptions.h +3 -7
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileBase.h +2 -10
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileImageFilter.h +1 -6
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileMaskFilter.h +1 -5
 - package/cpp/skia/include/gpu/graphite/precompile/PrecompileShader.h +16 -3
 - package/cpp/skia/include/gpu/vk/VulkanPreferredFeatures.h +3 -0
 - package/cpp/skia/{modules/pathops/include → include/pathops}/SkPathOps.h +49 -20
 - package/cpp/skia/include/ports/SkFontMgr_FontConfigInterface.h +2 -1
 - package/cpp/skia/include/ports/SkFontMgr_android.h +0 -4
 - package/cpp/skia/include/ports/SkFontMgr_android_ndk.h +4 -2
 - package/cpp/skia/include/ports/SkFontMgr_fontconfig.h +0 -3
 - package/cpp/skia/include/private/SkEncodedInfo.h +73 -54
 - package/cpp/skia/include/private/SkHdrMetadata.h +173 -0
 - package/cpp/skia/include/private/SkPathRef.h +117 -146
 - package/cpp/skia/include/private/base/SkTemplates.h +74 -32
 - package/cpp/skia/include/utils/SkParsePath.h +9 -1
 - package/cpp/skia/modules/skcms/src/Transform_inl.h +53 -7
 - package/cpp/skia/modules/skcms/src/skcms_Transform.h +2 -0
 - package/cpp/skia/modules/skcms/src/skcms_internals.h +8 -0
 - package/cpp/skia/modules/skottie/include/TextShaper.h +4 -0
 - package/cpp/skia/modules/skparagraph/include/FontCollection.h +1 -1
 - package/cpp/skia/modules/skparagraph/include/ParagraphStyle.h +7 -1
 - package/cpp/skia/modules/skparagraph/include/TextStyle.h +12 -0
 - package/cpp/skia/modules/sksg/include/SkSGGeometryEffect.h +26 -0
 - package/cpp/skia/modules/sksg/include/SkSGPath.h +1 -1
 - package/cpp/skia/modules/skunicode/include/SkUnicode.h +11 -1
 - package/cpp/skia/modules/svg/include/SkSVGAttributeParser.h +7 -11
 - package/cpp/skia/modules/svg/include/SkSVGCircle.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGEllipse.h +1 -2
 - package/cpp/skia/modules/svg/include/SkSVGFe.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGFeLightSource.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGFeLighting.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGLine.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGNode.h +11 -10
 - package/cpp/skia/modules/svg/include/SkSVGPath.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGPattern.h +4 -3
 - package/cpp/skia/modules/svg/include/SkSVGPoly.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGRadialGradient.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGRect.h +1 -2
 - package/cpp/skia/modules/svg/include/SkSVGRenderContext.h +5 -5
 - package/cpp/skia/modules/svg/include/SkSVGSVG.h +0 -1
 - package/cpp/skia/modules/svg/include/SkSVGShape.h +1 -1
 - package/cpp/skia/modules/svg/include/SkSVGTransformableNode.h +2 -2
 - package/cpp/skia/src/base/SkTLazy.h +8 -0
 - package/cpp/skia/src/core/SkLRUCache.h +17 -13
 - package/package.json +9 -8
 - package/react-native-skia.podspec +1 -2
 - package/scripts/install-skia.mjs +360 -0
 - package/cpp/skia/include/android/SkHeifDecoder.h +0 -50
 - package/lib/commonjs/__tests__/globalSetup.d.ts +0 -9
 - package/lib/commonjs/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/commonjs/__tests__/setup.d.ts +0 -36
 - package/lib/commonjs/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/commonjs/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/commonjs/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/commonjs/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/commonjs/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/commonjs/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/commonjs/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/commonjs/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/commonjs/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/commonjs/skia/__tests__/setup.d.ts +0 -16
 - package/lib/commonjs/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/module/__tests__/globalSetup.d.ts +0 -9
 - package/lib/module/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/module/__tests__/setup.d.ts +0 -36
 - package/lib/module/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/module/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/module/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/module/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/module/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/module/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/module/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/module/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/module/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/module/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/module/skia/__tests__/setup.d.ts +0 -16
 - package/lib/module/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/typescript/src/__tests__/globalSetup.d.ts +0 -9
 - package/lib/typescript/src/__tests__/globalTeardown.d.ts +0 -2
 - package/lib/typescript/src/__tests__/setup.d.ts +0 -36
 - package/lib/typescript/src/mock/__tests__/mock.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Data.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/FitBox.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Glyphs.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Image.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Paths.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Picture.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Simple.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Surfaces.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/Group.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/paint/Overview.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/documentation/shapes/Box.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/AdvancedImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Atlas.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Blending.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Blur.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Box.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Camera.spec.d.ts +0 -21
 - package/lib/typescript/src/renderer/__tests__/e2e/ColorFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/CoonPatch.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/DataEncoding.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/FontMgr.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Gradient.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Group.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Image.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/LightingImageFilters.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Mask.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Matrix4.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Offscreen.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Opacity.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paint.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ParagraphMethods.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paragraphs.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/PathEffects.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Paths.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Picture.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Point.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Rect.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/SDF.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/SVG.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Shader.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Skottie.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Snapshot.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Surfaces.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/TextPath.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Transforms.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Vertices.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/Video.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/Paragraph.d.ts +0 -20
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/SVG.d.ts +0 -13
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/SkiaObject.d.ts +0 -11
 - package/lib/typescript/src/renderer/__tests__/e2e/setup/index.d.ts +0 -3
 - package/lib/typescript/src/renderer/__tests__/examples/BlendModes.spec.d.ts +0 -1
 - package/lib/typescript/src/renderer/__tests__/setup.d.ts +0 -71
 - package/lib/typescript/src/skia/__tests__/ColorFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Data.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Drawings.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Enums.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Geometry.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/ImageFilter.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Mock.spec.d.ts +0 -0
 - package/lib/typescript/src/skia/__tests__/Paint.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Path.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/RuntimeEffect.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Shader.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Text.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Transform.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/Vertices.spec.d.ts +0 -1
 - package/lib/typescript/src/skia/__tests__/setup.d.ts +0 -16
 - package/lib/typescript/src/sksg/__tests__/Simple.spec.d.ts +0 -1
 - package/libs/android/arm64-v8a/libjsonreader.a +0 -0
 - package/libs/android/arm64-v8a/libpathops.a +0 -0
 - package/libs/android/arm64-v8a/libskia.a +0 -0
 - package/libs/android/arm64-v8a/libskottie.a +0 -0
 - package/libs/android/arm64-v8a/libskparagraph.a +0 -0
 - package/libs/android/arm64-v8a/libsksg.a +0 -0
 - package/libs/android/arm64-v8a/libskshaper.a +0 -0
 - package/libs/android/arm64-v8a/libskunicode_core.a +0 -0
 - package/libs/android/arm64-v8a/libskunicode_icu.a +0 -0
 - package/libs/android/arm64-v8a/libsvg.a +0 -0
 - package/libs/android/armeabi-v7a/libjsonreader.a +0 -0
 - package/libs/android/armeabi-v7a/libpathops.a +0 -0
 - package/libs/android/armeabi-v7a/libskia.a +0 -0
 - package/libs/android/armeabi-v7a/libskottie.a +0 -0
 - package/libs/android/armeabi-v7a/libskparagraph.a +0 -0
 - package/libs/android/armeabi-v7a/libsksg.a +0 -0
 - package/libs/android/armeabi-v7a/libskshaper.a +0 -0
 - package/libs/android/armeabi-v7a/libskunicode_core.a +0 -0
 - package/libs/android/armeabi-v7a/libskunicode_icu.a +0 -0
 - package/libs/android/armeabi-v7a/libsvg.a +0 -0
 - package/libs/android/x86/libjsonreader.a +0 -0
 - package/libs/android/x86/libpathops.a +0 -0
 - package/libs/android/x86/libskia.a +0 -0
 - package/libs/android/x86/libskottie.a +0 -0
 - package/libs/android/x86/libskparagraph.a +0 -0
 - package/libs/android/x86/libsksg.a +0 -0
 - package/libs/android/x86/libskshaper.a +0 -0
 - package/libs/android/x86/libskunicode_core.a +0 -0
 - package/libs/android/x86/libskunicode_icu.a +0 -0
 - package/libs/android/x86/libsvg.a +0 -0
 - package/libs/android/x86_64/libjsonreader.a +0 -0
 - package/libs/android/x86_64/libpathops.a +0 -0
 - package/libs/android/x86_64/libskia.a +0 -0
 - package/libs/android/x86_64/libskottie.a +0 -0
 - package/libs/android/x86_64/libskparagraph.a +0 -0
 - package/libs/android/x86_64/libsksg.a +0 -0
 - package/libs/android/x86_64/libskshaper.a +0 -0
 - package/libs/android/x86_64/libskunicode_core.a +0 -0
 - package/libs/android/x86_64/libskunicode_icu.a +0 -0
 - package/libs/android/x86_64/libsvg.a +0 -0
 - package/libs/apple/libpathops.xcframework/Info.plist +0 -111
 - package/libs/apple/libpathops.xcframework/ios-arm64_arm64e/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/ios-arm64_arm64e_x86_64-simulator/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/ios-arm64_x86_64-maccatalyst/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/macos-arm64_x86_64/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/tvos-arm64_arm64e/libpathops.a +0 -0
 - package/libs/apple/libpathops.xcframework/tvos-arm64_arm64e_x86_64-simulator/libpathops.a +0 -0
 - package/libs/apple/libskia.xcframework/Info.plist +0 -111
 - package/libs/apple/libskia.xcframework/ios-arm64_arm64e/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/ios-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/ios-arm64_x86_64-maccatalyst/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/macos-arm64_x86_64/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/tvos-arm64_arm64e/libskia.a +0 -0
 - package/libs/apple/libskia.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
 - package/libs/apple/libskottie.xcframework/Info.plist +0 -111
 - package/libs/apple/libskottie.xcframework/ios-arm64_arm64e/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/ios-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/ios-arm64_x86_64-maccatalyst/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/macos-arm64_x86_64/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/tvos-arm64_arm64e/libskottie.a +0 -0
 - package/libs/apple/libskottie.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/Info.plist +0 -111
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_arm64e/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/ios-arm64_x86_64-maccatalyst/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/macos-arm64_x86_64/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/tvos-arm64_arm64e/libskparagraph.a +0 -0
 - package/libs/apple/libskparagraph.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
 - package/libs/apple/libsksg.xcframework/Info.plist +0 -111
 - package/libs/apple/libsksg.xcframework/ios-arm64_arm64e/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/ios-arm64_x86_64-maccatalyst/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/macos-arm64_x86_64/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/tvos-arm64_arm64e/libsksg.a +0 -0
 - package/libs/apple/libsksg.xcframework/tvos-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
 - package/libs/apple/libskshaper.xcframework/Info.plist +0 -111
 - package/libs/apple/libskshaper.xcframework/ios-arm64_arm64e/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/ios-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/ios-arm64_x86_64-maccatalyst/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/macos-arm64_x86_64/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/tvos-arm64_arm64e/libskshaper.a +0 -0
 - package/libs/apple/libskshaper.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/Info.plist +0 -111
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_arm64e/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/ios-arm64_x86_64-maccatalyst/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/macos-arm64_x86_64/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/tvos-arm64_arm64e/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_core.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskunicode_core.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/Info.plist +0 -111
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_arm64e/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/ios-arm64_x86_64-maccatalyst/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/macos-arm64_x86_64/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/tvos-arm64_arm64e/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libskunicode_libgrapheme.xcframework/tvos-arm64_arm64e_x86_64-simulator/libskunicode_libgrapheme.a +0 -0
 - package/libs/apple/libsvg.xcframework/Info.plist +0 -111
 - package/libs/apple/libsvg.xcframework/ios-arm64_arm64e/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/ios-arm64_x86_64-maccatalyst/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/macos-arm64_x86_64/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/tvos-arm64_arm64e/libsvg.a +0 -0
 - package/libs/apple/libsvg.xcframework/tvos-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
 - package/src/__tests__/globalSetup.ts +0 -53
 - package/src/__tests__/globalTeardown.ts +0 -11
 - package/src/__tests__/setup.ts +0 -192
 - package/src/__tests__/snapshots/animated-images/bird.png +0 -0
 - package/src/__tests__/snapshots/animations/green.png +0 -0
 - package/src/__tests__/snapshots/animations/lightblue.png +0 -0
 - package/src/__tests__/snapshots/animations/quarter-lightblue.png +0 -0
 - package/src/__tests__/snapshots/animations/red.png +0 -0
 - package/src/__tests__/snapshots/atlas/identity.png +0 -0
 - package/src/__tests__/snapshots/atlas/rsxform.png +0 -0
 - package/src/__tests__/snapshots/atlas/rsxform1.png +0 -0
 - package/src/__tests__/snapshots/atlas/simple.png +0 -0
 - package/src/__tests__/snapshots/atlas/simple2.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow-opacity.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow2.png +0 -0
 - package/src/__tests__/snapshots/box/box-shadow3.png +0 -0
 - package/src/__tests__/snapshots/box/box-stroke.png +0 -0
 - package/src/__tests__/snapshots/color-filter/color-filter-composition.png +0 -0
 - package/src/__tests__/snapshots/color-filter/matrix1.png +0 -0
 - package/src/__tests__/snapshots/color-filter/matrix3.png +0 -0
 - package/src/__tests__/snapshots/color-filter/zurich-sepia.png +0 -0
 - package/src/__tests__/snapshots/coons-patch/patch-with-opacity.png +0 -0
 - package/src/__tests__/snapshots/coons-patch/simple.png +0 -0
 - package/src/__tests__/snapshots/cyan-buffer.png +0 -0
 - package/src/__tests__/snapshots/data/oslo.png +0 -0
 - package/src/__tests__/snapshots/data/red.png +0 -0
 - package/src/__tests__/snapshots/data/zurich.png +0 -0
 - package/src/__tests__/snapshots/demos/apple-breathe.png +0 -0
 - package/src/__tests__/snapshots/demos/apple-breathe1.png +0 -0
 - package/src/__tests__/snapshots/demos/breathe.png +0 -0
 - package/src/__tests__/snapshots/demos/breathe2.png +0 -0
 - package/src/__tests__/snapshots/demos/product.png +0 -0
 - package/src/__tests__/snapshots/demos/product2.png +0 -0
 - package/src/__tests__/snapshots/demos/skia-neon.png +0 -0
 - package/src/__tests__/snapshots/demos/skia-neon1.png +0 -0
 - package/src/__tests__/snapshots/drawings/arc.png +0 -0
 - package/src/__tests__/snapshots/drawings/blend-mode-multiply.png +0 -0
 - package/src/__tests__/snapshots/drawings/blend-modes.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur-node.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur.png +0 -0
 - package/src/__tests__/snapshots/drawings/blur2.png +0 -0
 - package/src/__tests__/snapshots/drawings/custom-drawing.png +0 -0
 - package/src/__tests__/snapshots/drawings/cyan-circle.png +0 -0
 - package/src/__tests__/snapshots/drawings/cyan.png +0 -0
 - package/src/__tests__/snapshots/drawings/default-props.png +0 -0
 - package/src/__tests__/snapshots/drawings/hello-world.png +0 -0
 - package/src/__tests__/snapshots/drawings/image-default-props.png +0 -0
 - package/src/__tests__/snapshots/drawings/lightblue-quarter-circle.png +0 -0
 - package/src/__tests__/snapshots/drawings/lightblue-rect.png +0 -0
 - package/src/__tests__/snapshots/drawings/line.png +0 -0
 - package/src/__tests__/snapshots/drawings/multiple-paints.png +0 -0
 - package/src/__tests__/snapshots/drawings/nested-shader.png +0 -0
 - package/src/__tests__/snapshots/drawings/nested-shader2.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-multiplication.png +0 -0
 - package/src/__tests__/snapshots/drawings/opacity-multiplication2.png +0 -0
 - package/src/__tests__/snapshots/drawings/points.png +0 -0
 - package/src/__tests__/snapshots/drawings/purple.png +0 -0
 - package/src/__tests__/snapshots/drawings/rotated-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/rotated-scaled-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/rrect-aa.png +0 -0
 - package/src/__tests__/snapshots/drawings/rrect-no-aa.png +0 -0
 - package/src/__tests__/snapshots/drawings/scaled-image.png +0 -0
 - package/src/__tests__/snapshots/drawings/scaled-image2.png +0 -0
 - package/src/__tests__/snapshots/drawings/semi-transparent-layer.png +0 -0
 - package/src/__tests__/snapshots/drawings/shader-opacity-reference.png +0 -0
 - package/src/__tests__/snapshots/drawings/skew-transform.png +0 -0
 - package/src/__tests__/snapshots/drawings/skew-transform2.png +0 -0
 - package/src/__tests__/snapshots/drawings/small-lightblue-rect.png +0 -0
 - package/src/__tests__/snapshots/drawings/stroke.png +0 -0
 - package/src/__tests__/snapshots/drawings/transform-origin.png +0 -0
 - package/src/__tests__/snapshots/drawings/transparent-layer.png +0 -0
 - package/src/__tests__/snapshots/drawings/transparent.png +0 -0
 - package/src/__tests__/snapshots/drawings/violet.png +0 -0
 - package/src/__tests__/snapshots/font/green.png +0 -0
 - package/src/__tests__/snapshots/font/red.png +0 -0
 - package/src/__tests__/snapshots/glyphs/simple.png +0 -0
 - package/src/__tests__/snapshots/gradient/linear-with-opacity.png +0 -0
 - package/src/__tests__/snapshots/gradient/linear.png +0 -0
 - package/src/__tests__/snapshots/green.png +0 -0
 - package/src/__tests__/snapshots/image-filter/blur.png +0 -0
 - package/src/__tests__/snapshots/image-filter/test-shadow.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-android.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-ios.png +0 -0
 - package/src/__tests__/snapshots/images/bundle-node.png +0 -0
 - package/src/__tests__/snapshots/images/bundle.png +0 -0
 - package/src/__tests__/snapshots/images/filter.png +0 -0
 - package/src/__tests__/snapshots/leak.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-corner.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-offset.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-top-left-center.png +0 -0
 - package/src/__tests__/snapshots/matrix4/camera-zoom-out.png +0 -0
 - package/src/__tests__/snapshots/matrix4/full-rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/perspective.png +0 -0
 - package/src/__tests__/snapshots/matrix4/rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/scaled-rect.png +0 -0
 - package/src/__tests__/snapshots/matrix4/test-perspective.png +0 -0
 - package/src/__tests__/snapshots/matrix4/test-perspective2.png +0 -0
 - package/src/__tests__/snapshots/paint/blend-mode.png +0 -0
 - package/src/__tests__/snapshots/paint/circle.png +0 -0
 - package/src/__tests__/snapshots/paint/colors.png +0 -0
 - package/src/__tests__/snapshots/paint/dither.png +0 -0
 - package/src/__tests__/snapshots/paint/path-paint.png +0 -0
 - package/src/__tests__/snapshots/paint/without-dither.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-node.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-ellipse-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-ellipse-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android-box.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios-box.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-android.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-ios.png +0 -0
 - package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-node.png +0 -0
 - package/src/__tests__/snapshots/path/interpolate.png +0 -0
 - package/src/__tests__/snapshots/path/logo.png +0 -0
 - package/src/__tests__/snapshots/path-effects/discrete.png +0 -0
 - package/src/__tests__/snapshots/path-effects/sum.png +0 -0
 - package/src/__tests__/snapshots/path-effects/sum2.png +0 -0
 - package/src/__tests__/snapshots/paths/arc.png +0 -0
 - package/src/__tests__/snapshots/paths/emptyPath.png +0 -0
 - package/src/__tests__/snapshots/paths/interpolation1.png +0 -0
 - package/src/__tests__/snapshots/paths/oval.png +0 -0
 - package/src/__tests__/snapshots/paths/pattern.png +0 -0
 - package/src/__tests__/snapshots/paths/poly.png +0 -0
 - package/src/__tests__/snapshots/paths/rrect.png +0 -0
 - package/src/__tests__/snapshots/paths/skia-trimmed.png +0 -0
 - package/src/__tests__/snapshots/paths/skia.png +0 -0
 - package/src/__tests__/snapshots/pictures/create-picture.png +0 -0
 - package/src/__tests__/snapshots/pictures/green.png +0 -0
 - package/src/__tests__/snapshots/pictures/hello-world.png +0 -0
 - package/src/__tests__/snapshots/pictures/red.png +0 -0
 - package/src/__tests__/snapshots/pictures/simple-picture.png +0 -0
 - package/src/__tests__/snapshots/platform-buffer-bgra.png +0 -0
 - package/src/__tests__/snapshots/platform-buffer.png +0 -0
 - package/src/__tests__/snapshots/points/points.png +0 -0
 - package/src/__tests__/snapshots/points/points2.png +0 -0
 - package/src/__tests__/snapshots/render-nodes/simple.png +0 -0
 - package/src/__tests__/snapshots/render-nodes/simple2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-burn3.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-color-dodge.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/blend-multiply.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/int-uniform.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/linear-gradient.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/linear-gradient2.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/small-spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-effects/spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/scaled-circle.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/scaled-circle2.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/simple.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/spiral.png +0 -0
 - package/src/__tests__/snapshots/runtime-shader/unscaled-image.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot1-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot2-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot3-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-android-ci.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot4-ios.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot5-android.png +0 -0
 - package/src/__tests__/snapshots/screens/snapshot5-ios.png +0 -0
 - package/src/__tests__/snapshots/sdf/circle.png +0 -0
 - package/src/__tests__/snapshots/sdf/heart.png +0 -0
 - package/src/__tests__/snapshots/sdf/line.png +0 -0
 - package/src/__tests__/snapshots/sdf/rectangle.png +0 -0
 - package/src/__tests__/snapshots/shader/bilinear-interpolation.png +0 -0
 - package/src/__tests__/snapshots/shader/hue.png +0 -0
 - package/src/__tests__/snapshots/shader/hue2.png +0 -0
 - package/src/__tests__/snapshots/shader/shader1.png +0 -0
 - package/src/__tests__/snapshots/shader/shader2.png +0 -0
 - package/src/__tests__/snapshots/shader/sweep-gradient.png +0 -0
 - package/src/__tests__/snapshots/sksg/breathe-0.png +0 -0
 - package/src/__tests__/snapshots/sksg/breathe.png +0 -0
 - package/src/__tests__/snapshots/sksg/simple.png +0 -0
 - package/src/__tests__/snapshots/sksg/simple2.png +0 -0
 - package/src/__tests__/snapshots/text/text-bounds-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-bounds-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-default-font-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-default-font-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path-bug-node.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path1-node.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-android.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-ios.png +0 -0
 - package/src/__tests__/snapshots/text/text-path2-node.png +0 -0
 - package/src/__tests__/snapshots/transform/rectangles.png +0 -0
 - package/src/__tests__/snapshots/transform/rotate-radiants.png +0 -0
 - package/src/__tests__/snapshots/transform/rotate.png +0 -0
 - package/src/__tests__/snapshots/transform/scale-origin.png +0 -0
 - package/src/__tests__/snapshots/transform/scale.png +0 -0
 - package/src/__tests__/snapshots/transform/skew.png +0 -0
 - package/src/__tests__/snapshots/transparent.png +0 -0
 - package/src/__tests__/snapshots/vertices/billinear-gradient.png +0 -0
 - package/src/__tests__/snapshots/vertices/strip.png +0 -0
 - package/src/__tests__/snapshots/vertices/vertices.png +0 -0
 - package/src/mock/__tests__/mock.spec.ts +0 -47
 - package/src/renderer/__tests__/Data.spec.tsx +0 -66
 - package/src/renderer/__tests__/Drawings.spec.tsx +0 -96
 - package/src/renderer/__tests__/FitBox.spec.tsx +0 -677
 - package/src/renderer/__tests__/Glyphs.spec.tsx +0 -46
 - package/src/renderer/__tests__/Image.spec.tsx +0 -45
 - package/src/renderer/__tests__/Paths.spec.tsx +0 -75
 - package/src/renderer/__tests__/Picture.spec.tsx +0 -83
 - package/src/renderer/__tests__/Simple.spec.tsx +0 -81
 - package/src/renderer/__tests__/Surfaces.spec.tsx +0 -68
 - package/src/renderer/__tests__/Text.spec.tsx +0 -134
 - package/src/renderer/__tests__/Transform.spec.tsx +0 -72
 - package/src/renderer/__tests__/documentation/Group.spec.tsx +0 -170
 - package/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.tsx +0 -51
 - package/src/renderer/__tests__/documentation/paint/Overview.spec.tsx +0 -84
 - package/src/renderer/__tests__/documentation/shapes/Box.spec.tsx +0 -46
 - package/src/renderer/__tests__/e2e/AdvancedImageFilters.spec.tsx +0 -492
 - package/src/renderer/__tests__/e2e/AnimatedImages.spec.tsx +0 -87
 - package/src/renderer/__tests__/e2e/Atlas.spec.tsx +0 -358
 - package/src/renderer/__tests__/e2e/BackdropFilters.spec.tsx +0 -164
 - package/src/renderer/__tests__/e2e/Blending.spec.tsx +0 -115
 - package/src/renderer/__tests__/e2e/Blur.spec.tsx +0 -56
 - package/src/renderer/__tests__/e2e/Box.spec.tsx +0 -105
 - package/src/renderer/__tests__/e2e/Camera.spec.tsx +0 -475
 - package/src/renderer/__tests__/e2e/ColorFilters.spec.tsx +0 -227
 - package/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.tsx +0 -102
 - package/src/renderer/__tests__/e2e/CoonPatch.spec.tsx +0 -74
 - package/src/renderer/__tests__/e2e/DataEncoding.spec.tsx +0 -79
 - package/src/renderer/__tests__/e2e/Drawings.spec.tsx +0 -254
 - package/src/renderer/__tests__/e2e/FontMgr.spec.tsx +0 -150
 - package/src/renderer/__tests__/e2e/Gradient.spec.tsx +0 -40
 - package/src/renderer/__tests__/e2e/Group.spec.tsx +0 -128
 - package/src/renderer/__tests__/e2e/Image.spec.tsx +0 -77
 - package/src/renderer/__tests__/e2e/ImageEncoding.spec.tsx +0 -255
 - package/src/renderer/__tests__/e2e/ImageFilter.spec.tsx +0 -99
 - package/src/renderer/__tests__/e2e/ImageFilters.spec.tsx +0 -320
 - package/src/renderer/__tests__/e2e/LightingImageFilters.spec.tsx +0 -1478
 - package/src/renderer/__tests__/e2e/Mask.spec.tsx +0 -85
 - package/src/renderer/__tests__/e2e/Matrix4.spec.tsx +0 -367
 - package/src/renderer/__tests__/e2e/NativeBuffer.spec.tsx +0 -158
 - package/src/renderer/__tests__/e2e/Offscreen.spec.tsx +0 -109
 - package/src/renderer/__tests__/e2e/Opacity.spec.tsx +0 -301
 - package/src/renderer/__tests__/e2e/Paint.spec.tsx +0 -230
 - package/src/renderer/__tests__/e2e/ParagraphMethods.spec.tsx +0 -388
 - package/src/renderer/__tests__/e2e/ParagraphPaint.spec.tsx +0 -262
 - package/src/renderer/__tests__/e2e/Paragraphs.spec.tsx +0 -615
 - package/src/renderer/__tests__/e2e/PathEffects.spec.tsx +0 -73
 - package/src/renderer/__tests__/e2e/Paths.spec.tsx +0 -394
 - package/src/renderer/__tests__/e2e/Picture.spec.tsx +0 -134
 - package/src/renderer/__tests__/e2e/Point.spec.tsx +0 -35
 - package/src/renderer/__tests__/e2e/Rect.spec.tsx +0 -139
 - package/src/renderer/__tests__/e2e/RuntimeShader.spec.tsx +0 -323
 - package/src/renderer/__tests__/e2e/SDF.spec.tsx +0 -148
 - package/src/renderer/__tests__/e2e/SVG.spec.tsx +0 -192
 - package/src/renderer/__tests__/e2e/Shader.spec.tsx +0 -353
 - package/src/renderer/__tests__/e2e/Skottie.spec.tsx +0 -463
 - package/src/renderer/__tests__/e2e/Snapshot.spec.tsx +0 -29
 - package/src/renderer/__tests__/e2e/Surfaces.spec.tsx +0 -17
 - package/src/renderer/__tests__/e2e/Text.spec.tsx +0 -109
 - package/src/renderer/__tests__/e2e/TextPath.spec.tsx +0 -43
 - package/src/renderer/__tests__/e2e/Transforms.spec.tsx +0 -63
 - package/src/renderer/__tests__/e2e/Vertices.spec.tsx +0 -30
 - package/src/renderer/__tests__/e2e/Video.ts +0 -68
 - package/src/renderer/__tests__/e2e/setup/Paragraph.ts +0 -60
 - package/src/renderer/__tests__/e2e/setup/SVG.ts +0 -31
 - package/src/renderer/__tests__/e2e/setup/SkiaObject.ts +0 -31
 - package/src/renderer/__tests__/e2e/setup/index.ts +0 -3
 - package/src/renderer/__tests__/e2e/setup/skottie/basic_slots.json +0 -1118
 - package/src/renderer/__tests__/e2e/setup/skottie/color-props.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/confetti.json +0 -5899
 - package/src/renderer/__tests__/e2e/setup/skottie/drinks.json +0 -43857
 - package/src/renderer/__tests__/e2e/setup/skottie/fingerprint.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/lego_loader.json +0 -29540
 - package/src/renderer/__tests__/e2e/setup/skottie/new-drop.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/onboarding.json +0 -1
 - package/src/renderer/__tests__/e2e/setup/skottie/text-layer.json +0 -1
 - package/src/renderer/__tests__/examples/BlendModes.spec.tsx +0 -123
 - package/src/renderer/__tests__/setup.tsx +0 -525
 - package/src/skia/__tests__/ColorFilter.spec.ts +0 -67
 - package/src/skia/__tests__/Data.spec.ts +0 -29
 - package/src/skia/__tests__/Drawings.spec.ts +0 -119
 - package/src/skia/__tests__/Enums.spec.ts +0 -136
 - package/src/skia/__tests__/Geometry.spec.ts +0 -39
 - package/src/skia/__tests__/ImageFilter.spec.ts +0 -19
 - package/src/skia/__tests__/Mock.spec.ts +0 -7
 - package/src/skia/__tests__/Paint.spec.ts +0 -25
 - package/src/skia/__tests__/Path.spec.ts +0 -384
 - package/src/skia/__tests__/RuntimeEffect.spec.ts +0 -66
 - package/src/skia/__tests__/Shader.spec.ts +0 -96
 - package/src/skia/__tests__/Text.spec.ts +0 -32
 - package/src/skia/__tests__/Transform.spec.ts +0 -89
 - package/src/skia/__tests__/Vertices.spec.ts +0 -40
 - package/src/skia/__tests__/assets/Avenir-Heavy.ttf +0 -0
 - package/src/skia/__tests__/assets/DIN-Medium.ttf +0 -0
 - package/src/skia/__tests__/assets/NotoColorEmoji.ttf +0 -0
 - package/src/skia/__tests__/assets/NotoSansSC-Regular.otf +0 -0
 - package/src/skia/__tests__/assets/Pacifico-Regular.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-BlackItalic.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Bold.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Italic.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Medium.ttf +0 -0
 - package/src/skia/__tests__/assets/Roboto-Regular.ttf +0 -0
 - package/src/skia/__tests__/assets/UberMove-Medium_mono.ttf +0 -0
 - package/src/skia/__tests__/assets/bird.gif +0 -0
 - package/src/skia/__tests__/assets/box.png +0 -0
 - package/src/skia/__tests__/assets/box2.png +0 -0
 - package/src/skia/__tests__/assets/card.png +0 -0
 - package/src/skia/__tests__/assets/mask.png +0 -0
 - package/src/skia/__tests__/assets/oslo-mini.jpg +0 -0
 - package/src/skia/__tests__/assets/oslo.jpg +0 -0
 - package/src/skia/__tests__/assets/product.png +0 -0
 - package/src/skia/__tests__/assets/skia_logo.png +0 -0
 - package/src/skia/__tests__/assets/skia_logo_jpeg.jpg +0 -0
 - package/src/skia/__tests__/assets/tiger.svg +0 -724
 - package/src/skia/__tests__/assets/zurich.jpg +0 -0
 - package/src/skia/__tests__/setup.ts +0 -27
 - package/src/sksg/__tests__/Simple.spec.tsx +0 -148
 
| 
         @@ -1,109 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { checkImage, docPath } from "../../../__tests__/setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import { Circle } from "../../components";
         
     | 
| 
       5 
     | 
    
         
            -
            import { surface, importSkia } from "../setup";
         
     | 
| 
       6 
     | 
    
         
            -
             
     | 
| 
       7 
     | 
    
         
            -
            describe("Offscreen Drawings", () => {
         
     | 
| 
       8 
     | 
    
         
            -
              it("Should use the canvas API to build an image", async () => {
         
     | 
| 
       9 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       10 
     | 
    
         
            -
                const raw = await surface.eval(
         
     | 
| 
       11 
     | 
    
         
            -
                  (Skia, ctx) => {
         
     | 
| 
       12 
     | 
    
         
            -
                    const r = ctx.width / 2;
         
     | 
| 
       13 
     | 
    
         
            -
                    const offscreen = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       14 
     | 
    
         
            -
                    if (!offscreen) {
         
     | 
| 
       15 
     | 
    
         
            -
                      throw new Error("Could not create offscreen surface");
         
     | 
| 
       16 
     | 
    
         
            -
                    }
         
     | 
| 
       17 
     | 
    
         
            -
                    const canvas = offscreen.getCanvas();
         
     | 
| 
       18 
     | 
    
         
            -
                    const paint = Skia.Paint();
         
     | 
| 
       19 
     | 
    
         
            -
                    paint.setColor(Skia.Color("lightblue"));
         
     | 
| 
       20 
     | 
    
         
            -
                    canvas.drawCircle(r, r, r, paint);
         
     | 
| 
       21 
     | 
    
         
            -
                    offscreen.flush();
         
     | 
| 
       22 
     | 
    
         
            -
                    return offscreen.makeImageSnapshot().encodeToBase64();
         
     | 
| 
       23 
     | 
    
         
            -
                  },
         
     | 
| 
       24 
     | 
    
         
            -
                  { width, height }
         
     | 
| 
       25 
     | 
    
         
            -
                );
         
     | 
| 
       26 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       27 
     | 
    
         
            -
                const data = Skia.Data.fromBase64(raw);
         
     | 
| 
       28 
     | 
    
         
            -
                const image = Skia.Image.MakeImageFromEncoded(data)!;
         
     | 
| 
       29 
     | 
    
         
            -
                expect(data).toBeDefined();
         
     | 
| 
       30 
     | 
    
         
            -
                checkImage(image, docPath("offscreen/circle.png"));
         
     | 
| 
       31 
     | 
    
         
            -
              });
         
     | 
| 
       32 
     | 
    
         
            -
              it("Should transfer one surface image to another", async () => {
         
     | 
| 
       33 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       34 
     | 
    
         
            -
                const raw = await surface.eval(
         
     | 
| 
       35 
     | 
    
         
            -
                  (Skia, ctx) => {
         
     | 
| 
       36 
     | 
    
         
            -
                    const r = ctx.width / 2;
         
     | 
| 
       37 
     | 
    
         
            -
                    const backSurface = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       38 
     | 
    
         
            -
                    const frontSurface = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       39 
     | 
    
         
            -
                    if (!backSurface || !frontSurface) {
         
     | 
| 
       40 
     | 
    
         
            -
                      throw new Error("Could not create offscreen surface");
         
     | 
| 
       41 
     | 
    
         
            -
                    }
         
     | 
| 
       42 
     | 
    
         
            -
                    const canvas = backSurface.getCanvas();
         
     | 
| 
       43 
     | 
    
         
            -
                    const paint = Skia.Paint();
         
     | 
| 
       44 
     | 
    
         
            -
                    paint.setColor(Skia.Color("lightblue"));
         
     | 
| 
       45 
     | 
    
         
            -
                    canvas.drawCircle(r, r, r, paint);
         
     | 
| 
       46 
     | 
    
         
            -
                    backSurface.flush();
         
     | 
| 
       47 
     | 
    
         
            -
                    const image = backSurface.makeImageSnapshot();
         
     | 
| 
       48 
     | 
    
         
            -
                    frontSurface.getCanvas().drawImage(image, 0, 0);
         
     | 
| 
       49 
     | 
    
         
            -
                    return frontSurface.makeImageSnapshot().encodeToBase64();
         
     | 
| 
       50 
     | 
    
         
            -
                  },
         
     | 
| 
       51 
     | 
    
         
            -
                  { width, height }
         
     | 
| 
       52 
     | 
    
         
            -
                );
         
     | 
| 
       53 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       54 
     | 
    
         
            -
                const data = Skia.Data.fromBase64(raw);
         
     | 
| 
       55 
     | 
    
         
            -
                const image = Skia.Image.MakeImageFromEncoded(data)!;
         
     | 
| 
       56 
     | 
    
         
            -
                expect(data).toBeDefined();
         
     | 
| 
       57 
     | 
    
         
            -
                checkImage(image, docPath("offscreen/circle.png"));
         
     | 
| 
       58 
     | 
    
         
            -
              });
         
     | 
| 
       59 
     | 
    
         
            -
             
     | 
| 
       60 
     | 
    
         
            -
              it("Should render to multiple offscreen surfaces at once (1)", async () => {
         
     | 
| 
       61 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       62 
     | 
    
         
            -
                const raw = await surface.eval(
         
     | 
| 
       63 
     | 
    
         
            -
                  (Skia, ctx) => {
         
     | 
| 
       64 
     | 
    
         
            -
                    const r = ctx.width / 4;
         
     | 
| 
       65 
     | 
    
         
            -
                    const backSurface1 = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       66 
     | 
    
         
            -
                    const backSurface2 = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       67 
     | 
    
         
            -
                    const frontSurface = Skia.Surface.MakeOffscreen(ctx.width, ctx.height)!;
         
     | 
| 
       68 
     | 
    
         
            -
                    if (!backSurface1 || !backSurface2 || !frontSurface) {
         
     | 
| 
       69 
     | 
    
         
            -
                      throw new Error("Could not create offscreen surface");
         
     | 
| 
       70 
     | 
    
         
            -
                    }
         
     | 
| 
       71 
     | 
    
         
            -
                    // Paint to first surface
         
     | 
| 
       72 
     | 
    
         
            -
                    const canvas1 = backSurface1.getCanvas();
         
     | 
| 
       73 
     | 
    
         
            -
                    const paint1 = Skia.Paint();
         
     | 
| 
       74 
     | 
    
         
            -
                    paint1.setColor(Skia.Color("lightblue"));
         
     | 
| 
       75 
     | 
    
         
            -
                    canvas1.drawCircle(r, r, r, paint1);
         
     | 
| 
       76 
     | 
    
         
            -
                    backSurface1.flush();
         
     | 
| 
       77 
     | 
    
         
            -
             
     | 
| 
       78 
     | 
    
         
            -
                    // Paint to second surface
         
     | 
| 
       79 
     | 
    
         
            -
                    const canvas2 = backSurface2.getCanvas();
         
     | 
| 
       80 
     | 
    
         
            -
                    const paint2 = Skia.Paint();
         
     | 
| 
       81 
     | 
    
         
            -
                    paint2.setColor(Skia.Color("magenta"));
         
     | 
| 
       82 
     | 
    
         
            -
                    canvas2.drawCircle(r, r, r / 2, paint2);
         
     | 
| 
       83 
     | 
    
         
            -
                    backSurface2.flush();
         
     | 
| 
       84 
     | 
    
         
            -
             
     | 
| 
       85 
     | 
    
         
            -
                    const image1 = backSurface1.makeImageSnapshot();
         
     | 
| 
       86 
     | 
    
         
            -
                    const image2 = backSurface2.makeImageSnapshot();
         
     | 
| 
       87 
     | 
    
         
            -
                    frontSurface.getCanvas().drawImage(image1, 0, 0);
         
     | 
| 
       88 
     | 
    
         
            -
                    frontSurface.getCanvas().drawImage(image2, ctx.width / 2, 0);
         
     | 
| 
       89 
     | 
    
         
            -
                    return frontSurface.makeImageSnapshot().encodeToBase64();
         
     | 
| 
       90 
     | 
    
         
            -
                  },
         
     | 
| 
       91 
     | 
    
         
            -
                  { width, height }
         
     | 
| 
       92 
     | 
    
         
            -
                );
         
     | 
| 
       93 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       94 
     | 
    
         
            -
                const data = Skia.Data.fromBase64(raw);
         
     | 
| 
       95 
     | 
    
         
            -
                const image = Skia.Image.MakeImageFromEncoded(data)!;
         
     | 
| 
       96 
     | 
    
         
            -
                expect(data).toBeDefined();
         
     | 
| 
       97 
     | 
    
         
            -
                checkImage(image, docPath("offscreen/multiple_circles.png"));
         
     | 
| 
       98 
     | 
    
         
            -
              });
         
     | 
| 
       99 
     | 
    
         
            -
              it("Should use the React API to build an image", async () => {
         
     | 
| 
       100 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       101 
     | 
    
         
            -
                const { drawAsImage } = importSkia();
         
     | 
| 
       102 
     | 
    
         
            -
                const r = width / 2;
         
     | 
| 
       103 
     | 
    
         
            -
                const image = await drawAsImage(
         
     | 
| 
       104 
     | 
    
         
            -
                  <Circle r={r} cx={r} cy={r} color="lightblue" />,
         
     | 
| 
       105 
     | 
    
         
            -
                  { width, height }
         
     | 
| 
       106 
     | 
    
         
            -
                );
         
     | 
| 
       107 
     | 
    
         
            -
                checkImage(image, docPath("offscreen/circle.png"));
         
     | 
| 
       108 
     | 
    
         
            -
              });
         
     | 
| 
       109 
     | 
    
         
            -
            });
         
     | 
| 
         @@ -1,301 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import {
         
     | 
| 
       4 
     | 
    
         
            -
              height as wHeight,
         
     | 
| 
       5 
     | 
    
         
            -
              importSkia,
         
     | 
| 
       6 
     | 
    
         
            -
              surface,
         
     | 
| 
       7 
     | 
    
         
            -
              width as wWidth,
         
     | 
| 
       8 
     | 
    
         
            -
              images,
         
     | 
| 
       9 
     | 
    
         
            -
            } from "../setup";
         
     | 
| 
       10 
     | 
    
         
            -
            import { processResult, checkImage } from "../../../__tests__/setup";
         
     | 
| 
       11 
     | 
    
         
            -
            import {
         
     | 
| 
       12 
     | 
    
         
            -
              ColorShader,
         
     | 
| 
       13 
     | 
    
         
            -
              Fill,
         
     | 
| 
       14 
     | 
    
         
            -
              Group,
         
     | 
| 
       15 
     | 
    
         
            -
              Image,
         
     | 
| 
       16 
     | 
    
         
            -
              ImageShader,
         
     | 
| 
       17 
     | 
    
         
            -
              Paint,
         
     | 
| 
       18 
     | 
    
         
            -
              RoundedRect,
         
     | 
| 
       19 
     | 
    
         
            -
            } from "../../components";
         
     | 
| 
       20 
     | 
    
         
            -
            import { setupSkia } from "../../../skia/__tests__/setup";
         
     | 
| 
       21 
     | 
    
         
            -
            import { fitRects } from "../../../dom/nodes/datatypes/Fitting";
         
     | 
| 
       22 
     | 
    
         
            -
             
     | 
| 
       23 
     | 
    
         
            -
            describe("Opacity", () => {
         
     | 
| 
       24 
     | 
    
         
            -
              it("Build reference result", async () => {
         
     | 
| 
       25 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       26 
     | 
    
         
            -
                  <>
         
     | 
| 
       27 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       28 
     | 
    
         
            -
                    <Fill color="rgba(0, 0, 255, 0.25)" />
         
     | 
| 
       29 
     | 
    
         
            -
                  </>
         
     | 
| 
       30 
     | 
    
         
            -
                );
         
     | 
| 
       31 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/violet.png");
         
     | 
| 
       32 
     | 
    
         
            -
              });
         
     | 
| 
       33 
     | 
    
         
            -
              it("Should multiply multiply the color opacity (1)", async () => {
         
     | 
| 
       34 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       35 
     | 
    
         
            -
                  <>
         
     | 
| 
       36 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       37 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       38 
     | 
    
         
            -
                      <Fill color="rgba(0, 0, 255, 0.5)" />
         
     | 
| 
       39 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       40 
     | 
    
         
            -
                  </>
         
     | 
| 
       41 
     | 
    
         
            -
                );
         
     | 
| 
       42 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/violet.png");
         
     | 
| 
       43 
     | 
    
         
            -
              });
         
     | 
| 
       44 
     | 
    
         
            -
              it("Should multiply multiply the color opacity (2)", async () => {
         
     | 
| 
       45 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       46 
     | 
    
         
            -
                  <>
         
     | 
| 
       47 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       48 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       49 
     | 
    
         
            -
                      <Group opacity={0.5}>
         
     | 
| 
       50 
     | 
    
         
            -
                        <Fill color="blue" />
         
     | 
| 
       51 
     | 
    
         
            -
                      </Group>
         
     | 
| 
       52 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       53 
     | 
    
         
            -
                  </>
         
     | 
| 
       54 
     | 
    
         
            -
                );
         
     | 
| 
       55 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/violet.png");
         
     | 
| 
       56 
     | 
    
         
            -
              });
         
     | 
| 
       57 
     | 
    
         
            -
              it("Should multiply the opacity to 0", async () => {
         
     | 
| 
       58 
     | 
    
         
            -
                const { rect, rrect } = importSkia();
         
     | 
| 
       59 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       60 
     | 
    
         
            -
                const r = width * 0.5;
         
     | 
| 
       61 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       62 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       63 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       64 
     | 
    
         
            -
                    <Group opacity={0}>
         
     | 
| 
       65 
     | 
    
         
            -
                      <RoundedRect
         
     | 
| 
       66 
     | 
    
         
            -
                        rect={rrect(rect(0, 0, r, r), r, r)}
         
     | 
| 
       67 
     | 
    
         
            -
                        color="rgba(0, 0, 0, 0.2)"
         
     | 
| 
       68 
     | 
    
         
            -
                      />
         
     | 
| 
       69 
     | 
    
         
            -
                      <RoundedRect
         
     | 
| 
       70 
     | 
    
         
            -
                        rect={rrect(rect(0, 0, r / 2, r / 2), r, r)}
         
     | 
| 
       71 
     | 
    
         
            -
                        color="white"
         
     | 
| 
       72 
     | 
    
         
            -
                      />
         
     | 
| 
       73 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       74 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       75 
     | 
    
         
            -
                );
         
     | 
| 
       76 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/opacity-multiplication.png");
         
     | 
| 
       77 
     | 
    
         
            -
              });
         
     | 
| 
       78 
     | 
    
         
            -
              it("Should build a reference result for the opacity", () => {
         
     | 
| 
       79 
     | 
    
         
            -
                const { surface: ckSurface, canvas, Skia } = setupSkia(wWidth, wHeight);
         
     | 
| 
       80 
     | 
    
         
            -
                const { rect, rrect } = importSkia();
         
     | 
| 
       81 
     | 
    
         
            -
                const p1 = Skia.Paint();
         
     | 
| 
       82 
     | 
    
         
            -
                const r = wWidth * 0.5;
         
     | 
| 
       83 
     | 
    
         
            -
             
     | 
| 
       84 
     | 
    
         
            -
                p1.setColor(Skia.Color("lightblue"));
         
     | 
| 
       85 
     | 
    
         
            -
                p1.setAlphaf(0.5);
         
     | 
| 
       86 
     | 
    
         
            -
                canvas.drawPaint(p1);
         
     | 
| 
       87 
     | 
    
         
            -
             
     | 
| 
       88 
     | 
    
         
            -
                const p2 = Skia.Paint();
         
     | 
| 
       89 
     | 
    
         
            -
                p2.setColor(Skia.Color("rgba(0, 0, 0, 1)"));
         
     | 
| 
       90 
     | 
    
         
            -
                p2.setAlphaf(0.2 * 0.5 * 0.5);
         
     | 
| 
       91 
     | 
    
         
            -
                canvas.drawRRect(rrect(rect(0, 0, r, r), r, r), p2);
         
     | 
| 
       92 
     | 
    
         
            -
             
     | 
| 
       93 
     | 
    
         
            -
                const p3 = Skia.Paint();
         
     | 
| 
       94 
     | 
    
         
            -
                p3.setColor(Skia.Color("white"));
         
     | 
| 
       95 
     | 
    
         
            -
                p3.setAlphaf(0.5 * 0.5);
         
     | 
| 
       96 
     | 
    
         
            -
                canvas.drawRRect(rrect(rect(0, 0, r / 2, r / 2), r, r), p3);
         
     | 
| 
       97 
     | 
    
         
            -
             
     | 
| 
       98 
     | 
    
         
            -
                processResult(ckSurface, "snapshots/drawings/opacity-multiplication2.png");
         
     | 
| 
       99 
     | 
    
         
            -
              });
         
     | 
| 
       100 
     | 
    
         
            -
              it("Should multiply the opacity to 0.25", async () => {
         
     | 
| 
       101 
     | 
    
         
            -
                const { rect, rrect } = importSkia();
         
     | 
| 
       102 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       103 
     | 
    
         
            -
                const r = width * 0.5;
         
     | 
| 
       104 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       105 
     | 
    
         
            -
                  <Group opacity={0.5}>
         
     | 
| 
       106 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       107 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       108 
     | 
    
         
            -
                      <RoundedRect
         
     | 
| 
       109 
     | 
    
         
            -
                        rect={rrect(rect(0, 0, r, r), r, r)}
         
     | 
| 
       110 
     | 
    
         
            -
                        color="rgba(0, 0, 0, 0.2)"
         
     | 
| 
       111 
     | 
    
         
            -
                      />
         
     | 
| 
       112 
     | 
    
         
            -
                      <RoundedRect
         
     | 
| 
       113 
     | 
    
         
            -
                        rect={rrect(rect(0, 0, r / 2, r / 2), r, r)}
         
     | 
| 
       114 
     | 
    
         
            -
                        color="white"
         
     | 
| 
       115 
     | 
    
         
            -
                      />
         
     | 
| 
       116 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       117 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       118 
     | 
    
         
            -
                );
         
     | 
| 
       119 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/opacity-multiplication2.png");
         
     | 
| 
       120 
     | 
    
         
            -
              });
         
     | 
| 
       121 
     | 
    
         
            -
              it("Should build a reference result for shader opacity", () => {
         
     | 
| 
       122 
     | 
    
         
            -
                const { surface: ckSurface, Skia, canvas } = setupSkia(wWidth, wHeight);
         
     | 
| 
       123 
     | 
    
         
            -
                canvas.drawColor(Skia.Color("white"));
         
     | 
| 
       124 
     | 
    
         
            -
                const paint = Skia.Paint();
         
     | 
| 
       125 
     | 
    
         
            -
                paint.setShader(Skia.Shader.MakeColor(Skia.Color("lightblue")));
         
     | 
| 
       126 
     | 
    
         
            -
                paint.setAlphaf(0.5);
         
     | 
| 
       127 
     | 
    
         
            -
                canvas.drawPaint(paint);
         
     | 
| 
       128 
     | 
    
         
            -
                processResult(ckSurface, "snapshots/drawings/shader-opacity-reference.png");
         
     | 
| 
       129 
     | 
    
         
            -
              });
         
     | 
| 
       130 
     | 
    
         
            -
              it("Should set shader opacity (1)", async () => {
         
     | 
| 
       131 
     | 
    
         
            -
                let image = await surface.draw(
         
     | 
| 
       132 
     | 
    
         
            -
                  <>
         
     | 
| 
       133 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       134 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       135 
     | 
    
         
            -
                      <ColorShader color="lightblue" />
         
     | 
| 
       136 
     | 
    
         
            -
                      <Fill />
         
     | 
| 
       137 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       138 
     | 
    
         
            -
                  </>
         
     | 
| 
       139 
     | 
    
         
            -
                );
         
     | 
| 
       140 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/shader-opacity-reference.png");
         
     | 
| 
       141 
     | 
    
         
            -
                image = await surface.draw(
         
     | 
| 
       142 
     | 
    
         
            -
                  <>
         
     | 
| 
       143 
     | 
    
         
            -
                    <Fill color="white" />
         
     | 
| 
       144 
     | 
    
         
            -
                    <Fill opacity={0.5}>
         
     | 
| 
       145 
     | 
    
         
            -
                      <ColorShader color="lightblue" />
         
     | 
| 
       146 
     | 
    
         
            -
                    </Fill>
         
     | 
| 
       147 
     | 
    
         
            -
                  </>
         
     | 
| 
       148 
     | 
    
         
            -
                );
         
     | 
| 
       149 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/shader-opacity-reference.png");
         
     | 
| 
       150 
     | 
    
         
            -
              });
         
     | 
| 
       151 
     | 
    
         
            -
              it("Should multiply the opacity to 0.25 using a Shader", async () => {
         
     | 
| 
       152 
     | 
    
         
            -
                const { rect, rrect } = importSkia();
         
     | 
| 
       153 
     | 
    
         
            -
                const { width } = surface;
         
     | 
| 
       154 
     | 
    
         
            -
                const r = width * 0.5;
         
     | 
| 
       155 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       156 
     | 
    
         
            -
                  <Group opacity={0.5}>
         
     | 
| 
       157 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       158 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       159 
     | 
    
         
            -
                      <RoundedRect rect={rrect(rect(0, 0, r, r), r, r)} opacity={0.2}>
         
     | 
| 
       160 
     | 
    
         
            -
                        <ColorShader color="black" />
         
     | 
| 
       161 
     | 
    
         
            -
                      </RoundedRect>
         
     | 
| 
       162 
     | 
    
         
            -
                      <RoundedRect
         
     | 
| 
       163 
     | 
    
         
            -
                        rect={rrect(rect(0, 0, r / 2, r / 2), r, r)}
         
     | 
| 
       164 
     | 
    
         
            -
                        color="white"
         
     | 
| 
       165 
     | 
    
         
            -
                      />
         
     | 
| 
       166 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       167 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       168 
     | 
    
         
            -
                );
         
     | 
| 
       169 
     | 
    
         
            -
                checkImage(image, "snapshots/drawings/opacity-multiplication2.png");
         
     | 
| 
       170 
     | 
    
         
            -
              });
         
     | 
| 
       171 
     | 
    
         
            -
              it("Build reference result (2)", () => {
         
     | 
| 
       172 
     | 
    
         
            -
                const {
         
     | 
| 
       173 
     | 
    
         
            -
                  surface: ckSurface,
         
     | 
| 
       174 
     | 
    
         
            -
                  Skia,
         
     | 
| 
       175 
     | 
    
         
            -
                  canvas,
         
     | 
| 
       176 
     | 
    
         
            -
                  width,
         
     | 
| 
       177 
     | 
    
         
            -
                  height,
         
     | 
| 
       178 
     | 
    
         
            -
                } = setupSkia(wWidth, wHeight);
         
     | 
| 
       179 
     | 
    
         
            -
                const { oslo } = images;
         
     | 
| 
       180 
     | 
    
         
            -
                canvas.drawColor(Skia.Color("lightblue"));
         
     | 
| 
       181 
     | 
    
         
            -
                const paint = Skia.Paint();
         
     | 
| 
       182 
     | 
    
         
            -
                paint.setAlphaf(0.5);
         
     | 
| 
       183 
     | 
    
         
            -
                const { src, dst } = fitRects(
         
     | 
| 
       184 
     | 
    
         
            -
                  "cover",
         
     | 
| 
       185 
     | 
    
         
            -
                  {
         
     | 
| 
       186 
     | 
    
         
            -
                    x: 0,
         
     | 
| 
       187 
     | 
    
         
            -
                    y: 0,
         
     | 
| 
       188 
     | 
    
         
            -
                    width: oslo.width(),
         
     | 
| 
       189 
     | 
    
         
            -
                    height: oslo.height(),
         
     | 
| 
       190 
     | 
    
         
            -
                  },
         
     | 
| 
       191 
     | 
    
         
            -
                  { x: 0, y: 0, width, height }
         
     | 
| 
       192 
     | 
    
         
            -
                );
         
     | 
| 
       193 
     | 
    
         
            -
                canvas.drawImageRect(oslo, src, dst, paint);
         
     | 
| 
       194 
     | 
    
         
            -
                processResult(ckSurface, "snapshots/drawings/opacity-image.png");
         
     | 
| 
       195 
     | 
    
         
            -
              });
         
     | 
| 
       196 
     | 
    
         
            -
              it("Should apply opacity to an image (1)", async () => {
         
     | 
| 
       197 
     | 
    
         
            -
                const { oslo } = images;
         
     | 
| 
       198 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       199 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       200 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       201 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       202 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       203 
     | 
    
         
            -
                      <Image
         
     | 
| 
       204 
     | 
    
         
            -
                        image={oslo}
         
     | 
| 
       205 
     | 
    
         
            -
                        x={0}
         
     | 
| 
       206 
     | 
    
         
            -
                        y={0}
         
     | 
| 
       207 
     | 
    
         
            -
                        width={width}
         
     | 
| 
       208 
     | 
    
         
            -
                        height={height}
         
     | 
| 
       209 
     | 
    
         
            -
                        fit="cover"
         
     | 
| 
       210 
     | 
    
         
            -
                      />
         
     | 
| 
       211 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       212 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       213 
     | 
    
         
            -
                );
         
     | 
| 
       214 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/opacity-image.png");
         
     | 
| 
       215 
     | 
    
         
            -
              });
         
     | 
| 
       216 
     | 
    
         
            -
              it("Should apply opacity to an image (2)", async () => {
         
     | 
| 
       217 
     | 
    
         
            -
                const { oslo } = images;
         
     | 
| 
       218 
     | 
    
         
            -
                const {} = importSkia();
         
     | 
| 
       219 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       220 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       221 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       222 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       223 
     | 
    
         
            -
                    <Image
         
     | 
| 
       224 
     | 
    
         
            -
                      opacity={0.5}
         
     | 
| 
       225 
     | 
    
         
            -
                      image={oslo}
         
     | 
| 
       226 
     | 
    
         
            -
                      x={0}
         
     | 
| 
       227 
     | 
    
         
            -
                      y={0}
         
     | 
| 
       228 
     | 
    
         
            -
                      width={width}
         
     | 
| 
       229 
     | 
    
         
            -
                      height={height}
         
     | 
| 
       230 
     | 
    
         
            -
                      fit="cover"
         
     | 
| 
       231 
     | 
    
         
            -
                    />
         
     | 
| 
       232 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       233 
     | 
    
         
            -
                );
         
     | 
| 
       234 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/opacity-image.png");
         
     | 
| 
       235 
     | 
    
         
            -
              });
         
     | 
| 
       236 
     | 
    
         
            -
              it("Should apply opacity to an image shader (1)", async () => {
         
     | 
| 
       237 
     | 
    
         
            -
                const { oslo } = images;
         
     | 
| 
       238 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       239 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       240 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       241 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       242 
     | 
    
         
            -
                    <Fill opacity={0.5}>
         
     | 
| 
       243 
     | 
    
         
            -
                      <ImageShader
         
     | 
| 
       244 
     | 
    
         
            -
                        image={oslo}
         
     | 
| 
       245 
     | 
    
         
            -
                        x={0}
         
     | 
| 
       246 
     | 
    
         
            -
                        y={0}
         
     | 
| 
       247 
     | 
    
         
            -
                        width={width}
         
     | 
| 
       248 
     | 
    
         
            -
                        height={height}
         
     | 
| 
       249 
     | 
    
         
            -
                        fit="cover"
         
     | 
| 
       250 
     | 
    
         
            -
                      />
         
     | 
| 
       251 
     | 
    
         
            -
                    </Fill>
         
     | 
| 
       252 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       253 
     | 
    
         
            -
                );
         
     | 
| 
       254 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/opacity-image.png");
         
     | 
| 
       255 
     | 
    
         
            -
              });
         
     | 
| 
       256 
     | 
    
         
            -
              it("Should apply opacity to an image shader (2)", async () => {
         
     | 
| 
       257 
     | 
    
         
            -
                const { oslo } = images;
         
     | 
| 
       258 
     | 
    
         
            -
                const {} = importSkia();
         
     | 
| 
       259 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       260 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       261 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       262 
     | 
    
         
            -
                    <Fill color="lightblue" />
         
     | 
| 
       263 
     | 
    
         
            -
                    <Group opacity={0.5}>
         
     | 
| 
       264 
     | 
    
         
            -
                      <Fill>
         
     | 
| 
       265 
     | 
    
         
            -
                        <ImageShader
         
     | 
| 
       266 
     | 
    
         
            -
                          image={oslo}
         
     | 
| 
       267 
     | 
    
         
            -
                          x={0}
         
     | 
| 
       268 
     | 
    
         
            -
                          y={0}
         
     | 
| 
       269 
     | 
    
         
            -
                          width={width}
         
     | 
| 
       270 
     | 
    
         
            -
                          height={height}
         
     | 
| 
       271 
     | 
    
         
            -
                          fit="cover"
         
     | 
| 
       272 
     | 
    
         
            -
                        />
         
     | 
| 
       273 
     | 
    
         
            -
                      </Fill>
         
     | 
| 
       274 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       275 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       276 
     | 
    
         
            -
                );
         
     | 
| 
       277 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/opacity-image.png");
         
     | 
| 
       278 
     | 
    
         
            -
              });
         
     | 
| 
       279 
     | 
    
         
            -
              it("Should apply opacity on a layer (1)", async () => {
         
     | 
| 
       280 
     | 
    
         
            -
                const {} = importSkia();
         
     | 
| 
       281 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       282 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       283 
     | 
    
         
            -
                    <Group layer={<Paint opacity={0.5} />}>
         
     | 
| 
       284 
     | 
    
         
            -
                      <Fill color="lightblue" />
         
     | 
| 
       285 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       286 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       287 
     | 
    
         
            -
                );
         
     | 
| 
       288 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/semi-transparent-layer.png");
         
     | 
| 
       289 
     | 
    
         
            -
              });
         
     | 
| 
       290 
     | 
    
         
            -
              it("Should apply opacity on a layer (2)", async () => {
         
     | 
| 
       291 
     | 
    
         
            -
                const {} = importSkia();
         
     | 
| 
       292 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       293 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       294 
     | 
    
         
            -
                    <Group layer={<Paint opacity={0} />}>
         
     | 
| 
       295 
     | 
    
         
            -
                      <Fill color="lightblue" />
         
     | 
| 
       296 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       297 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       298 
     | 
    
         
            -
                );
         
     | 
| 
       299 
     | 
    
         
            -
                checkImage(img, "snapshots/drawings/transparent-layer.png");
         
     | 
| 
       300 
     | 
    
         
            -
              });
         
     | 
| 
       301 
     | 
    
         
            -
            });
         
     | 
| 
         @@ -1,230 +0,0 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            import React from "react";
         
     | 
| 
       2 
     | 
    
         
            -
             
     | 
| 
       3 
     | 
    
         
            -
            import { surface, importSkia } from "../setup";
         
     | 
| 
       4 
     | 
    
         
            -
            import {
         
     | 
| 
       5 
     | 
    
         
            -
              Circle,
         
     | 
| 
       6 
     | 
    
         
            -
              Fill,
         
     | 
| 
       7 
     | 
    
         
            -
              Group,
         
     | 
| 
       8 
     | 
    
         
            -
              LinearGradient,
         
     | 
| 
       9 
     | 
    
         
            -
              Paint,
         
     | 
| 
       10 
     | 
    
         
            -
              Path,
         
     | 
| 
       11 
     | 
    
         
            -
              SweepGradient,
         
     | 
| 
       12 
     | 
    
         
            -
            } from "../../components";
         
     | 
| 
       13 
     | 
    
         
            -
            import { checkImage, docPath } from "../../../__tests__/setup";
         
     | 
| 
       14 
     | 
    
         
            -
            import { fitbox } from "../../components/shapes/FitBox";
         
     | 
| 
       15 
     | 
    
         
            -
             
     | 
| 
       16 
     | 
    
         
            -
            const blendModes = [
         
     | 
| 
       17 
     | 
    
         
            -
              "clear",
         
     | 
| 
       18 
     | 
    
         
            -
              "src",
         
     | 
| 
       19 
     | 
    
         
            -
              "dst",
         
     | 
| 
       20 
     | 
    
         
            -
              "srcOver",
         
     | 
| 
       21 
     | 
    
         
            -
              "dstOver",
         
     | 
| 
       22 
     | 
    
         
            -
              "srcIn",
         
     | 
| 
       23 
     | 
    
         
            -
              "dstIn",
         
     | 
| 
       24 
     | 
    
         
            -
              "srcOut",
         
     | 
| 
       25 
     | 
    
         
            -
              "dstOut",
         
     | 
| 
       26 
     | 
    
         
            -
              "srcATop",
         
     | 
| 
       27 
     | 
    
         
            -
              "dstATop",
         
     | 
| 
       28 
     | 
    
         
            -
              "xor",
         
     | 
| 
       29 
     | 
    
         
            -
              "plus",
         
     | 
| 
       30 
     | 
    
         
            -
              "modulate",
         
     | 
| 
       31 
     | 
    
         
            -
              "screen",
         
     | 
| 
       32 
     | 
    
         
            -
              "overlay",
         
     | 
| 
       33 
     | 
    
         
            -
              "darken",
         
     | 
| 
       34 
     | 
    
         
            -
              "lighten",
         
     | 
| 
       35 
     | 
    
         
            -
              "colorDodge",
         
     | 
| 
       36 
     | 
    
         
            -
              "colorBurn",
         
     | 
| 
       37 
     | 
    
         
            -
              "hardLight",
         
     | 
| 
       38 
     | 
    
         
            -
              "softLight",
         
     | 
| 
       39 
     | 
    
         
            -
              "difference",
         
     | 
| 
       40 
     | 
    
         
            -
              "exclusion",
         
     | 
| 
       41 
     | 
    
         
            -
              "multiply",
         
     | 
| 
       42 
     | 
    
         
            -
              "hue",
         
     | 
| 
       43 
     | 
    
         
            -
              "saturation",
         
     | 
| 
       44 
     | 
    
         
            -
              "color",
         
     | 
| 
       45 
     | 
    
         
            -
              "luminosity",
         
     | 
| 
       46 
     | 
    
         
            -
            ] as const;
         
     | 
| 
       47 
     | 
    
         
            -
             
     | 
| 
       48 
     | 
    
         
            -
            const SIZE = 32;
         
     | 
| 
       49 
     | 
    
         
            -
            const COLS = 256 / SIZE;
         
     | 
| 
       50 
     | 
    
         
            -
             
     | 
| 
       51 
     | 
    
         
            -
            describe("Paint", () => {
         
     | 
| 
       52 
     | 
    
         
            -
              it("should interpret the #rrggbbaa correctly", async () => {
         
     | 
| 
       53 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       54 
     | 
    
         
            -
                const { rect } = importSkia();
         
     | 
| 
       55 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       56 
     | 
    
         
            -
                  <>
         
     | 
| 
       57 
     | 
    
         
            -
                    <Group clip={rect(0, 0, width / 2, height)}>
         
     | 
| 
       58 
     | 
    
         
            -
                      <Fill color="#ff000079" />
         
     | 
| 
       59 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       60 
     | 
    
         
            -
                    <Group clip={rect(width / 2, 0, width / 2, height)}>
         
     | 
| 
       61 
     | 
    
         
            -
                      <Fill color="#ff000080" />
         
     | 
| 
       62 
     | 
    
         
            -
                    </Group>
         
     | 
| 
       63 
     | 
    
         
            -
                  </>
         
     | 
| 
       64 
     | 
    
         
            -
                );
         
     | 
| 
       65 
     | 
    
         
            -
                checkImage(image, "snapshots/paint/colors.png");
         
     | 
| 
       66 
     | 
    
         
            -
              });
         
     | 
| 
       67 
     | 
    
         
            -
              it("should accept a paint object as property", async () => {
         
     | 
| 
       68 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       69 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       70 
     | 
    
         
            -
                const paint = Skia.Paint();
         
     | 
| 
       71 
     | 
    
         
            -
                paint.setColor(Skia.Color("lightblue"));
         
     | 
| 
       72 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       73 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       74 
     | 
    
         
            -
                    <Circle
         
     | 
| 
       75 
     | 
    
         
            -
                      cx={width / 2}
         
     | 
| 
       76 
     | 
    
         
            -
                      cy={height / 2}
         
     | 
| 
       77 
     | 
    
         
            -
                      r={width / 2}
         
     | 
| 
       78 
     | 
    
         
            -
                      paint={paint}
         
     | 
| 
       79 
     | 
    
         
            -
                      color="red"
         
     | 
| 
       80 
     | 
    
         
            -
                    />
         
     | 
| 
       81 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       82 
     | 
    
         
            -
                );
         
     | 
| 
       83 
     | 
    
         
            -
                checkImage(image, "snapshots/paint/circle.png");
         
     | 
| 
       84 
     | 
    
         
            -
              });
         
     | 
| 
       85 
     | 
    
         
            -
              it("should accept a paint object as path property", async () => {
         
     | 
| 
       86 
     | 
    
         
            -
                const { Skia } = importSkia();
         
     | 
| 
       87 
     | 
    
         
            -
                const paint = Skia.Paint();
         
     | 
| 
       88 
     | 
    
         
            -
                paint.setColor(Skia.Color("lightblue"));
         
     | 
| 
       89 
     | 
    
         
            -
                const image = await surface.draw(
         
     | 
| 
       90 
     | 
    
         
            -
                  <Group>
         
     | 
| 
       91 
     | 
    
         
            -
                    <Path path="M0 0h100v100H0z" paint={paint} color="red" />
         
     | 
| 
       92 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       93 
     | 
    
         
            -
                );
         
     | 
| 
       94 
     | 
    
         
            -
                checkImage(image, "snapshots/paint/path-paint.png");
         
     | 
| 
       95 
     | 
    
         
            -
              });
         
     | 
| 
       96 
     | 
    
         
            -
              it("should display blend modes properly", async () => {
         
     | 
| 
       97 
     | 
    
         
            -
                const { Skia, rect } = importSkia();
         
     | 
| 
       98 
     | 
    
         
            -
                const src = Skia.Path.MakeFromSVGString(
         
     | 
| 
       99 
     | 
    
         
            -
                  [
         
     | 
| 
       100 
     | 
    
         
            -
                    "M170.699 148.614C135.228 184.085 100.799 213.726 74.0057 232.813C90.1873 241.166 108.534 245.913 127.998 245.913C193.121 245.913 245.909 193.124 245.909 128.001C245.909 110.165 241.926 93.2652 234.837 78.1096C217.359 99.6154 195.456 123.859 170.699 148.615V148.614Z",
         
     | 
| 
       101 
     | 
    
         
            -
                    "M254.299 1.69725C247.995 -4.60656 225.09 7.01991 194.111 30.4188C175.254 17.6079 152.513 10.089 127.998 10.089C62.8758 10.089 10.0869 62.8778 10.0869 128C10.0869 152.517 17.6079 175.254 30.4188 194.113C7.01991 225.094 -4.60656 248.001 1.69725 254.301C13.1117 265.715 78.9083 218.421 148.663 148.666C218.418 78.9109 265.715 13.1111 254.298 1.69986L254.299 1.69725Z",
         
     | 
| 
       102 
     | 
    
         
            -
                  ].join(" ")
         
     | 
| 
       103 
     | 
    
         
            -
                )!;
         
     | 
| 
       104 
     | 
    
         
            -
                const dst = Skia.Path.MakeFromSVGString(
         
     | 
| 
       105 
     | 
    
         
            -
                  [
         
     | 
| 
       106 
     | 
    
         
            -
                    "M3.75337 3.75477C10.8647 -3.35674 92.9919 -5.28784 142.454 44.1778C154.016 55.7403 163.904 67.9247 171.948 80.1734L208.991 81.7669L256 128.773L195.968 145.267C196.467 160.332 192.34 173.419 182.882 182.88C173.423 192.338 160.334 196.467 145.27 195.967L128.776 256L81.7688 208.991L80.1773 171.946C67.9284 163.902 55.7442 154.012 44.1825 142.451C-5.28603 92.9918 -3.359 10.8662 3.75637 3.75272L3.75337 3.75477ZM48.1571 79.8283C56.9032 88.5745 71.0812 88.5745 79.8252 79.8283C88.5712 71.0821 88.5712 56.9038 79.8252 48.1595C71.0791 39.4133 56.9012 39.4133 48.1571 48.1595C39.4111 56.9038 39.4111 71.0841 48.1571 79.8283Z",
         
     | 
| 
       107 
     | 
    
         
            -
                    "M195.01 222.191C184.687 211.867 183.417 199.108 191.258 191.264C199.098 183.425 211.857 184.692 222.184 195.017C235.86 208.692 242.751 238.822 240.785 240.789C238.817 242.759 208.688 235.867 195.01 222.191Z",
         
     | 
| 
       108 
     | 
    
         
            -
                  ].join(" ")
         
     | 
| 
       109 
     | 
    
         
            -
                )!;
         
     | 
| 
       110 
     | 
    
         
            -
                expect(src).toBeDefined();
         
     | 
| 
       111 
     | 
    
         
            -
                expect(dst).toBeDefined();
         
     | 
| 
       112 
     | 
    
         
            -
                const srcBox = src.computeTightBounds();
         
     | 
| 
       113 
     | 
    
         
            -
                const dstBox = dst.computeTightBounds();
         
     | 
| 
       114 
     | 
    
         
            -
                const img = await surface.draw(
         
     | 
| 
       115 
     | 
    
         
            -
                  <>
         
     | 
| 
       116 
     | 
    
         
            -
                    {blendModes.map((blendMode, i) => {
         
     | 
| 
       117 
     | 
    
         
            -
                      return (
         
     | 
| 
       118 
     | 
    
         
            -
                        <Group
         
     | 
| 
       119 
     | 
    
         
            -
                          transform={[
         
     | 
| 
       120 
     | 
    
         
            -
                            { translateX: SIZE * (i % COLS) },
         
     | 
| 
       121 
     | 
    
         
            -
                            { translateY: SIZE * Math.floor(i / COLS) },
         
     | 
| 
       122 
     | 
    
         
            -
                          ]}
         
     | 
| 
       123 
     | 
    
         
            -
                          key={blendMode}
         
     | 
| 
       124 
     | 
    
         
            -
                          layer
         
     | 
| 
       125 
     | 
    
         
            -
                        >
         
     | 
| 
       126 
     | 
    
         
            -
                          <Path
         
     | 
| 
       127 
     | 
    
         
            -
                            path={dst}
         
     | 
| 
       128 
     | 
    
         
            -
                            transform={fitbox("contain", dstBox, rect(0, 0, SIZE, SIZE))}
         
     | 
| 
       129 
     | 
    
         
            -
                            color="pink"
         
     | 
| 
       130 
     | 
    
         
            -
                          />
         
     | 
| 
       131 
     | 
    
         
            -
                          <Group layer={<Paint blendMode={blendMode} />}>
         
     | 
| 
       132 
     | 
    
         
            -
                            <Path
         
     | 
| 
       133 
     | 
    
         
            -
                              path={src}
         
     | 
| 
       134 
     | 
    
         
            -
                              color="lightblue"
         
     | 
| 
       135 
     | 
    
         
            -
                              transform={fitbox("contain", srcBox, rect(0, 0, SIZE, SIZE))}
         
     | 
| 
       136 
     | 
    
         
            -
                            />
         
     | 
| 
       137 
     | 
    
         
            -
                          </Group>
         
     | 
| 
       138 
     | 
    
         
            -
                        </Group>
         
     | 
| 
       139 
     | 
    
         
            -
                      );
         
     | 
| 
       140 
     | 
    
         
            -
                    })}
         
     | 
| 
       141 
     | 
    
         
            -
                  </>
         
     | 
| 
       142 
     | 
    
         
            -
                );
         
     | 
| 
       143 
     | 
    
         
            -
                checkImage(img, "snapshots/paint/blend-mode.png");
         
     | 
| 
       144 
     | 
    
         
            -
              });
         
     | 
| 
       145 
     | 
    
         
            -
              it("Dithering", async () => {
         
     | 
| 
       146 
     | 
    
         
            -
                const { height } = surface;
         
     | 
| 
       147 
     | 
    
         
            -
                const { vec } = importSkia();
         
     | 
| 
       148 
     | 
    
         
            -
                const c1 = "#202225ff";
         
     | 
| 
       149 
     | 
    
         
            -
                const c2 = "#141619FF";
         
     | 
| 
       150 
     | 
    
         
            -
                async function drawGradientWithDither(dither: boolean) {
         
     | 
| 
       151 
     | 
    
         
            -
                  return surface.draw(
         
     | 
| 
       152 
     | 
    
         
            -
                    <Fill dither={dither}>
         
     | 
| 
       153 
     | 
    
         
            -
                      <LinearGradient
         
     | 
| 
       154 
     | 
    
         
            -
                        start={vec(0, 0)}
         
     | 
| 
       155 
     | 
    
         
            -
                        end={vec(0, height)}
         
     | 
| 
       156 
     | 
    
         
            -
                        colors={[c1, c2]}
         
     | 
| 
       157 
     | 
    
         
            -
                      />
         
     | 
| 
       158 
     | 
    
         
            -
                    </Fill>
         
     | 
| 
       159 
     | 
    
         
            -
                  );
         
     | 
| 
       160 
     | 
    
         
            -
                }
         
     | 
| 
       161 
     | 
    
         
            -
                const withDither = await drawGradientWithDither(true);
         
     | 
| 
       162 
     | 
    
         
            -
                const withoutDither = await drawGradientWithDither(false);
         
     | 
| 
       163 
     | 
    
         
            -
                checkImage(withDither, "snapshots/paint/dither.png");
         
     | 
| 
       164 
     | 
    
         
            -
                checkImage(withoutDither, "snapshots/paint/without-dither.png");
         
     | 
| 
       165 
     | 
    
         
            -
                checkImage(withoutDither, "snapshots/paint/dither.png", {
         
     | 
| 
       166 
     | 
    
         
            -
                  shouldFail: true,
         
     | 
| 
       167 
     | 
    
         
            -
                  threshold: 0,
         
     | 
| 
       168 
     | 
    
         
            -
                });
         
     | 
| 
       169 
     | 
    
         
            -
              });
         
     | 
| 
       170 
     | 
    
         
            -
              it("should override colors", async () => {
         
     | 
| 
       171 
     | 
    
         
            -
                const { vec } = importSkia();
         
     | 
| 
       172 
     | 
    
         
            -
                const strokeWidth = 10;
         
     | 
| 
       173 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       174 
     | 
    
         
            -
                const c = vec(width / 2, height / 2);
         
     | 
| 
       175 
     | 
    
         
            -
                const r = (width - strokeWidth) / 2;
         
     | 
| 
       176 
     | 
    
         
            -
                const result = await surface.draw(
         
     | 
| 
       177 
     | 
    
         
            -
                  <>
         
     | 
| 
       178 
     | 
    
         
            -
                    <Circle c={c} r={r} color="transparent">
         
     | 
| 
       179 
     | 
    
         
            -
                      <Paint color="lightblue" />
         
     | 
| 
       180 
     | 
    
         
            -
                      <Paint color="#adbce6" style="stroke" strokeWidth={strokeWidth} />
         
     | 
| 
       181 
     | 
    
         
            -
                      <Paint color="#ade6d8" style="stroke" strokeWidth={strokeWidth / 2} />
         
     | 
| 
       182 
     | 
    
         
            -
                    </Circle>
         
     | 
| 
       183 
     | 
    
         
            -
                  </>
         
     | 
| 
       184 
     | 
    
         
            -
                );
         
     | 
| 
       185 
     | 
    
         
            -
                checkImage(result, docPath("paint/stroke.png"));
         
     | 
| 
       186 
     | 
    
         
            -
              });
         
     | 
| 
       187 
     | 
    
         
            -
              it("colors don't influence opacity (1)", async () => {
         
     | 
| 
       188 
     | 
    
         
            -
                const { vec } = importSkia();
         
     | 
| 
       189 
     | 
    
         
            -
                const strokeWidth = 10;
         
     | 
| 
       190 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       191 
     | 
    
         
            -
                const c = vec(width / 2, height / 2);
         
     | 
| 
       192 
     | 
    
         
            -
                const r = (width - strokeWidth) / 2;
         
     | 
| 
       193 
     | 
    
         
            -
                const result = await surface.draw(
         
     | 
| 
       194 
     | 
    
         
            -
                  <Group color="rgba(0,0,0,0.5)">
         
     | 
| 
       195 
     | 
    
         
            -
                    <Circle c={c} r={r} color="lightblue" />
         
     | 
| 
       196 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       197 
     | 
    
         
            -
                );
         
     | 
| 
       198 
     | 
    
         
            -
                checkImage(result, docPath("paint/opaque-circle.png"));
         
     | 
| 
       199 
     | 
    
         
            -
              });
         
     | 
| 
       200 
     | 
    
         
            -
              it("colors don't influence opacity (2)", async () => {
         
     | 
| 
       201 
     | 
    
         
            -
                const { vec } = importSkia();
         
     | 
| 
       202 
     | 
    
         
            -
                const strokeWidth = 10;
         
     | 
| 
       203 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       204 
     | 
    
         
            -
                const c = vec(width / 2, height / 2);
         
     | 
| 
       205 
     | 
    
         
            -
                const r = (width - strokeWidth) / 2;
         
     | 
| 
       206 
     | 
    
         
            -
                const result = await surface.draw(
         
     | 
| 
       207 
     | 
    
         
            -
                  <Group opacity={0.5}>
         
     | 
| 
       208 
     | 
    
         
            -
                    <Circle c={c} r={r} color="lightblue" />
         
     | 
| 
       209 
     | 
    
         
            -
                  </Group>
         
     | 
| 
       210 
     | 
    
         
            -
                );
         
     | 
| 
       211 
     | 
    
         
            -
                checkImage(result, docPath("paint/semi-transparent-circle.png"));
         
     | 
| 
       212 
     | 
    
         
            -
              });
         
     | 
| 
       213 
     | 
    
         
            -
              it("test paint", async () => {
         
     | 
| 
       214 
     | 
    
         
            -
                const { vec, Skia } = importSkia();
         
     | 
| 
       215 
     | 
    
         
            -
                const strokeWidth = 10;
         
     | 
| 
       216 
     | 
    
         
            -
                const { width, height } = surface;
         
     | 
| 
       217 
     | 
    
         
            -
                const c = vec(width / 2, height / 2);
         
     | 
| 
       218 
     | 
    
         
            -
                const r = (width - strokeWidth) / 2;
         
     | 
| 
       219 
     | 
    
         
            -
                const path = Skia.Path.Make();
         
     | 
| 
       220 
     | 
    
         
            -
                path.addCircle(c.x, c.y, r);
         
     | 
| 
       221 
     | 
    
         
            -
                const result = await surface.draw(
         
     | 
| 
       222 
     | 
    
         
            -
                  <Path path={path} color="transparent">
         
     | 
| 
       223 
     | 
    
         
            -
                    <Paint style="stroke" strokeWidth={20} strokeCap="round">
         
     | 
| 
       224 
     | 
    
         
            -
                      <SweepGradient c={c} colors={["#64BC65", "#4488ff"]} />
         
     | 
| 
       225 
     | 
    
         
            -
                    </Paint>
         
     | 
| 
       226 
     | 
    
         
            -
                  </Path>
         
     | 
| 
       227 
     | 
    
         
            -
                );
         
     | 
| 
       228 
     | 
    
         
            -
                checkImage(result, docPath("paint/test-paint.png"));
         
     | 
| 
       229 
     | 
    
         
            -
              });
         
     | 
| 
       230 
     | 
    
         
            -
            });
         
     |