summaryrefslogtreecommitdiffstats
path: root/src/helpers.js
diff options
context:
space:
mode:
authorSaivan <savian@me.com>2018-07-03 22:07:53 +1000
committerSaivan <savian@me.com>2018-07-03 22:07:53 +1000
commit5a1be483befaa644fd996b7be74ef59655160f95 (patch)
treed43c98bcaa973ec7b61ff2542b4f95f81e4a31df /src/helpers.js
parentea8767c90953f494d82acf9049fed11cbecfc51d (diff)
downloadsvg.js-5a1be483befaa644fd996b7be74ef59655160f95.tar.gz
svg.js-5a1be483befaa644fd996b7be74ef59655160f95.zip
Fixed an issue that occurred when we applied more than one transform
This commit allows us to apply more than one transform to an element, and have them correctly applied to the element.
Diffstat (limited to 'src/helpers.js')
-rw-r--r--src/helpers.js35
1 files changed, 32 insertions, 3 deletions
diff --git a/src/helpers.js b/src/helpers.js
index 99a7c0b..755beba 100644
--- a/src/helpers.js
+++ b/src/helpers.js
@@ -260,23 +260,52 @@ function formatTransforms (o) {
}
}
+/* TODO: KILL
+
+
+ 1. Transform the origin by figuring out the delta
+
+ - At the start, we had:
+
+ let Sinv = new SVG.Matrix(element).inverse()
+ let origin = getOrigin(element)
+
+ - At a particular frame we have:
+
+ let C = Matrix(element)
+ let newOrigin = origin.transform(S.inv).transform(C)
+
+*/
+
+
function getOrigin (o, element) {
// Allow origin or around as the names
let origin = o.around == null ? o.origin : o.around
// Allow the user to pass a string to rotate around a given point
if (typeof origin === 'string' || origin == null) {
+
// Get the bounding box of the element with no transformations applied
const string = (origin || 'center').toLowerCase().trim()
const { height, width, x, y } = element.bbox()
- // Set the bounds eg : "bottom-left", "Top right", "middle" etc...
- const ox = o.ox || string.includes('left') ? x
+ // Calculate the transformed x and y coordinates
+ const bx = string.includes('left') ? x
: string.includes('right') ? x + width
: x + width / 2
- const oy = o.oy || string.includes('top') ? y
+ const by = string.includes('top') ? y
: string.includes('bottom') ? y + height
: y + height / 2
+
+ // Find the new center in the transformed coordinates
+ const matrix = new SVG.Matrix(element)
+ const {x: tx , y: ty} = new SVG.Point(bx, by).transform(matrix)
+
+ // Set the bounds eg : "bottom-left", "Top right", "middle" etc...
+ const ox = o.ox != null ? o.ox : tx
+ const oy = o.oy != null ? o.oy : ty
+
+ // Set the origin based on the current matrix location
return [ox, oy]
}