UNPKG

@shopify/react-native-skia

Version:

High-performance React Native Graphics using Skia

46 lines 1.36 kB
import { BlendMode } from "../../../skia/types"; import { NodeType } from "../../types"; import { enumKey } from "../datatypes"; import { JsiDrawingNode } from "../DrawingNode"; export class PatchNode extends JsiDrawingNode { constructor(ctx, props) { super(ctx, NodeType.Patch, props); } deriveProps() { const { colors, blendMode, patch } = this.props; const defaultBlendMode = colors ? BlendMode.DstOver : BlendMode.SrcOver; const mode = blendMode ? BlendMode[enumKey(blendMode)] : defaultBlendMode; // Patch requires a path with the following constraints: // M tl // C c1 c2 br // C c1 c2 bl // C c1 c2 tl (the redundant point in the last command is removed) return { mode, points: [patch[0].pos, patch[0].c2, patch[1].c1, patch[1].pos, patch[1].c2, patch[2].c1, patch[2].pos, patch[2].c2, patch[3].c1, patch[3].pos, patch[3].c2, patch[0].c1], colors: colors ? colors.map(c => this.Skia.Color(c)) : undefined }; } draw({ canvas, paint }) { if (!this.derived) { throw new Error("PatchNode: derived props not set"); } const { texture } = this.props; const { colors, points, mode } = this.derived; canvas.drawPatch(points, colors, texture, mode, paint); } } //# sourceMappingURL=PatchNode.js.map