123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343 |
- "use strict";
- var Util = require('../util/common');
- var MatrixUtil = require('./util/matrix');
- var Vector2 = require('./util/vector2');
- var StyleUtil = require('./util/style-parse');
- function isUnchanged(m) {
- return m[0] === 1 && m[1] === 0 && m[2] === 0 && m[3] === 1 && m[4] === 0 && m[5] === 0;
- }
- var ALIAS_ATTRS_MAP = {
- stroke: 'strokeStyle',
- fill: 'fillStyle',
- opacity: 'globalAlpha'
- };
- var SHAPE_ATTRS = ['fillStyle', 'font', 'globalAlpha', 'lineCap', 'lineWidth', 'lineJoin', 'miterLimit', 'shadowBlur', 'shadowColor', 'shadowOffsetX', 'shadowOffsetY', 'strokeStyle', 'textAlign', 'textBaseline', 'lineDash', 'shadow' // 兼容支付宝小程序
- ];
- var CLIP_SHAPES = ['circle', 'sector', 'polygon', 'rect', 'polyline'];
- var Element = /*#__PURE__*/function () {
- var _proto = Element.prototype;
- _proto._initProperties = function _initProperties() {
- this._attrs = {
- zIndex: 0,
- visible: true,
- destroyed: false
- };
- };
- function Element(cfg) {
- this._initProperties();
- Util.mix(this._attrs, cfg);
- var attrs = this._attrs.attrs;
- if (attrs) {
- this.initAttrs(attrs);
- }
- this.initTransform();
- }
- _proto.get = function get(name) {
- return this._attrs[name];
- };
- _proto.set = function set(name, value) {
- this._attrs[name] = value;
- };
- _proto.isGroup = function isGroup() {
- return this.get('isGroup');
- };
- _proto.isShape = function isShape() {
- return this.get('isShape');
- };
- _proto.initAttrs = function initAttrs(attrs) {
- this.attr(Util.mix(this.getDefaultAttrs(), attrs));
- };
- _proto.getDefaultAttrs = function getDefaultAttrs() {
- return {};
- };
- _proto._setAttr = function _setAttr(name, value) {
- var attrs = this._attrs.attrs;
- if (name === 'clip') {
- value = this._setAttrClip(value);
- } else {
- var alias = ALIAS_ATTRS_MAP[name];
- if (alias) {
- attrs[alias] = value;
- }
- }
- attrs[name] = value;
- };
- _proto._getAttr = function _getAttr(name) {
- return this._attrs.attrs[name];
- } // _afterAttrsSet() {}
- ;
- _proto._setAttrClip = function _setAttrClip(clip) {
- if (clip && CLIP_SHAPES.indexOf(clip._attrs.type) > -1) {
- if (clip.get('canvas') === null) {
- clip = Object.assign({}, clip);
- }
- clip.set('parent', this.get('parent'));
- clip.set('context', this.get('context'));
- return clip;
- }
- return null;
- };
- _proto.attr = function attr(name, value) {
- var self = this;
- if (self.get('destroyed')) return null;
- var argumentsLen = arguments.length;
- if (argumentsLen === 0) {
- return self._attrs.attrs;
- }
- if (Util.isObject(name)) {
- this._attrs.bbox = null;
- for (var k in name) {
- self._setAttr(k, name[k]);
- }
- if (self._afterAttrsSet) {
- self._afterAttrsSet();
- }
- return self;
- }
- if (argumentsLen === 2) {
- this._attrs.bbox = null;
- self._setAttr(name, value);
- if (self._afterAttrsSet) {
- self._afterAttrsSet();
- }
- return self;
- }
- return self._getAttr(name);
- };
- _proto.getParent = function getParent() {
- return this.get('parent');
- };
- _proto.draw = function draw(context) {
- if (this.get('destroyed')) {
- return;
- }
- if (this.get('visible')) {
- this.setContext(context);
- this.drawInner(context);
- this.restoreContext(context);
- }
- };
- _proto.setContext = function setContext(context) {
- var clip = this._attrs.attrs.clip;
- context.save();
- if (clip) {
- clip.resetTransform(context);
- clip.createPath(context);
- context.clip();
- }
- this.resetContext(context);
- this.resetTransform(context);
- };
- _proto.restoreContext = function restoreContext(context) {
- context.restore();
- };
- _proto.resetContext = function resetContext(context) {
- var elAttrs = this._attrs.attrs;
- if (!this._attrs.isGroup) {
- for (var k in elAttrs) {
- if (SHAPE_ATTRS.indexOf(k) > -1) {
- var v = elAttrs[k];
- if (k === 'fillStyle' || k === 'strokeStyle') {
- v = StyleUtil.parseStyle(v, this, context);
- }
- if (k === 'lineDash' && context.setLineDash && Util.isArray(v)) {
- context.setLineDash(v);
- } else {
- context[k] = v;
- }
- }
- }
- }
- };
- _proto.hasFill = function hasFill() {
- return this.get('canFill') && this._attrs.attrs.fillStyle;
- };
- _proto.hasStroke = function hasStroke() {
- return this.get('canStroke') && this._attrs.attrs.strokeStyle;
- };
- _proto.drawInner = function drawInner()
- /* context */
- {};
- _proto.show = function show() {
- this.set('visible', true);
- return this;
- };
- _proto.hide = function hide() {
- this.set('visible', false);
- return this;
- };
- _proto.isVisible = function isVisible() {
- return this.get('visible');
- };
- _proto._removeFromParent = function _removeFromParent() {
- var parent = this.get('parent');
- if (parent) {
- var children = parent.get('children');
- Util.Array.remove(children, this);
- }
- return this;
- };
- _proto.remove = function remove(destroy) {
- if (destroy) {
- this.destroy();
- } else {
- this._removeFromParent();
- }
- };
- _proto.destroy = function destroy() {
- var destroyed = this.get('destroyed');
- if (destroyed) {
- return null;
- }
- this._removeFromParent();
- this._attrs = {};
- this.set('destroyed', true);
- };
- _proto.getBBox = function getBBox() {
- return {
- minX: 0,
- maxX: 0,
- minY: 0,
- maxY: 0,
- width: 0,
- height: 0
- };
- };
- _proto.initTransform = function initTransform() {
- var attrs = this._attrs.attrs || {};
- if (!attrs.matrix) {
- attrs.matrix = [1, 0, 0, 1, 0, 0];
- }
- this._attrs.attrs = attrs;
- };
- _proto.getMatrix = function getMatrix() {
- return this._attrs.attrs.matrix;
- };
- _proto.setMatrix = function setMatrix(m) {
- this._attrs.attrs.matrix = [m[0], m[1], m[2], m[3], m[4], m[5]];
- };
- _proto.transform = function transform(actions) {
- var matrix = this._attrs.attrs.matrix;
- this._attrs.attrs.matrix = MatrixUtil.transform(matrix, actions);
- return this;
- };
- _proto.setTransform = function setTransform(actions) {
- this._attrs.attrs.matrix = [1, 0, 0, 1, 0, 0];
- return this.transform(actions);
- };
- _proto.translate = function translate(x, y) {
- var matrix = this._attrs.attrs.matrix;
- MatrixUtil.translate(matrix, matrix, [x, y]);
- };
- _proto.rotate = function rotate(rad) {
- var matrix = this._attrs.attrs.matrix;
- MatrixUtil.rotate(matrix, matrix, rad);
- };
- _proto.scale = function scale(sx, sy) {
- var matrix = this._attrs.attrs.matrix;
- MatrixUtil.scale(matrix, matrix, [sx, sy]);
- };
- _proto.moveTo = function moveTo(x, y) {
- var cx = this._attrs.x || 0;
- var cy = this._attrs.y || 0;
- this.translate(x - cx, y - cy);
- this.set('x', x);
- this.set('y', y);
- };
- _proto.apply = function apply(v) {
- var m = this._attrs.attrs.matrix;
- Vector2.transformMat2d(v, v, m);
- return this;
- };
- _proto.resetTransform = function resetTransform(context) {
- var mo = this._attrs.attrs.matrix;
- if (!isUnchanged(mo)) {
- context.transform(mo[0], mo[1], mo[2], mo[3], mo[4], mo[5]);
- }
- };
- _proto.isDestroyed = function isDestroyed() {
- return this.get('destroyed');
- };
- return Element;
- }();
- module.exports = Element;
|