UNPKG

@shopify/react-native-skia

Version:

High-performance React Native Graphics using Skia

60 lines 1.72 kB
import { toMatrix3 } from "../types"; import { HostObject } from "./Host"; const isMatrixHostObject = obj => !Array.isArray(obj); export class JsiSkMatrix extends HostObject { constructor(CanvasKit, ref) { super(CanvasKit, ref, "Matrix"); } preMultiply(matrix) { this.ref.set(this.CanvasKit.Matrix.multiply(this.ref, matrix)); } postMultiply(matrix) { this.ref.set(this.CanvasKit.Matrix.multiply(matrix, this.ref)); } concat(matrix) { this.preMultiply( // eslint-disable-next-line no-nested-ternary isMatrixHostObject(matrix) ? JsiSkMatrix.fromValue(matrix) : matrix.length === 16 ? toMatrix3(matrix) : [...matrix]); return this; } translate(x, y) { this.preMultiply(this.CanvasKit.Matrix.translated(x, y)); return this; } postTranslate(x, y) { this.postMultiply(this.CanvasKit.Matrix.translated(x, y)); return this; } scale(x, y) { this.preMultiply(this.CanvasKit.Matrix.scaled(x, y !== null && y !== void 0 ? y : x)); return this; } postScale(x, y) { this.postMultiply(this.CanvasKit.Matrix.scaled(x, y !== null && y !== void 0 ? y : x)); return this; } skew(x, y) { this.preMultiply(this.CanvasKit.Matrix.skewed(x, y)); return this; } postSkew(x, y) { this.postMultiply(this.CanvasKit.Matrix.skewed(x, y)); return this; } rotate(value) { this.preMultiply(this.CanvasKit.Matrix.rotated(value)); return this; } postRotate(value) { this.postMultiply(this.CanvasKit.Matrix.rotated(value)); return this; } identity() { this.ref.set(this.CanvasKit.Matrix.identity()); return this; } get() { return Array.from(this.ref); } } //# sourceMappingURL=JsiSkMatrix.js.map