@shopify/react-native-skia 0.1.157 → 0.1.159

Sign up to get free protection for your applications and to get access to all the features.
Files changed (482) hide show
  1. package/android/CMakeLists.txt +35 -11
  2. package/android/build.gradle +31 -30
  3. package/android/cpp/jni/JniLoad.cpp +2 -0
  4. package/android/cpp/jni/include/JniSkiaDomView.h +89 -0
  5. package/android/cpp/rnskia-android/SkiaOpenGLRenderer.cpp +4 -3
  6. package/android/cpp/rnskia-android/SkiaOpenGLRenderer.h +4 -3
  7. package/android/src/main/java/com/shopify/reactnative/skia/RNSkiaPackage.java +2 -1
  8. package/android/src/main/java/com/shopify/reactnative/skia/SkiaDomView.java +45 -0
  9. package/android/src/main/java/com/shopify/reactnative/skia/SkiaDomViewManager.java +64 -0
  10. package/cpp/api/JsiSkContourMeasure.h +7 -5
  11. package/cpp/api/JsiSkHostObjects.h +6 -0
  12. package/cpp/api/JsiSkImageFilterFactory.h +1 -1
  13. package/cpp/api/JsiSkPaint.h +9 -2
  14. package/cpp/api/JsiSkPath.h +1 -0
  15. package/cpp/api/JsiSkRuntimeEffect.h +36 -36
  16. package/cpp/jsi/JsiHostObject.cpp +16 -28
  17. package/cpp/jsi/JsiHostObject.h +127 -7
  18. package/cpp/jsi/JsiValue.cpp +346 -0
  19. package/cpp/jsi/JsiValue.h +222 -0
  20. package/cpp/jsi/JsiValueWrapper.h +33 -5
  21. package/cpp/rnskia/RNSkDomView.cpp +220 -0
  22. package/cpp/rnskia/RNSkDomView.h +140 -0
  23. package/cpp/rnskia/RNSkJsView.cpp +0 -4
  24. package/cpp/rnskia/RNSkJsView.h +6 -4
  25. package/cpp/rnskia/RNSkManager.cpp +7 -0
  26. package/cpp/rnskia/RNSkPictureView.h +5 -8
  27. package/cpp/rnskia/RNSkView.h +113 -5
  28. package/cpp/rnskia/dom/JsiDomApi.h +167 -0
  29. package/cpp/rnskia/dom/base/BaseNodeProp.h +72 -0
  30. package/cpp/rnskia/dom/base/DerivedNodeProp.h +187 -0
  31. package/cpp/rnskia/dom/base/DrawingContext.cpp +227 -0
  32. package/cpp/rnskia/dom/base/DrawingContext.h +136 -0
  33. package/cpp/rnskia/dom/base/JsiDependencyManager.h +294 -0
  34. package/cpp/rnskia/dom/base/JsiDomDeclarationNode.h +176 -0
  35. package/cpp/rnskia/dom/base/JsiDomDrawingNode.h +50 -0
  36. package/cpp/rnskia/dom/base/JsiDomNode.h +361 -0
  37. package/cpp/rnskia/dom/base/JsiDomRenderNode.h +267 -0
  38. package/cpp/rnskia/dom/base/NodeProp.h +130 -0
  39. package/cpp/rnskia/dom/base/NodePropsContainer.h +119 -0
  40. package/cpp/rnskia/dom/nodes/JsiBackdropFilterNode.h +38 -0
  41. package/cpp/rnskia/dom/nodes/JsiBlendNode.h +112 -0
  42. package/cpp/rnskia/dom/nodes/JsiBlurMaskNode.h +78 -0
  43. package/cpp/rnskia/dom/nodes/JsiBoxNode.h +104 -0
  44. package/cpp/rnskia/dom/nodes/JsiBoxShadowNode.h +33 -0
  45. package/cpp/rnskia/dom/nodes/JsiCircleNode.h +38 -0
  46. package/cpp/rnskia/dom/nodes/JsiColorFilterNodes.h +192 -0
  47. package/cpp/rnskia/dom/nodes/JsiCustomDrawingNode.h +123 -0
  48. package/cpp/rnskia/dom/nodes/JsiDiffRectNode.h +42 -0
  49. package/cpp/rnskia/dom/nodes/JsiFillNode.h +22 -0
  50. package/cpp/rnskia/dom/nodes/JsiGlyphsNode.h +56 -0
  51. package/cpp/rnskia/dom/nodes/JsiGroupNode.h +26 -0
  52. package/cpp/rnskia/dom/nodes/JsiImageFilterNodes.h +415 -0
  53. package/cpp/rnskia/dom/nodes/JsiImageNode.h +34 -0
  54. package/cpp/rnskia/dom/nodes/JsiImageSvgNode.h +44 -0
  55. package/cpp/rnskia/dom/nodes/JsiLayerNode.h +64 -0
  56. package/cpp/rnskia/dom/nodes/JsiLineNode.h +43 -0
  57. package/cpp/rnskia/dom/nodes/JsiOvalNode.h +34 -0
  58. package/cpp/rnskia/dom/nodes/JsiPaintNode.h +77 -0
  59. package/cpp/rnskia/dom/nodes/JsiPatchNode.h +54 -0
  60. package/cpp/rnskia/dom/nodes/JsiPathEffectNodes.h +315 -0
  61. package/cpp/rnskia/dom/nodes/JsiPathNode.h +181 -0
  62. package/cpp/rnskia/dom/nodes/JsiPictureNode.h +32 -0
  63. package/cpp/rnskia/dom/nodes/JsiPointsNode.h +51 -0
  64. package/cpp/rnskia/dom/nodes/JsiRRectNode.h +34 -0
  65. package/cpp/rnskia/dom/nodes/JsiRectNode.h +34 -0
  66. package/cpp/rnskia/dom/nodes/JsiShaderNodes.h +517 -0
  67. package/cpp/rnskia/dom/nodes/JsiTextBlobNode.h +47 -0
  68. package/cpp/rnskia/dom/nodes/JsiTextNode.h +54 -0
  69. package/cpp/rnskia/dom/nodes/JsiTextPathNode.h +32 -0
  70. package/cpp/rnskia/dom/nodes/JsiVerticesNode.h +43 -0
  71. package/cpp/rnskia/dom/props/BezierProps.h +63 -0
  72. package/cpp/rnskia/dom/props/BlendModeProp.h +101 -0
  73. package/cpp/rnskia/dom/props/BoxShadowProps.h +61 -0
  74. package/cpp/rnskia/dom/props/CircleProp.h +46 -0
  75. package/cpp/rnskia/dom/props/ClipProp.h +62 -0
  76. package/cpp/rnskia/dom/props/ColorProp.h +80 -0
  77. package/cpp/rnskia/dom/props/DrawingProp.h +33 -0
  78. package/cpp/rnskia/dom/props/FontProp.h +34 -0
  79. package/cpp/rnskia/dom/props/GlyphsProp.h +53 -0
  80. package/cpp/rnskia/dom/props/ImageProps.h +173 -0
  81. package/cpp/rnskia/dom/props/LayerProp.h +50 -0
  82. package/cpp/rnskia/dom/props/MatrixProp.h +33 -0
  83. package/cpp/rnskia/dom/props/NumbersProp.h +63 -0
  84. package/cpp/rnskia/dom/props/PaintProps.h +172 -0
  85. package/cpp/rnskia/dom/props/PathProp.h +55 -0
  86. package/cpp/rnskia/dom/props/PictureProp.h +38 -0
  87. package/cpp/rnskia/dom/props/PointProp.h +72 -0
  88. package/cpp/rnskia/dom/props/PointsProp.h +83 -0
  89. package/cpp/rnskia/dom/props/RRectProp.h +134 -0
  90. package/cpp/rnskia/dom/props/RadiusProp.h +43 -0
  91. package/cpp/rnskia/dom/props/RectProp.h +118 -0
  92. package/cpp/rnskia/dom/props/StrokeProps.h +75 -0
  93. package/cpp/rnskia/dom/props/SvgProp.h +37 -0
  94. package/cpp/rnskia/dom/props/TextBlobProp.h +128 -0
  95. package/cpp/rnskia/dom/props/TileModeProp.h +50 -0
  96. package/cpp/rnskia/dom/props/TransformProp.h +80 -0
  97. package/cpp/rnskia/dom/props/TransformsProps.h +68 -0
  98. package/cpp/rnskia/dom/props/UniformsProp.h +194 -0
  99. package/cpp/rnskia/dom/props/VertexModeProp.h +47 -0
  100. package/cpp/rnskia/dom/props/VerticesProps.h +67 -0
  101. package/cpp/rnskia/values/RNSkReadonlyValue.h +13 -4
  102. package/cpp/skia/include/android/SkAndroidFrameworkUtils.h +35 -1
  103. package/cpp/skia/include/codec/SkAndroidCodec.h +17 -1
  104. package/cpp/skia/include/codec/SkCodec.h +8 -5
  105. package/cpp/skia/include/core/SkAnnotation.h +2 -0
  106. package/cpp/skia/include/core/SkBitmap.h +52 -1
  107. package/cpp/skia/include/core/SkBlendMode.h +2 -0
  108. package/cpp/skia/include/core/SkCanvas.h +52 -31
  109. package/cpp/skia/include/core/SkCapabilities.h +44 -0
  110. package/cpp/skia/include/core/SkColor.h +7 -0
  111. package/cpp/skia/include/core/SkColorFilter.h +37 -0
  112. package/cpp/skia/include/core/SkColorSpace.h +1 -1
  113. package/cpp/skia/include/core/SkFont.h +4 -0
  114. package/cpp/skia/include/core/SkFontMgr.h +3 -0
  115. package/cpp/skia/include/core/SkGraphics.h +9 -0
  116. package/cpp/skia/include/core/SkImage.h +77 -17
  117. package/cpp/skia/include/core/SkImageEncoder.h +5 -3
  118. package/cpp/skia/include/core/SkImageGenerator.h +27 -17
  119. package/cpp/skia/include/core/SkM44.h +1 -0
  120. package/cpp/skia/include/core/SkMesh.h +120 -34
  121. package/cpp/skia/include/core/SkMilestone.h +1 -1
  122. package/cpp/skia/include/core/SkOverdrawCanvas.h +2 -1
  123. package/cpp/skia/include/core/SkPaint.h +15 -2
  124. package/cpp/skia/include/core/SkPath.h +4 -0
  125. package/cpp/skia/include/core/SkPathBuilder.h +1 -1
  126. package/cpp/skia/include/core/SkPicture.h +0 -3
  127. package/cpp/skia/include/core/SkPictureRecorder.h +0 -2
  128. package/cpp/skia/include/core/SkPixmap.h +19 -0
  129. package/cpp/skia/include/core/SkRasterHandleAllocator.h +3 -1
  130. package/cpp/skia/include/core/SkRect.h +11 -4
  131. package/cpp/skia/include/core/SkRefCnt.h +13 -1
  132. package/cpp/skia/include/core/SkRegion.h +6 -0
  133. package/cpp/skia/include/core/SkSamplingOptions.h +8 -6
  134. package/cpp/skia/include/core/SkScalar.h +6 -25
  135. package/cpp/skia/include/core/SkShader.h +20 -12
  136. package/cpp/skia/include/core/SkSpan.h +51 -19
  137. package/cpp/skia/include/core/SkStream.h +2 -2
  138. package/cpp/skia/include/core/SkString.h +11 -3
  139. package/cpp/skia/include/core/SkSurface.h +85 -8
  140. package/cpp/skia/include/core/SkTextBlob.h +5 -2
  141. package/cpp/skia/include/core/SkTypes.h +11 -10
  142. package/cpp/skia/include/docs/SkPDFDocument.h +0 -5
  143. package/cpp/skia/include/effects/Sk1DPathEffect.h +6 -1
  144. package/cpp/skia/include/effects/Sk2DPathEffect.h +4 -1
  145. package/cpp/skia/include/effects/SkColorMatrix.h +1 -0
  146. package/cpp/skia/include/effects/SkColorMatrixFilter.h +5 -8
  147. package/cpp/skia/include/effects/SkCornerPathEffect.h +5 -1
  148. package/cpp/skia/include/effects/SkDashPathEffect.h +5 -1
  149. package/cpp/skia/include/effects/SkGradientShader.h +68 -38
  150. package/cpp/skia/include/effects/SkHighContrastFilter.h +5 -1
  151. package/cpp/skia/include/effects/SkImageFilters.h +5 -4
  152. package/cpp/skia/include/effects/SkLumaColorFilter.h +4 -1
  153. package/cpp/skia/include/effects/SkOpPathEffect.h +6 -2
  154. package/cpp/skia/include/effects/SkOverdrawColorFilter.h +5 -2
  155. package/cpp/skia/include/effects/SkRuntimeEffect.h +54 -62
  156. package/cpp/skia/include/effects/SkShaderMaskFilter.h +3 -1
  157. package/cpp/skia/include/effects/SkTableColorFilter.h +8 -21
  158. package/cpp/skia/include/effects/SkTableMaskFilter.h +5 -1
  159. package/cpp/skia/include/effects/SkTrimPathEffect.h +5 -1
  160. package/cpp/skia/include/encode/SkEncoder.h +17 -0
  161. package/cpp/skia/include/encode/SkWebpEncoder.h +17 -0
  162. package/cpp/skia/include/gpu/GpuTypes.h +18 -0
  163. package/cpp/skia/include/gpu/GrBackendSurface.h +38 -17
  164. package/cpp/skia/include/gpu/GrBackendSurfaceMutableState.h +6 -71
  165. package/cpp/skia/include/gpu/GrContextOptions.h +1 -1
  166. package/cpp/skia/include/gpu/GrContextThreadSafeProxy.h +10 -9
  167. package/cpp/skia/include/gpu/GrDirectContext.h +42 -22
  168. package/cpp/skia/include/gpu/GrRecordingContext.h +6 -3
  169. package/cpp/skia/include/gpu/GrTypes.h +11 -11
  170. package/cpp/skia/include/gpu/MutableTextureState.h +122 -0
  171. package/cpp/skia/include/gpu/gl/GrGLFunctions.h +1 -0
  172. package/cpp/skia/include/gpu/gl/GrGLInterface.h +1 -0
  173. package/cpp/skia/include/gpu/graphite/BackendTexture.h +7 -0
  174. package/cpp/skia/include/gpu/graphite/CombinationBuilder.h +195 -0
  175. package/cpp/skia/include/gpu/graphite/Context.h +47 -55
  176. package/cpp/skia/include/gpu/graphite/ContextOptions.h +85 -0
  177. package/cpp/skia/include/gpu/graphite/GraphiteTypes.h +1 -17
  178. package/cpp/skia/include/gpu/graphite/ImageProvider.h +61 -0
  179. package/cpp/skia/include/gpu/graphite/Recorder.h +87 -8
  180. package/cpp/skia/include/gpu/graphite/Recording.h +19 -9
  181. package/cpp/skia/include/gpu/graphite/TextureInfo.h +40 -8
  182. package/cpp/skia/include/gpu/graphite/dawn/DawnBackendContext.h +25 -0
  183. package/cpp/skia/include/gpu/graphite/mtl/MtlBackendContext.h +3 -2
  184. package/cpp/skia/include/gpu/graphite/vk/VulkanGraphiteTypes.h +69 -0
  185. package/cpp/skia/include/gpu/mtl/MtlMemoryAllocator.h +39 -0
  186. package/cpp/skia/include/gpu/vk/GrVkBackendContext.h +21 -19
  187. package/cpp/skia/include/gpu/vk/GrVkExtensions.h +2 -50
  188. package/cpp/skia/include/gpu/vk/GrVkMemoryAllocator.h +2 -127
  189. package/cpp/skia/include/gpu/vk/GrVkTypes.h +5 -43
  190. package/cpp/skia/include/gpu/vk/VulkanBackendContext.h +46 -0
  191. package/cpp/skia/include/gpu/vk/VulkanExtensions.h +67 -0
  192. package/cpp/skia/include/gpu/vk/VulkanMemoryAllocator.h +116 -0
  193. package/cpp/skia/include/gpu/vk/VulkanTypes.h +59 -0
  194. package/cpp/skia/include/pathops/SkPathOps.h +1 -1
  195. package/cpp/skia/include/private/SkColorData.h +10 -40
  196. package/cpp/skia/include/private/SkEncodedInfo.h +9 -3
  197. package/cpp/skia/include/private/SkFloatingPoint.h +9 -6
  198. package/cpp/skia/include/private/SkHalf.h +5 -52
  199. package/cpp/skia/include/private/SkMacros.h +1 -1
  200. package/cpp/skia/include/private/SkMalloc.h +4 -0
  201. package/cpp/skia/include/private/SkPathRef.h +10 -10
  202. package/cpp/skia/include/private/SkSLModifiers.h +59 -23
  203. package/cpp/skia/include/private/SkSLProgramKind.h +1 -0
  204. package/cpp/skia/include/private/SkSLSymbol.h +7 -3
  205. package/cpp/skia/include/private/SkStringView.h +4 -0
  206. package/cpp/skia/include/private/SkTArray.h +21 -7
  207. package/cpp/skia/include/private/SkTDArray.h +173 -285
  208. package/cpp/skia/include/private/SkTHash.h +33 -32
  209. package/cpp/skia/include/private/SkTemplates.h +24 -26
  210. package/cpp/skia/include/private/SkVx.h +218 -135
  211. package/cpp/skia/include/private/chromium/GrSlug.h +3 -65
  212. package/cpp/skia/include/private/chromium/SkChromeRemoteGlyphCache.h +6 -3
  213. package/cpp/skia/include/private/chromium/Slug.h +76 -0
  214. package/cpp/skia/include/private/gpu/ganesh/GrTypesPriv.h +6 -1
  215. package/cpp/skia/include/private/gpu/ganesh/GrVkTypesPriv.h +5 -39
  216. package/cpp/skia/include/private/gpu/graphite/VulkanGraphiteTypesPriv.h +63 -0
  217. package/cpp/skia/include/{gpu/vk/GrVkVulkan.h → private/gpu/vk/SkiaVulkan.h} +2 -2
  218. package/cpp/skia/include/private/gpu/vk/VulkanTypesPriv.h +57 -0
  219. package/cpp/skia/include/sksl/DSL.h +0 -1
  220. package/cpp/skia/include/sksl/DSLBlock.h +4 -18
  221. package/cpp/skia/include/sksl/DSLCase.h +2 -8
  222. package/cpp/skia/include/sksl/DSLCore.h +8 -15
  223. package/cpp/skia/include/sksl/DSLExpression.h +51 -142
  224. package/cpp/skia/include/sksl/DSLFunction.h +7 -15
  225. package/cpp/skia/include/sksl/DSLModifiers.h +5 -2
  226. package/cpp/skia/include/sksl/DSLStatement.h +4 -39
  227. package/cpp/skia/include/sksl/DSLSymbols.h +1 -11
  228. package/cpp/skia/include/sksl/DSLType.h +20 -12
  229. package/cpp/skia/include/sksl/DSLVar.h +56 -146
  230. package/cpp/skia/include/sksl/SkSLErrorReporter.h +2 -15
  231. package/cpp/skia/include/sksl/SkSLOperator.h +62 -59
  232. package/cpp/skia/include/sksl/SkSLPosition.h +2 -0
  233. package/cpp/skia/include/sksl/SkSLVersion.h +27 -0
  234. package/cpp/skia/include/svg/SkSVGCanvas.h +1 -0
  235. package/cpp/skia/include/utils/SkAnimCodecPlayer.h +1 -1
  236. package/cpp/skia/include/utils/SkBase64.h +2 -0
  237. package/cpp/skia/include/utils/SkCustomTypeface.h +24 -11
  238. package/cpp/skia/include/utils/SkEventTracer.h +12 -1
  239. package/cpp/skia/include/utils/SkNWayCanvas.h +11 -4
  240. package/cpp/skia/include/utils/SkPaintFilterCanvas.h +9 -4
  241. package/cpp/skia/include/utils/SkParse.h +3 -0
  242. package/cpp/skia/include/utils/SkShadowUtils.h +2 -0
  243. package/cpp/skia/include/utils/SkTextUtils.h +2 -1
  244. package/cpp/skia/{include/third_party → modules}/skcms/skcms.h +10 -0
  245. package/cpp/skia/modules/skcms/skcms_internal.h +56 -0
  246. package/cpp/skia/modules/skcms/src/Transform_inl.h +1609 -0
  247. package/cpp/skia/modules/skparagraph/include/DartTypes.h +153 -0
  248. package/cpp/skia/modules/skparagraph/include/FontArguments.h +46 -0
  249. package/cpp/skia/modules/skparagraph/include/FontCollection.h +84 -0
  250. package/cpp/skia/modules/skparagraph/include/Metrics.h +98 -0
  251. package/cpp/skia/modules/skparagraph/include/Paragraph.h +111 -0
  252. package/cpp/skia/modules/skparagraph/include/ParagraphBuilder.h +69 -0
  253. package/cpp/skia/modules/skparagraph/include/ParagraphCache.h +77 -0
  254. package/cpp/skia/modules/skparagraph/include/ParagraphStyle.h +143 -0
  255. package/cpp/skia/modules/skparagraph/include/TextShadow.h +30 -0
  256. package/cpp/skia/modules/skparagraph/include/TextStyle.h +352 -0
  257. package/cpp/skia/modules/skparagraph/include/TypefaceFontProvider.h +81 -0
  258. package/cpp/skia/modules/svg/include/SkSVGAttributeParser.h +1 -1
  259. package/cpp/skia/modules/svg/include/SkSVGTypes.h +3 -3
  260. package/cpp/skia/src/core/SkLRUCache.h +126 -0
  261. package/cpp/skia/src/core/SkTInternalLList.h +302 -0
  262. package/cpp/utils/RNSkTimingInfo.h +1 -0
  263. package/ios/RNSkia-iOS/RNSkMetalCanvasProvider.h +15 -4
  264. package/ios/RNSkia-iOS/RNSkMetalCanvasProvider.mm +40 -54
  265. package/ios/RNSkia-iOS/SkiaDomViewManager.h +8 -0
  266. package/ios/RNSkia-iOS/SkiaDomViewManager.mm +51 -0
  267. package/lib/commonjs/dom/nodes/DrawingNode.js +1 -5
  268. package/lib/commonjs/dom/nodes/DrawingNode.js.map +1 -1
  269. package/lib/commonjs/dom/nodes/JsiSkDOM.js +56 -56
  270. package/lib/commonjs/dom/nodes/JsiSkDOM.js.map +1 -1
  271. package/lib/commonjs/dom/nodes/RenderNode.js +3 -9
  272. package/lib/commonjs/dom/nodes/RenderNode.js.map +1 -1
  273. package/lib/commonjs/dom/nodes/drawings/Text.js +4 -9
  274. package/lib/commonjs/dom/nodes/drawings/Text.js.map +1 -1
  275. package/lib/commonjs/dom/types/Common.js.map +1 -1
  276. package/lib/commonjs/dom/types/Drawings.js.map +1 -1
  277. package/lib/commonjs/mock/index.js +0 -1
  278. package/lib/commonjs/mock/index.js.map +1 -1
  279. package/lib/commonjs/renderer/Canvas.js +21 -57
  280. package/lib/commonjs/renderer/Canvas.js.map +1 -1
  281. package/lib/commonjs/renderer/DependencyManager.js +0 -5
  282. package/lib/commonjs/renderer/DependencyManager.js.map +1 -1
  283. package/lib/commonjs/renderer/HostComponents.js.map +1 -1
  284. package/lib/commonjs/renderer/components/Mask.js +1 -3
  285. package/lib/commonjs/renderer/components/Mask.js.map +1 -1
  286. package/lib/commonjs/renderer/components/Paint.js +5 -18
  287. package/lib/commonjs/renderer/components/Paint.js.map +1 -1
  288. package/lib/commonjs/renderer/useCanvas.js +8 -6
  289. package/lib/commonjs/renderer/useCanvas.js.map +1 -1
  290. package/lib/commonjs/skia/core/Picture.js +1 -24
  291. package/lib/commonjs/skia/core/Picture.js.map +1 -1
  292. package/lib/commonjs/skia/core/Rect.js +1 -1
  293. package/lib/commonjs/skia/core/Rect.js.map +1 -1
  294. package/lib/commonjs/skia/types/ContourMeasure.js.map +1 -1
  295. package/lib/commonjs/skia/types/Size.js +2 -0
  296. package/lib/commonjs/skia/types/Size.js.map +1 -0
  297. package/lib/commonjs/skia/types/index.js +13 -0
  298. package/lib/commonjs/skia/types/index.js.map +1 -1
  299. package/lib/commonjs/skia/web/JsiSkColor.js +8 -0
  300. package/lib/commonjs/skia/web/JsiSkColor.js.map +1 -1
  301. package/lib/commonjs/skia/web/JsiSkContourMeasure.js +4 -7
  302. package/lib/commonjs/skia/web/JsiSkContourMeasure.js.map +1 -1
  303. package/lib/commonjs/values/web/RNSkReadonlyValue.js +4 -2
  304. package/lib/commonjs/values/web/RNSkReadonlyValue.js.map +1 -1
  305. package/lib/commonjs/views/SkiaBaseWebView.js +9 -2
  306. package/lib/commonjs/views/SkiaBaseWebView.js.map +1 -1
  307. package/lib/commonjs/views/SkiaDomView.js +152 -0
  308. package/lib/commonjs/views/SkiaDomView.js.map +1 -0
  309. package/lib/commonjs/views/SkiaDomView.web.js +55 -0
  310. package/lib/commonjs/views/SkiaDomView.web.js.map +1 -0
  311. package/lib/commonjs/views/SkiaPictureView.js +16 -2
  312. package/lib/commonjs/views/SkiaPictureView.js.map +1 -1
  313. package/lib/commonjs/views/SkiaView.js +17 -2
  314. package/lib/commonjs/views/SkiaView.js.map +1 -1
  315. package/lib/commonjs/views/index.js +13 -0
  316. package/lib/commonjs/views/index.js.map +1 -1
  317. package/lib/commonjs/views/types.js.map +1 -1
  318. package/lib/module/dom/nodes/DrawingNode.js +2 -6
  319. package/lib/module/dom/nodes/DrawingNode.js.map +1 -1
  320. package/lib/module/dom/nodes/JsiSkDOM.js +56 -56
  321. package/lib/module/dom/nodes/JsiSkDOM.js.map +1 -1
  322. package/lib/module/dom/nodes/RenderNode.js +2 -5
  323. package/lib/module/dom/nodes/RenderNode.js.map +1 -1
  324. package/lib/module/dom/nodes/drawings/Text.js +4 -9
  325. package/lib/module/dom/nodes/drawings/Text.js.map +1 -1
  326. package/lib/module/dom/types/Common.js.map +1 -1
  327. package/lib/module/dom/types/Drawings.js.map +1 -1
  328. package/lib/module/mock/index.js +0 -1
  329. package/lib/module/mock/index.js.map +1 -1
  330. package/lib/module/renderer/Canvas.js +22 -58
  331. package/lib/module/renderer/Canvas.js.map +1 -1
  332. package/lib/module/renderer/DependencyManager.js +0 -5
  333. package/lib/module/renderer/DependencyManager.js.map +1 -1
  334. package/lib/module/renderer/HostComponents.js.map +1 -1
  335. package/lib/module/renderer/components/Mask.js +2 -4
  336. package/lib/module/renderer/components/Mask.js.map +1 -1
  337. package/lib/module/renderer/components/Paint.js +3 -14
  338. package/lib/module/renderer/components/Paint.js.map +1 -1
  339. package/lib/module/renderer/useCanvas.js +6 -4
  340. package/lib/module/renderer/useCanvas.js.map +1 -1
  341. package/lib/module/skia/core/Picture.js +0 -18
  342. package/lib/module/skia/core/Picture.js.map +1 -1
  343. package/lib/module/skia/core/Rect.js +1 -1
  344. package/lib/module/skia/core/Rect.js.map +1 -1
  345. package/lib/module/skia/types/ContourMeasure.js.map +1 -1
  346. package/lib/module/skia/types/Size.js +2 -0
  347. package/lib/module/skia/types/Size.js.map +1 -0
  348. package/lib/module/skia/types/index.js +1 -0
  349. package/lib/module/skia/types/index.js.map +1 -1
  350. package/lib/module/skia/web/JsiSkColor.js +8 -0
  351. package/lib/module/skia/web/JsiSkColor.js.map +1 -1
  352. package/lib/module/skia/web/JsiSkContourMeasure.js +3 -7
  353. package/lib/module/skia/web/JsiSkContourMeasure.js.map +1 -1
  354. package/lib/module/values/web/RNSkReadonlyValue.js +4 -2
  355. package/lib/module/values/web/RNSkReadonlyValue.js.map +1 -1
  356. package/lib/module/views/SkiaBaseWebView.js +9 -2
  357. package/lib/module/views/SkiaBaseWebView.js.map +1 -1
  358. package/lib/module/views/SkiaDomView.js +128 -0
  359. package/lib/module/views/SkiaDomView.js.map +1 -0
  360. package/lib/module/views/SkiaDomView.web.js +41 -0
  361. package/lib/module/views/SkiaDomView.web.js.map +1 -0
  362. package/lib/module/views/SkiaPictureView.js +14 -2
  363. package/lib/module/views/SkiaPictureView.js.map +1 -1
  364. package/lib/module/views/SkiaView.js +15 -2
  365. package/lib/module/views/SkiaView.js.map +1 -1
  366. package/lib/module/views/index.js +1 -0
  367. package/lib/module/views/index.js.map +1 -1
  368. package/lib/module/views/types.js.map +1 -1
  369. package/lib/typescript/src/dom/nodes/JsiSkDOM.d.ts +57 -64
  370. package/lib/typescript/src/dom/nodes/RenderNode.d.ts +1 -3
  371. package/lib/typescript/src/dom/types/Common.d.ts +2 -3
  372. package/lib/typescript/src/dom/types/Drawings.d.ts +1 -3
  373. package/lib/typescript/src/renderer/Canvas.d.ts +5 -5
  374. package/lib/typescript/src/renderer/DependencyManager.d.ts +0 -2
  375. package/lib/typescript/src/renderer/HostComponents.d.ts +67 -8
  376. package/lib/typescript/src/renderer/components/Paint.d.ts +3 -4
  377. package/lib/typescript/src/renderer/useCanvas.d.ts +1 -6
  378. package/lib/typescript/src/skia/core/Picture.d.ts +0 -8
  379. package/lib/typescript/src/skia/types/ContourMeasure.d.ts +3 -2
  380. package/lib/typescript/src/skia/types/Size.d.ts +4 -0
  381. package/lib/typescript/src/skia/types/index.d.ts +1 -0
  382. package/lib/typescript/src/skia/web/JsiSkContourMeasure.d.ts +2 -6
  383. package/lib/typescript/src/views/SkiaBaseWebView.d.ts +4 -0
  384. package/lib/typescript/src/views/SkiaDomView.d.ts +31 -0
  385. package/lib/typescript/src/views/SkiaDomView.web.d.ts +7 -0
  386. package/lib/typescript/src/views/index.d.ts +1 -0
  387. package/lib/typescript/src/views/types.d.ts +12 -2
  388. package/libs/android/arm64-v8a/libskia.a +0 -0
  389. package/libs/android/arm64-v8a/libskottie.a +0 -0
  390. package/libs/android/arm64-v8a/libskparagraph.a +0 -0
  391. package/libs/android/arm64-v8a/libsksg.a +0 -0
  392. package/libs/android/arm64-v8a/libskshaper.a +0 -0
  393. package/libs/android/arm64-v8a/libskunicode.a +0 -0
  394. package/libs/android/arm64-v8a/libsvg.a +0 -0
  395. package/libs/android/armeabi-v7a/libskia.a +0 -0
  396. package/libs/android/armeabi-v7a/libskottie.a +0 -0
  397. package/libs/android/armeabi-v7a/libskparagraph.a +0 -0
  398. package/libs/android/armeabi-v7a/libsksg.a +0 -0
  399. package/libs/android/armeabi-v7a/libskshaper.a +0 -0
  400. package/libs/android/armeabi-v7a/libskunicode.a +0 -0
  401. package/libs/android/armeabi-v7a/libsvg.a +0 -0
  402. package/libs/android/x86/libskia.a +0 -0
  403. package/libs/android/x86/libskottie.a +0 -0
  404. package/libs/android/x86/libskparagraph.a +0 -0
  405. package/libs/android/x86/libsksg.a +0 -0
  406. package/libs/android/x86/libskshaper.a +0 -0
  407. package/libs/android/x86/libskunicode.a +0 -0
  408. package/libs/android/x86/libsvg.a +0 -0
  409. package/libs/android/x86_64/libskia.a +0 -0
  410. package/libs/android/x86_64/libskottie.a +0 -0
  411. package/libs/android/x86_64/libskparagraph.a +0 -0
  412. package/libs/android/x86_64/libsksg.a +0 -0
  413. package/libs/android/x86_64/libskshaper.a +0 -0
  414. package/libs/android/x86_64/libskunicode.a +0 -0
  415. package/libs/android/x86_64/libsvg.a +0 -0
  416. package/libs/ios/libskia.xcframework/ios-arm64_arm64e/libskia.a +0 -0
  417. package/libs/ios/libskia.xcframework/ios-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
  418. package/libs/ios/libskottie.xcframework/ios-arm64_arm64e/libskottie.a +0 -0
  419. package/libs/ios/libskottie.xcframework/ios-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
  420. package/libs/ios/libskparagraph.xcframework/Info.plist +42 -0
  421. package/libs/ios/libskparagraph.xcframework/ios-arm64_arm64e/libskparagraph.a +0 -0
  422. package/libs/ios/libskparagraph.xcframework/ios-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
  423. package/libs/ios/libsksg.xcframework/Info.plist +5 -5
  424. package/libs/ios/libsksg.xcframework/ios-arm64_arm64e/libsksg.a +0 -0
  425. package/libs/ios/libsksg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
  426. package/libs/ios/libskshaper.xcframework/ios-arm64_arm64e/libskshaper.a +0 -0
  427. package/libs/ios/libskshaper.xcframework/ios-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
  428. package/libs/ios/libskunicode.xcframework/Info.plist +42 -0
  429. package/libs/ios/libskunicode.xcframework/ios-arm64_arm64e/libskunicode.a +0 -0
  430. package/libs/ios/libskunicode.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode.a +0 -0
  431. package/libs/ios/libsvg.xcframework/ios-arm64_arm64e/libsvg.a +0 -0
  432. package/libs/ios/libsvg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
  433. package/package.json +6 -4
  434. package/react-native-skia.podspec +3 -1
  435. package/src/dom/nodes/DrawingNode.ts +2 -4
  436. package/src/dom/nodes/JsiSkDOM.ts +170 -56
  437. package/src/dom/nodes/RenderNode.ts +2 -14
  438. package/src/dom/nodes/drawings/Text.ts +4 -4
  439. package/src/dom/types/Common.ts +2 -4
  440. package/src/dom/types/Drawings.ts +1 -4
  441. package/src/mock/index.ts +0 -1
  442. package/src/renderer/Canvas.tsx +32 -51
  443. package/src/renderer/DependencyManager.tsx +0 -5
  444. package/src/renderer/HostComponents.ts +153 -5
  445. package/src/renderer/components/Mask.tsx +2 -2
  446. package/src/renderer/components/Paint.tsx +3 -14
  447. package/src/renderer/useCanvas.ts +5 -5
  448. package/src/skia/core/Picture.ts +0 -24
  449. package/src/skia/core/Rect.ts +1 -1
  450. package/src/skia/types/ContourMeasure.tsx +3 -2
  451. package/src/skia/types/Size.ts +4 -0
  452. package/src/skia/types/index.ts +1 -0
  453. package/src/skia/web/JsiSkColor.ts +11 -0
  454. package/src/skia/web/JsiSkContourMeasure.ts +7 -3
  455. package/src/values/web/RNSkReadonlyValue.ts +4 -2
  456. package/src/views/SkiaBaseWebView.tsx +6 -2
  457. package/src/views/SkiaDomView.tsx +120 -0
  458. package/src/views/SkiaDomView.web.tsx +37 -0
  459. package/src/views/SkiaPictureView.tsx +10 -2
  460. package/src/views/SkiaView.tsx +11 -3
  461. package/src/views/index.ts +1 -0
  462. package/src/views/types.ts +19 -2
  463. package/cpp/jsi/JsiSimpleValueWrapper.h +0 -99
  464. package/cpp/skia/include/c/sk_canvas.h +0 -159
  465. package/cpp/skia/include/c/sk_colorspace.h +0 -25
  466. package/cpp/skia/include/c/sk_data.h +0 -65
  467. package/cpp/skia/include/c/sk_image.h +0 -71
  468. package/cpp/skia/include/c/sk_imageinfo.h +0 -62
  469. package/cpp/skia/include/c/sk_maskfilter.h +0 -47
  470. package/cpp/skia/include/c/sk_matrix.h +0 -49
  471. package/cpp/skia/include/c/sk_paint.h +0 -145
  472. package/cpp/skia/include/c/sk_path.h +0 -102
  473. package/cpp/skia/include/c/sk_picture.h +0 -70
  474. package/cpp/skia/include/c/sk_shader.h +0 -143
  475. package/cpp/skia/include/c/sk_surface.h +0 -73
  476. package/cpp/skia/include/c/sk_types.h +0 -278
  477. package/cpp/skia/include/gpu/graphite/SkStuff.h +0 -47
  478. package/cpp/skia/include/private/SkNx.h +0 -430
  479. package/cpp/skia/include/private/SkNx_neon.h +0 -713
  480. package/cpp/skia/include/private/SkNx_sse.h +0 -823
  481. package/cpp/skia/include/sksl/DSLRuntimeEffects.h +0 -32
  482. package/cpp/skia/include/sksl/DSLWrapper.h +0 -77
package/package.json CHANGED
@@ -7,7 +7,7 @@
7
7
  "setup-skia-web": "./scripts/setup-canvaskit.js"
8
8
  },
9
9
  "title": "React Native Skia",
10
- "version": "0.1.157",
10
+ "version": "0.1.159",
11
11
  "description": "High-performance React Native Graphics using Skia",
12
12
  "main": "lib/module/index.js",
13
13
  "files": [
@@ -32,6 +32,8 @@
32
32
  "libs/ios/libsvg.xcframework",
33
33
  "libs/ios/libskottie.xcframework",
34
34
  "libs/ios/libsksg.xcframework",
35
+ "libs/ios/libskparagraph.xcframework",
36
+ "libs/ios/libskunicode.xcframework",
35
37
  "react-native-skia.podspec",
36
38
  "scripts/install-npm.js",
37
39
  "scripts/setup-canvaskit.js",
@@ -77,21 +79,21 @@
77
79
  }
78
80
  },
79
81
  "devDependencies": {
82
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
80
83
  "@types/jest": "^28.1.6",
81
- "@types/react-native": "0.66.2",
84
+ "@types/react-native": "0.70.6",
82
85
  "@types/react-reconciler": "^0.26.7",
83
86
  "eslint": "8.21.0",
84
87
  "eslint-config-react-native-wcandillon": "3.9.0",
85
88
  "eslint-plugin-reanimated": "2.0.0",
86
89
  "jest": "28.1.3",
87
90
  "react": "18.1.0",
88
- "react-native": "0.70.1",
91
+ "react-native": "0.70.6",
89
92
  "react-native-builder-bob": "^0.18.2",
90
93
  "ts-jest": "^28.0.7",
91
94
  "typescript": "4.8.3"
92
95
  },
93
96
  "dependencies": {
94
- "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
95
97
  "canvaskit-wasm": "0.36.1",
96
98
  "react-reconciler": "^0.27.0"
97
99
  },
@@ -31,7 +31,9 @@ Pod::Spec.new do |s|
31
31
  s.ios.vendored_frameworks = [
32
32
  'libs/ios/libskia.xcframework',
33
33
  'libs/ios/libsvg.xcframework',
34
- 'libs/ios/libskshaper.xcframework'
34
+ 'libs/ios/libskshaper.xcframework',
35
+ 'libs/ios/libskparagraph.xcframework',
36
+ 'libs/ios/libskunicode.xcframework',
35
37
  ]
36
38
 
37
39
  # All iOS cpp/h files
@@ -9,7 +9,7 @@ import type {
9
9
  import type { NodeContext } from "./Node";
10
10
  import { JsiDeclarationNode } from "./Node";
11
11
  import { PaintNode } from "./PaintNode";
12
- import { isSkPaint, JsiRenderNode } from "./RenderNode";
12
+ import { JsiRenderNode } from "./RenderNode";
13
13
 
14
14
  export abstract class JsiDrawingNode<P extends DrawingNodeProps, C>
15
15
  extends JsiRenderNode<P>
@@ -52,10 +52,8 @@ export abstract class JsiDrawingNode<P extends DrawingNodeProps, C>
52
52
  }
53
53
 
54
54
  renderNode(ctx: DrawingContext): void {
55
- if (this.props.paint && isSkPaint(this.props.paint)) {
55
+ if (this.props.paint) {
56
56
  this.draw({ ...ctx, paint: this.props.paint });
57
- } else if (this.props.paint && this.props.paint.current != null) {
58
- this.draw({ ...ctx, paint: this.props.paint.current.materialize() });
59
57
  } else {
60
58
  this.draw(ctx);
61
59
  }
@@ -127,232 +127,346 @@ export class JsiSkDOM implements SkDOM {
127
127
  constructor(private ctx: NodeContext) {}
128
128
 
129
129
  Layer(props?: ChildrenProps) {
130
- return new LayerNode(this.ctx, props ?? {});
130
+ return global.SkiaDomApi && global.SkiaDomApi.LayerNode
131
+ ? global.SkiaDomApi.LayerNode(props ?? {})
132
+ : new LayerNode(this.ctx, props ?? {});
131
133
  }
132
134
 
133
135
  Group(props?: GroupProps) {
134
- return new GroupNode(this.ctx, props ?? {});
136
+ return global.SkiaDomApi && global.SkiaDomApi.GroupNode
137
+ ? global.SkiaDomApi.GroupNode(props ?? {})
138
+ : new GroupNode(this.ctx, props ?? {});
135
139
  }
136
140
 
137
141
  Paint(props: PaintProps) {
138
- return new PaintNode(this.ctx, props);
142
+ return global.SkiaDomApi && global.SkiaDomApi.PaintNode
143
+ ? global.SkiaDomApi.PaintNode(props ?? {})
144
+ : new PaintNode(this.ctx, props);
139
145
  }
140
146
 
141
147
  // Drawings
142
148
  Fill(props?: DrawingNodeProps) {
143
- return new FillNode(this.ctx, props);
149
+ return global.SkiaDomApi && global.SkiaDomApi.FillNode
150
+ ? global.SkiaDomApi.FillNode(props ?? {})
151
+ : new FillNode(this.ctx, props);
144
152
  }
145
153
 
146
154
  Image(props: ImageProps) {
147
- return new ImageNode(this.ctx, props);
155
+ return global.SkiaDomApi && global.SkiaDomApi.ImageNode
156
+ ? global.SkiaDomApi.ImageNode(props ?? {})
157
+ : new ImageNode(this.ctx, props);
148
158
  }
149
159
 
150
160
  Circle(props: CircleProps) {
151
- return new CircleNode(this.ctx, props);
161
+ return global.SkiaDomApi && global.SkiaDomApi.CircleNode
162
+ ? global.SkiaDomApi.CircleNode(props ?? {})
163
+ : new CircleNode(this.ctx, props);
152
164
  }
153
165
 
154
166
  Path(props: PathProps) {
155
- return new PathNode(this.ctx, props);
167
+ return global.SkiaDomApi && global.SkiaDomApi.PathNode
168
+ ? global.SkiaDomApi.PathNode(props ?? {})
169
+ : new PathNode(this.ctx, props);
156
170
  }
157
171
 
158
172
  CustomDrawing(props: CustomDrawingNodeProps) {
159
- return new CustomDrawingNode(this.ctx, props);
173
+ return global.SkiaDomApi && global.SkiaDomApi.CustomDrawingNode
174
+ ? global.SkiaDomApi.CustomDrawingNode(props ?? {})
175
+ : new CustomDrawingNode(this.ctx, props);
160
176
  }
161
177
 
162
178
  Line(props: LineProps) {
163
- return new LineNode(this.ctx, props);
179
+ return global.SkiaDomApi && global.SkiaDomApi.LineNode
180
+ ? global.SkiaDomApi.LineNode(props ?? {})
181
+ : new LineNode(this.ctx, props);
164
182
  }
165
183
 
166
184
  Oval(props: OvalProps) {
167
- return new OvalNode(this.ctx, props);
185
+ return global.SkiaDomApi && global.SkiaDomApi.OvalNode
186
+ ? global.SkiaDomApi.OvalNode(props ?? {})
187
+ : new OvalNode(this.ctx, props);
168
188
  }
169
189
 
170
190
  Patch(props: PatchProps) {
171
- return new PatchNode(this.ctx, props);
191
+ return global.SkiaDomApi && global.SkiaDomApi.PatchNode
192
+ ? global.SkiaDomApi.PatchNode(props ?? {})
193
+ : new PatchNode(this.ctx, props);
172
194
  }
173
195
 
174
196
  Points(props: PointsProps) {
175
- return new PointsNode(this.ctx, props);
197
+ return global.SkiaDomApi && global.SkiaDomApi.PointsNode
198
+ ? global.SkiaDomApi.PointsNode(props ?? {})
199
+ : new PointsNode(this.ctx, props);
176
200
  }
177
201
 
178
202
  Rect(props: RectProps) {
179
- return new RectNode(this.ctx, props);
203
+ return global.SkiaDomApi && global.SkiaDomApi.RectNode
204
+ ? global.SkiaDomApi.RectNode(props)
205
+ : new RectNode(this.ctx, props);
180
206
  }
181
207
 
182
208
  RRect(props: RoundedRectProps) {
183
- return new RRectNode(this.ctx, props);
209
+ return global.SkiaDomApi && global.SkiaDomApi.RRectNode
210
+ ? global.SkiaDomApi.RRectNode(props)
211
+ : new RRectNode(this.ctx, props);
184
212
  }
185
213
 
186
214
  Vertices(props: VerticesProps) {
187
- return new VerticesNode(this.ctx, props);
215
+ return global.SkiaDomApi && global.SkiaDomApi.VerticesNode
216
+ ? global.SkiaDomApi.VerticesNode(props)
217
+ : new VerticesNode(this.ctx, props);
188
218
  }
189
219
 
190
220
  Text(props: TextProps) {
191
- return new TextNode(this.ctx, props);
221
+ return global.SkiaDomApi && global.SkiaDomApi.TextNode
222
+ ? global.SkiaDomApi.TextNode(props)
223
+ : new TextNode(this.ctx, props);
192
224
  }
193
225
 
194
226
  TextPath(props: TextPathProps) {
195
- return new TextPathNode(this.ctx, props);
227
+ return global.SkiaDomApi && global.SkiaDomApi.TextPathNode
228
+ ? global.SkiaDomApi.TextPathNode(props)
229
+ : new TextPathNode(this.ctx, props);
196
230
  }
197
231
 
198
232
  TextBlob(props: TextBlobProps) {
199
- return new TextBlobNode(this.ctx, props);
233
+ return global.SkiaDomApi && global.SkiaDomApi.TextBlobNode
234
+ ? global.SkiaDomApi.TextBlobNode(props)
235
+ : new TextBlobNode(this.ctx, props);
200
236
  }
201
237
 
202
238
  Glyphs(props: GlyphsProps) {
203
- return new GlyphsNode(this.ctx, props);
239
+ return global.SkiaDomApi && global.SkiaDomApi.GlyphsNode
240
+ ? global.SkiaDomApi.GlyphsNode(props)
241
+ : new GlyphsNode(this.ctx, props);
204
242
  }
205
243
 
206
244
  DiffRect(props: DiffRectProps) {
207
- return new DiffRectNode(this.ctx, props);
245
+ return global.SkiaDomApi && global.SkiaDomApi.DiffRectNode
246
+ ? global.SkiaDomApi.DiffRectNode(props)
247
+ : new DiffRectNode(this.ctx, props);
208
248
  }
209
249
 
210
250
  Picture(props: PictureProps) {
211
- return new PictureNode(this.ctx, props);
251
+ return global.SkiaDomApi && global.SkiaDomApi.PictureNode
252
+ ? global.SkiaDomApi.PictureNode(props)
253
+ : new PictureNode(this.ctx, props);
212
254
  }
213
255
 
214
256
  ImageSVG(props: ImageSVGProps) {
215
- return new ImageSVGNode(this.ctx, props);
257
+ return global.SkiaDomApi && global.SkiaDomApi.ImageSVGNode
258
+ ? global.SkiaDomApi.ImageSVGNode(props)
259
+ : new ImageSVGNode(this.ctx, props);
216
260
  }
217
261
 
218
262
  // BlurMaskFilters
219
263
  BlurMaskFilter(props: BlurMaskFilterProps) {
220
- return new BlurMaskFilterNode(this.ctx, props);
264
+ return global.SkiaDomApi && global.SkiaDomApi.BlurMaskFilterNode
265
+ ? global.SkiaDomApi.BlurMaskFilterNode(props)
266
+ : new BlurMaskFilterNode(this.ctx, props);
221
267
  }
222
268
 
223
269
  // ImageFilters
224
270
  BlendImageFilter(props: BlendImageFilterProps) {
225
- return new BlendImageFilterNode(this.ctx, props);
271
+ return global.SkiaDomApi && global.SkiaDomApi.BlendImageFilterNode
272
+ ? global.SkiaDomApi.BlendImageFilterNode(props)
273
+ : new BlendImageFilterNode(this.ctx, props);
226
274
  }
227
275
 
228
276
  DropShadowImageFilter(props: DropShadowImageFilterProps) {
229
- return new DropShadowImageFilterNode(this.ctx, props);
277
+ return global.SkiaDomApi && global.SkiaDomApi.DropShadowImageFilterNode
278
+ ? global.SkiaDomApi.DropShadowImageFilterNode(props)
279
+ : new DropShadowImageFilterNode(this.ctx, props);
230
280
  }
231
281
 
232
282
  DisplacementMapImageFilter(props: DisplacementMapImageFilterProps) {
233
- return new DisplacementMapImageFilterNode(this.ctx, props);
283
+ return global.SkiaDomApi && global.SkiaDomApi.DisplacementMapImageFilterNode
284
+ ? global.SkiaDomApi.DisplacementMapImageFilterNode(props)
285
+ : new DisplacementMapImageFilterNode(this.ctx, props);
234
286
  }
235
287
 
236
288
  BlurImageFilter(props: BlurImageFilterProps) {
237
- return new BlurImageFilterNode(this.ctx, props);
289
+ return global.SkiaDomApi && global.SkiaDomApi.BlurImageFilterNode
290
+ ? global.SkiaDomApi.BlurImageFilterNode(props)
291
+ : new BlurImageFilterNode(this.ctx, props);
238
292
  }
239
293
 
240
294
  OffsetImageFilter(props: OffsetImageFilterProps) {
241
- return new OffsetImageFilterNode(this.ctx, props);
295
+ return global.SkiaDomApi && global.SkiaDomApi.OffsetImageFilterNode
296
+ ? global.SkiaDomApi.OffsetImageFilterNode(props)
297
+ : new OffsetImageFilterNode(this.ctx, props);
242
298
  }
243
299
 
244
300
  MorphologyImageFilter(props: MorphologyImageFilterProps) {
245
- return new MorphologyImageFilterNode(this.ctx, props);
301
+ return global.SkiaDomApi && global.SkiaDomApi.MorphologyImageFilterNode
302
+ ? global.SkiaDomApi.MorphologyImageFilterNode(props)
303
+ : new MorphologyImageFilterNode(this.ctx, props);
246
304
  }
247
305
 
248
306
  RuntimeShaderImageFilter(props: RuntimeShaderImageFilterProps) {
249
- return new RuntimeShaderImageFilterNode(this.ctx, props);
307
+ return global.SkiaDomApi && global.SkiaDomApi.RuntimeShaderImageFilterNode
308
+ ? global.SkiaDomApi.RuntimeShaderImageFilterNode(props)
309
+ : new RuntimeShaderImageFilterNode(this.ctx, props);
250
310
  }
251
311
 
252
312
  // Color Filters
253
313
  MatrixColorFilter(props: MatrixColorFilterProps) {
254
- return new MatrixColorFilterNode(this.ctx, props);
314
+ return global.SkiaDomApi && global.SkiaDomApi.MatrixColorFilterNode
315
+ ? global.SkiaDomApi.MatrixColorFilterNode(props)
316
+ : new MatrixColorFilterNode(this.ctx, props);
255
317
  }
256
318
 
257
319
  BlendColorFilter(props: BlendColorFilterProps) {
258
- return new BlendColorFilterNode(this.ctx, props);
320
+ return global.SkiaDomApi && global.SkiaDomApi.BlendColorFilterNode
321
+ ? global.SkiaDomApi.BlendColorFilterNode(props)
322
+ : new BlendColorFilterNode(this.ctx, props);
259
323
  }
260
324
 
261
325
  LumaColorFilter() {
262
- return new LumaColorFilterNode(this.ctx);
326
+ return global.SkiaDomApi && global.SkiaDomApi.LumaColorFilterNode
327
+ ? global.SkiaDomApi.LumaColorFilterNode()
328
+ : new LumaColorFilterNode(this.ctx);
263
329
  }
264
330
 
265
331
  LinearToSRGBGammaColorFilter() {
266
- return new LinearToSRGBGammaColorFilterNode(this.ctx);
332
+ return global.SkiaDomApi &&
333
+ global.SkiaDomApi.LinearToSRGBGammaColorFilterNode
334
+ ? global.SkiaDomApi.LinearToSRGBGammaColorFilterNode()
335
+ : new LinearToSRGBGammaColorFilterNode(this.ctx);
267
336
  }
268
337
 
269
338
  SRGBToLinearGammaColorFilter() {
270
- return new SRGBToLinearGammaColorFilterNode(this.ctx);
339
+ return global.SkiaDomApi &&
340
+ global.SkiaDomApi.SRGBToLinearGammaColorFilterNode
341
+ ? global.SkiaDomApi.SRGBToLinearGammaColorFilterNode()
342
+ : new SRGBToLinearGammaColorFilterNode(this.ctx);
271
343
  }
272
344
 
273
345
  LerpColorFilter(props: LerpColorFilterProps) {
274
- return new LerpColorFilterNode(this.ctx, props);
346
+ return global.SkiaDomApi && global.SkiaDomApi.LerpColorFilterNode
347
+ ? global.SkiaDomApi.LerpColorFilterNode(props)
348
+ : new LerpColorFilterNode(this.ctx, props);
275
349
  }
276
350
 
277
351
  // Shaders
278
352
  Shader(props: ShaderProps) {
279
- return new ShaderNode(this.ctx, props);
353
+ return global.SkiaDomApi && global.SkiaDomApi.ShaderNode
354
+ ? global.SkiaDomApi.ShaderNode(props)
355
+ : new ShaderNode(this.ctx, props);
280
356
  }
281
357
 
282
358
  ImageShader(props: ImageShaderProps) {
283
- return new ImageShaderNode(this.ctx, props);
359
+ return global.SkiaDomApi && global.SkiaDomApi.ImageShaderNode
360
+ ? global.SkiaDomApi.ImageShaderNode(props)
361
+ : new ImageShaderNode(this.ctx, props);
284
362
  }
285
363
 
286
364
  ColorShader(props: ColorProps) {
287
- return new ColorNode(this.ctx, props);
365
+ return global.SkiaDomApi && global.SkiaDomApi.ColorShaderNode
366
+ ? global.SkiaDomApi.ColorShaderNode(props)
367
+ : new ColorNode(this.ctx, props);
288
368
  }
289
369
 
290
370
  SweepGradient(props: SweepGradientProps) {
291
- return new SweepGradientNode(this.ctx, props);
371
+ return global.SkiaDomApi && global.SkiaDomApi.SweepGradientNode
372
+ ? global.SkiaDomApi.SweepGradientNode(props)
373
+ : new SweepGradientNode(this.ctx, props);
292
374
  }
293
375
 
294
376
  Turbulence(props: TurbulenceProps) {
295
- return new TurbulenceNode(this.ctx, props);
377
+ return global.SkiaDomApi && global.SkiaDomApi.TurbulenceNode
378
+ ? global.SkiaDomApi.TurbulenceNode(props)
379
+ : new TurbulenceNode(this.ctx, props);
296
380
  }
297
381
 
298
382
  FractalNoise(props: FractalNoiseProps) {
299
- return new FractalNoiseNode(this.ctx, props);
383
+ return global.SkiaDomApi && global.SkiaDomApi.FractalNoiseNode
384
+ ? global.SkiaDomApi.FractalNoiseNode(props)
385
+ : new FractalNoiseNode(this.ctx, props);
300
386
  }
301
387
 
302
388
  LinearGradient(props: LinearGradientProps) {
303
- return new LinearGradientNode(this.ctx, props);
389
+ return global.SkiaDomApi && global.SkiaDomApi.LinearGradientNode
390
+ ? global.SkiaDomApi.LinearGradientNode(props)
391
+ : new LinearGradientNode(this.ctx, props);
304
392
  }
305
393
 
306
394
  RadialGradient(props: RadialGradientProps) {
307
- return new RadialGradientNode(this.ctx, props);
395
+ return global.SkiaDomApi && global.SkiaDomApi.RadialGradientNode
396
+ ? global.SkiaDomApi.RadialGradientNode(props)
397
+ : new RadialGradientNode(this.ctx, props);
308
398
  }
309
399
 
310
400
  TwoPointConicalGradient(props: TwoPointConicalGradientProps) {
311
- return new TwoPointConicalGradientNode(this.ctx, props);
401
+ return global.SkiaDomApi && global.SkiaDomApi.TwoPointConicalGradientNode
402
+ ? global.SkiaDomApi.TwoPointConicalGradientNode(props)
403
+ : new TwoPointConicalGradientNode(this.ctx, props);
312
404
  }
313
405
 
314
406
  // Path Effects
315
407
  CornerPathEffect(props: CornerPathEffectProps) {
316
- return new CornerPathEffectNode(this.ctx, props);
408
+ return global.SkiaDomApi && global.SkiaDomApi.CornerPathEffectNode
409
+ ? global.SkiaDomApi.CornerPathEffectNode(props)
410
+ : new CornerPathEffectNode(this.ctx, props);
317
411
  }
318
412
 
319
413
  DiscretePathEffect(props: DiscretePathEffectProps) {
320
- return new DiscretePathEffectNode(this.ctx, props);
414
+ return global.SkiaDomApi && global.SkiaDomApi.DiscretePathEffectNode
415
+ ? global.SkiaDomApi.DiscretePathEffectNode(props)
416
+ : new DiscretePathEffectNode(this.ctx, props);
321
417
  }
322
418
 
323
419
  DashPathEffect(props: DashPathEffectProps) {
324
- return new DashPathEffectNode(this.ctx, props);
420
+ return global.SkiaDomApi && global.SkiaDomApi.DashPathEffectNode
421
+ ? global.SkiaDomApi.DashPathEffectNode(props)
422
+ : new DashPathEffectNode(this.ctx, props);
325
423
  }
326
424
 
327
425
  Path1DPathEffect(props: Path1DPathEffectProps) {
328
- return new Path1DPathEffectNode(this.ctx, props);
426
+ return global.SkiaDomApi && global.SkiaDomApi.Path1DPathEffectNode
427
+ ? global.SkiaDomApi.Path1DPathEffectNode(props)
428
+ : new Path1DPathEffectNode(this.ctx, props);
329
429
  }
330
430
 
331
431
  Path2DPathEffect(props: Path2DPathEffectProps) {
332
- return new Path2DPathEffectNode(this.ctx, props);
432
+ return global.SkiaDomApi && global.SkiaDomApi.Path2DPathEffectNode
433
+ ? global.SkiaDomApi.Path2DPathEffectNode(props)
434
+ : new Path2DPathEffectNode(this.ctx, props);
333
435
  }
334
436
 
335
437
  SumPathEffect() {
336
- return new SumPathEffectNode(this.ctx);
438
+ return global.SkiaDomApi && global.SkiaDomApi.SumPathEffectNode
439
+ ? global.SkiaDomApi.SumPathEffectNode()
440
+ : new SumPathEffectNode(this.ctx);
337
441
  }
338
442
 
339
443
  Line2DPathEffect(props: Line2DPathEffectProps) {
340
- return new Line2DPathEffectNode(this.ctx, props);
444
+ return global.SkiaDomApi && global.SkiaDomApi.Line2DPathEffectNode
445
+ ? global.SkiaDomApi.Line2DPathEffectNode(props)
446
+ : new Line2DPathEffectNode(this.ctx, props);
341
447
  }
342
448
 
343
449
  Blend(props: BlendProps) {
344
- return new BlendNode(this.ctx, props);
450
+ return global.SkiaDomApi && global.SkiaDomApi.BlendNode
451
+ ? global.SkiaDomApi.BlendNode(props)
452
+ : new BlendNode(this.ctx, props);
345
453
  }
346
454
 
347
455
  BackdropFilter(props: ChildrenProps) {
348
- return new BackdropFilterNode(this.ctx, props);
456
+ return global.SkiaDomApi && global.SkiaDomApi.BackdropFilterNode
457
+ ? global.SkiaDomApi.BackdropFilterNode(props)
458
+ : new BackdropFilterNode(this.ctx, props);
349
459
  }
350
460
 
351
461
  Box(props: BoxProps) {
352
- return new BoxNode(this.ctx, props);
462
+ return global.SkiaDomApi && global.SkiaDomApi.BoxNode
463
+ ? global.SkiaDomApi.BoxNode(props)
464
+ : new BoxNode(this.ctx, props);
353
465
  }
354
466
 
355
467
  BoxShadow(props: BoxShadowProps) {
356
- return new BoxShadowNode(this.ctx, props);
468
+ return global.SkiaDomApi && global.SkiaDomApi.BoxShadowNode
469
+ ? global.SkiaDomApi.BoxShadowNode(props)
470
+ : new BoxShadowNode(this.ctx, props);
357
471
  }
358
472
  }
@@ -1,5 +1,3 @@
1
- import type { RefObject } from "react";
2
-
3
1
  import type {
4
2
  SkMatrix,
5
3
  SkRect,
@@ -21,7 +19,6 @@ import type {
21
19
  DrawingContext,
22
20
  NodeType,
23
21
  Node,
24
- DeclarationNode,
25
22
  } from "../types";
26
23
 
27
24
  import { isPathDef, processPath, processTransformProps } from "./datatypes";
@@ -236,17 +233,12 @@ export abstract class JsiRenderNode<P extends GroupProps>
236
233
  this.clipRRect !== undefined;
237
234
  const shouldSave = hasTransform || hasClip || !!layer;
238
235
  const op = invertClip ? ClipOp.Difference : ClipOp.Intersect;
239
-
240
236
  if (shouldSave) {
241
237
  if (layer) {
242
238
  if (typeof layer === "boolean") {
243
239
  canvas.saveLayer();
244
- } else if (isSkPaint(layer)) {
245
- canvas.saveLayer(layer);
246
240
  } else {
247
- canvas.saveLayer(
248
- layer.current ? layer.current.materialize() : undefined
249
- );
241
+ canvas.saveLayer(layer);
250
242
  }
251
243
  } else {
252
244
  canvas.save();
@@ -274,10 +266,6 @@ export abstract class JsiRenderNode<P extends GroupProps>
274
266
  abstract renderNode(ctx: DrawingContext): void;
275
267
  }
276
268
 
277
- export const isSkPaint = (
278
- obj: RefObject<DeclarationNode<unknown, SkPaint>> | SkPaint
279
- ): obj is SkPaint => "__typename__" in obj && obj.__typename__ === "Paint";
280
-
281
269
  const concatPaint = (
282
270
  parent: SkPaint,
283
271
  {
@@ -305,7 +293,7 @@ const concatPaint = (
305
293
  paint.setColor(color);
306
294
  } else {
307
295
  const cl = paint.getColor();
308
- cl[3] *= opacity;
296
+ cl[3] = opacity;
309
297
  paint.setColor(cl);
310
298
  }
311
299
  if (strokeWidth !== undefined) {
@@ -57,10 +57,10 @@ export class TextPathNode extends JsiDrawingNode<TextPathProps, SkTextBlob> {
57
57
  }
58
58
  // Gives us the (x, y) coordinates as well as the cos/sin of the tangent
59
59
  // line at that position.
60
- const { px, py, tx, ty } = cont.getPosTan(dist);
61
- const adjustedX = px - (width / 2) * tx;
62
- const adjustedY = py - (width / 2) * ty;
63
- rsx.push(this.Skia.RSXform(tx, ty, adjustedX, adjustedY));
60
+ const [p, t] = cont.getPosTan(dist);
61
+ const adjustedX = p.x - (width / 2) * t.x;
62
+ const adjustedY = p.y - (width / 2) * t.y;
63
+ rsx.push(this.Skia.RSXform(t.x, t.y, adjustedX, adjustedY));
64
64
  dist += width / 2;
65
65
  }
66
66
  return this.Skia.TextBlob.MakeFromRSXform(text, rsx, font);
@@ -1,4 +1,4 @@
1
- import type { ReactNode, RefObject } from "react";
1
+ import type { ReactNode } from "react";
2
2
 
3
3
  import type {
4
4
  BlendMode,
@@ -15,8 +15,6 @@ import type {
15
15
  Vector,
16
16
  } from "../../skia/types";
17
17
 
18
- import type { DeclarationNode } from "./Node";
19
-
20
18
  export type SkEnum<T> = Uncapitalize<keyof T extends string ? keyof T : never>;
21
19
 
22
20
  export type PathDef = string | SkPath;
@@ -86,5 +84,5 @@ export interface PaintProps extends ChildrenProps {
86
84
  export interface GroupProps extends PaintProps, TransformProps {
87
85
  clip?: ClipDef;
88
86
  invertClip?: boolean;
89
- layer?: RefObject<DeclarationNode<unknown, SkPaint>> | SkPaint | boolean;
87
+ layer?: SkPaint | boolean;
90
88
  }
@@ -1,5 +1,3 @@
1
- import type { RefObject } from "react";
2
-
3
1
  import type {
4
2
  FillType,
5
3
  SkImage,
@@ -29,10 +27,9 @@ import type {
29
27
  SkEnum,
30
28
  } from "./Common";
31
29
  import type { DrawingContext } from "./DrawingContext";
32
- import type { DeclarationNode } from "./Node";
33
30
 
34
31
  export interface DrawingNodeProps extends GroupProps {
35
- paint?: SkPaint | RefObject<DeclarationNode<unknown, SkPaint>>;
32
+ paint?: SkPaint;
36
33
  }
37
34
 
38
35
  export type ImageProps = DrawingNodeProps &
package/src/mock/index.ts CHANGED
@@ -53,7 +53,6 @@ export const Mock: typeof SkiaExports &
53
53
  useTypeface: Noop,
54
54
  useImage: Noop,
55
55
  useSVG: Noop,
56
- usePicture: Noop,
57
56
  createPicture: Noop,
58
57
  // 3. Point/Rect/Transform utilities
59
58
  vec,