From 8cec512cc216139ff70ea09e6ef2cc75f54e22c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Sun, 8 Dec 2013 22:00:40 +0100 Subject: [PATCH] Take matrices into account in PathItem#getIntersections() --- src/path/Curve.js | 23 +++++++++++++---------- src/path/PathItem.js | 10 ++++++++-- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/src/path/Curve.js b/src/path/Curve.js index e8104f3b..3bcca9ce 100644 --- a/src/path/Curve.js +++ b/src/path/Curve.js @@ -248,8 +248,8 @@ var Curve = Base.extend(/** @lends Curve# */{ this.getPoint2().setSelected(selected); }, - getValues: function() { - return Curve.getValues(this._segment1, this._segment2); + getValues: function(matrix) { + return Curve.getValues(this._segment1, this._segment2, matrix); }, getPoints: function() { @@ -446,17 +446,20 @@ var Curve = Base.extend(/** @lends Curve# */{ // Mess with indentation in order to get more line-space below... statics: { - getValues: function(segment1, segment2) { + getValues: function(segment1, segment2, matrix) { var p1 = segment1._point, h1 = segment1._handleOut, h2 = segment2._handleIn, - p2 = segment2._point; - return [ - p1._x, p1._y, - p1._x + h1._x, p1._y + h1._y, - p2._x + h2._x, p2._y + h2._y, - p2._x, p2._y - ]; + p2 = segment2._point, + values = [ + p1._x, p1._y, + p1._x + h1._x, p1._y + h1._y, + p2._x + h2._x, p2._y + h2._y, + p2._x, p2._y + ]; + if (matrix) + matrix._transformCoordinates(values, 0, values, 0, 6); + return values; }, evaluate: function(v, t, type) { diff --git a/src/path/PathItem.js b/src/path/PathItem.js index 2269a40c..980ad3e9 100644 --- a/src/path/PathItem.js +++ b/src/path/PathItem.js @@ -67,13 +67,19 @@ var PathItem = Item.extend(/** @lends PathItem# */{ var locations = [], curves1 = this.getCurves(), curves2 = path.getCurves(), + matrix1 = this._matrix, + matrix2 = path._matrix, length2 = curves2.length, values2 = []; + if (matrix1.isIdentity()) + matrix1 = null; + if (matrix2.isIdentity()) + matrix2 = null; for (var i = 0; i < length2; i++) - values2[i] = curves2[i].getValues(); + values2[i] = curves2[i].getValues(matrix2); for (var i = 0, l = curves1.length; i < l; i++) { var curve1 = curves1[i], - values1 = curve1.getValues(); + values1 = curve1.getValues(matrix1); for (var j = 0; j < length2; j++) Curve.getIntersections(values1, values2[j], curve1, curves2[j], locations);