UNPKG

@nmmty/lazycanvas

Version:

A simple way to interact with @napi-rs/canvas in an advanced way!

166 lines (165 loc) 5.59 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.BaseLayer = void 0; const enum_1 = require("../../types/enum"); const utils_1 = require("../../utils/utils"); const LazyUtil_1 = require("../../utils/LazyUtil"); class BaseLayer { id; type; zIndex; visible; props; constructor(type, props) { this.id = (0, utils_1.generateID)(type ? type : enum_1.LayerType.Base); this.type = type ? type : enum_1.LayerType.Base; this.zIndex = 1; this.visible = true; this.props = props ? props : {}; if (!this.props.x) this.props.x = 0; if (!this.props.y) this.props.y = 0; if (!this.props.opacity) this.props.opacity = 1; if (!this.props.centring) this.props.centring = enum_1.Centring.Center; if (!this.props.transform) this.props.transform = {}; } /** * @description Position of the layer in the 2D plane. You can use `numbers`, `percentages`, `px`, `vw`, `vh`, `vmin`, `vmax`. * @param x {ScaleType} - The `x` position of the layer * @param y {ScaleType} - The `y` position of the layer */ setPosition(x, y) { this.props.x = x; this.props.y = y; return this; } /** * @description Opacity of the layer. The value must be between `0` and `1`. * @param opacity {number} - The `opacity` of the layer */ setOpacity(opacity) { this.props.opacity = opacity; return this; } /** * @description Sets the `id` of the layer. * @param id {string} - The `id` of the layer */ setID(id) { this.id = id; return this; } /** * @description Sets shadow of layer. * @param color {string} - The `color` of the filter * @param blur {number} - The `blur` of the filter * @param offsetX {number} - The `offsetX` of the filter * @param offsetY {number} - The `offsetY` of the filter */ setShadow(color, blur, offsetX, offsetY) { if (!color) throw new LazyUtil_1.LazyError('The color of the shadow must be provided'); if (!(0, utils_1.isColor)(color)) throw new LazyUtil_1.LazyError('The color of the shadow must be a valid color'); let parse = (0, utils_1.parseColor)(color); this.props.shadow = { color: parse, blur: blur || 0, offsetX: offsetX || 0, offsetY: offsetY || 0, }; return this; } /** * @description Matrix of the layer in the 2D plane. * @param matrix {DOMMatrix2DInit} - The `matrix` of the layer */ setMatrix(matrix) { this.props.transform = { ...this.props.transform, matrix }; return this; } /** * @description Scale of the layer in the x and y direction by the given amount from their current position. * @param x {number} - The `x` scale of the layer * @param y {number} - The `y` scale of the layer */ setScale(x, y) { this.props.transform = { ...this.props.transform, scale: { x, y } }; return this; } /** * @description Rotate of the layer in the clockwise direction by the given amount from its current position. * @param rotate {number} - The `rotate` of the layer */ setRotate(rotate) { this.props.transform = { ...this.props.transform, rotate }; return this; } /** * @description Translate of the layer in the x and y direction by the given amount from their current position. * @param x {number} - The `x` translation of the layer * @param y {number} - The `y` translation of the layer */ setTranslate(x, y) { this.props.transform = { ...this.props.transform, translate: { x, y } }; return this; } /** * @description The **`CanvasRenderingContext2D`**. filter property of the Canvas 2D API provides filter effects such as blurring and grayscaling. * It is similar to the CSS [`filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/filter) property and accepts the same values. * @param filter {string} - The `filter` of the layer. Multiple filters are supported. */ setFilters(...filter) { this.props.filter = filter.join(' '); return this; } /** * @description Sets type of centring of the layer. * @param centring {AnyCentring} - The `centring` of the layer */ setCentring(centring) { this.props.centring = centring; return this; } /** * @description Sets the visibility of the layer. * @param visible {boolean} - The `visibility` of the layer */ setVisible(visible) { this.visible = visible; return this; } /** * @description Sets zIndex of the layer. * @param zIndex {number} - The `zIndex` of the layer */ setZIndex(zIndex) { this.zIndex = zIndex; return this; } /** * @description Sets global composite operation of the layer. * @param operation {AnyGlobalCompositeOperation} - The `operation` of the layer */ setGlobalCompositeOperation(operation) { this.props.globalComposite = operation; return this; } /** * @returns {IBaseLayer} */ toJSON() { return { id: this.id, type: this.type, zIndex: this.zIndex, visible: this.visible, props: this.props, }; } } exports.BaseLayer = BaseLayer;