UNPKG

@shopify/react-native-skia

Version:

High-performance React Native Graphics using Skia

84 lines (76 loc) 2.44 kB
import type { CanvasKit, Image } from "canvaskit-wasm"; import { isNativeBufferWeb } from "../types"; import type { SkData, ImageInfo, SkImage, NativeBuffer, ImageFactory, } from "../types"; import { Host, getEnum } from "./Host"; import { JsiSkImage } from "./JsiSkImage"; import { JsiSkData } from "./JsiSkData"; import type { JsiSkSurface } from "./JsiSkSurface"; export class JsiSkImageFactory extends Host implements ImageFactory { constructor(CanvasKit: CanvasKit) { super(CanvasKit); } MakeImageFromViewTag(viewTag: number): Promise<SkImage | null> { const view = viewTag as unknown as HTMLElement; // TODO: Implement screenshot from view in React JS console.log(view); return Promise.resolve(null); } MakeImageFromNativeBuffer( buffer: NativeBuffer, surface?: JsiSkSurface, image?: JsiSkImage ) { if (!isNativeBufferWeb(buffer)) { throw new Error("Invalid NativeBuffer"); } if (!surface) { // TODO: this is way to slow const img = this.CanvasKit.MakeImageFromCanvasImageSource(buffer); return new JsiSkImage(this.CanvasKit, img); } else if (!image) { // eslint-disable-next-line @typescript-eslint/no-explicit-any const img = (surface as any).makeImageFromTextureSource(buffer) as Image; return new JsiSkImage(this.CanvasKit, img); } else { // eslint-disable-next-line @typescript-eslint/no-explicit-any const img = (surface as any).updateTextureFromSource( image, buffer ) as Image; return new JsiSkImage(this.CanvasKit, img); } } MakeImageFromEncoded(encoded: SkData) { const image = this.CanvasKit.MakeImageFromEncoded( JsiSkData.fromValue(encoded) ); if (image === null) { return null; } return new JsiSkImage(this.CanvasKit, image); } MakeImage(info: ImageInfo, data: SkData, bytesPerRow: number) { // see toSkImageInfo() from canvaskit const image = this.CanvasKit.MakeImage( { alphaType: getEnum(this.CanvasKit.AlphaType, info.alphaType), colorSpace: this.CanvasKit.ColorSpace.SRGB, colorType: getEnum(this.CanvasKit.ColorType, info.colorType), height: info.height, width: info.width, }, JsiSkData.fromValue(data), bytesPerRow ); if (image === null) { return null; } return new JsiSkImage(this.CanvasKit, image); } }