2015-04-29 15:28:18 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-04-29 15:28:18 -07:00
|
|
|
*
|
2018-05-10 19:06:46 -07:00
|
|
|
* @format
|
2015-04-29 15:28:18 -07:00
|
|
|
*/
|
2018-05-10 19:06:46 -07:00
|
|
|
|
2015-05-19 13:43:46 -07:00
|
|
|
'use strict';
|
2015-04-29 15:28:18 -07:00
|
|
|
|
|
|
|
// TODO: Move this into an ART mode called "serialized" or something
|
|
|
|
|
2018-05-10 15:44:52 -07:00
|
|
|
const Class = require('art/core/class.js');
|
|
|
|
const Path = require('art/core/path.js');
|
2015-04-29 15:28:18 -07:00
|
|
|
|
2018-05-10 15:44:52 -07:00
|
|
|
const MOVE_TO = 0;
|
|
|
|
const CLOSE = 1;
|
|
|
|
const LINE_TO = 2;
|
|
|
|
const CURVE_TO = 3;
|
|
|
|
const ARC = 4;
|
2015-04-29 15:28:18 -07:00
|
|
|
|
2018-05-10 15:44:52 -07:00
|
|
|
const SerializablePath = Class(Path, {
|
2015-04-29 15:28:18 -07:00
|
|
|
initialize: function(path) {
|
|
|
|
this.reset();
|
|
|
|
if (path instanceof SerializablePath) {
|
|
|
|
this.path = path.path.slice(0);
|
|
|
|
} else if (path) {
|
|
|
|
if (path.applyToPath) {
|
|
|
|
path.applyToPath(this);
|
|
|
|
} else {
|
|
|
|
this.push(path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onReset: function() {
|
|
|
|
this.path = [];
|
|
|
|
},
|
|
|
|
|
|
|
|
onMove: function(sx, sy, x, y) {
|
|
|
|
this.path.push(MOVE_TO, x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
onLine: function(sx, sy, x, y) {
|
|
|
|
this.path.push(LINE_TO, x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
onBezierCurve: function(sx, sy, p1x, p1y, p2x, p2y, x, y) {
|
|
|
|
this.path.push(CURVE_TO, p1x, p1y, p2x, p2y, x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
_arcToBezier: Path.prototype.onArc,
|
|
|
|
|
|
|
|
onArc: function(sx, sy, ex, ey, cx, cy, rx, ry, sa, ea, ccw, rotation) {
|
|
|
|
if (rx !== ry || rotation) {
|
|
|
|
return this._arcToBezier(
|
2018-05-10 19:06:46 -07:00
|
|
|
sx,
|
|
|
|
sy,
|
|
|
|
ex,
|
|
|
|
ey,
|
|
|
|
cx,
|
|
|
|
cy,
|
|
|
|
rx,
|
|
|
|
ry,
|
|
|
|
sa,
|
|
|
|
ea,
|
|
|
|
ccw,
|
|
|
|
rotation,
|
2015-04-29 15:28:18 -07:00
|
|
|
);
|
|
|
|
}
|
|
|
|
this.path.push(ARC, cx, cy, rx, sa, ea, ccw ? 0 : 1);
|
|
|
|
},
|
|
|
|
|
|
|
|
onClose: function() {
|
|
|
|
this.path.push(CLOSE);
|
|
|
|
},
|
|
|
|
|
|
|
|
toJSON: function() {
|
|
|
|
return this.path;
|
2018-05-10 19:06:46 -07:00
|
|
|
},
|
2015-04-29 15:28:18 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = SerializablePath;
|