Implement Path#getArea() and CompoundPath#getArea().

This commit is contained in:
Jürg Lehni 2013-04-25 17:37:19 -07:00
parent 80a1129eab
commit 898e216668
3 changed files with 49 additions and 1 deletions

View file

@ -153,6 +153,21 @@ var CompoundPath = this.CompoundPath = PathItem.extend(/** @lends CompoundPath#
return last && last.getFirstCurve(); return last && last.getFirstCurve();
}, },
/**
* The area of the path in square points. Self-intersecting paths can
* contain sub-areas that cancel each other out.
*
* @type Number
* @bean
*/
getArea: function() {
var children = this._children,
area = 0;
for (var i = 0, l = children.length; i < l; i++)
area += children[i].getArea();
return area;
},
getPathData: function(/* precision */) { getPathData: function(/* precision */) {
var children = this._children, var children = this._children,
paths = []; paths = [];

View file

@ -267,6 +267,10 @@ var Curve = this.Curve = Base.extend(/** @lends Curve# */{
return length; return length;
}, },
getArea: function() {
return Curve.getArea(this.getValues());
},
getPart: function(from, to) { getPart: function(from, to) {
return new Curve(Curve.getPart(this.getValues(), from, to)); return new Curve(Curve.getPart(this.getValues(), from, to));
}, },
@ -986,6 +990,20 @@ new function() { // Scope for methods that require numerical integration
return Numerical.integrate(ds, a, b, getIterations(a, b)); return Numerical.integrate(ds, a, b, getIterations(a, b));
}, },
getArea: function(v) {
var p1x = v[0], p1y = v[1],
c1x = v[2], c1y = v[3],
c2x = v[4], c2y = v[5],
p2x = v[6], p2y = v[7];
// http://objectmix.com/graphics/133553-area-closed-bezier-curve.html
return 3 / 10 * c1y * p1x - 3 / 20 * c1y * c2x
- 3 / 20 * c1y * p2x - 3 / 10 * p1y * c1x
- 3 / 20 * p1y * c2x - 1 / 20 * p1y * p2x
+ 3 / 20 * c2y * p1x + 3 / 20 * c2y * c1x
- 3 / 10 * c2y * p2x + 1 / 20 * p2y * p1x
+ 3 / 20 * p2y * c1x + 3 / 10 * p2y * c2x;
},
getParameterAt: function(v, offset, start) { getParameterAt: function(v, offset, start) {
if (offset == 0) if (offset == 0)
return start; return start;

View file

@ -1226,7 +1226,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
}, },
/** /**
* The length of the perimeter of the path. * The approximate length of the path in points.
* *
* @type Number * @type Number
* @bean * @bean
@ -1241,6 +1241,21 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
return this._length; return this._length;
}, },
/**
* The area of the path in square points. Self-intersecting paths can
* contain sub-areas that cancel each other out.
*
* @type Number
* @bean
*/
getArea: function() {
var curves = this.getCurves();
var area = 0;
for (var i = 0, l = curves.length; i < l; i++)
area += curves[i].getArea();
return area;
},
_getOffset: function(location) { _getOffset: function(location) {
var index = location && location.getIndex(); var index = location && location.getIndex();
if (index != null) { if (index != null) {