mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 10:48:38 -05:00
Have SVGImport respect the current PaperScope's applyMatrix setting.
This commit is contained in:
parent
54d959df1f
commit
3c31c0e482
5 changed files with 32 additions and 24 deletions
|
@ -11,7 +11,7 @@
|
||||||
svg.visible = true; // Turn off display: none;
|
svg.visible = true; // Turn off display: none;
|
||||||
|
|
||||||
// Resize the tiger to fit within the window:
|
// Resize the tiger to fit within the window:
|
||||||
project.activeLayer.fitBounds(view.bounds);
|
svg.fitBounds(view.bounds);
|
||||||
|
|
||||||
var items = project.activeLayer.firstChild.children;
|
var items = project.activeLayer.firstChild.children;
|
||||||
var mouseIsDown = false;
|
var mouseIsDown = false;
|
||||||
|
|
|
@ -6,22 +6,19 @@
|
||||||
<link rel="stylesheet" href="../css/style.css">
|
<link rel="stylesheet" href="../css/style.css">
|
||||||
<script type="text/javascript" src="../../dist/paper-full.js"></script>
|
<script type="text/javascript" src="../../dist/paper-full.js"></script>
|
||||||
<script type="text/paperscript" canvas="canvas">
|
<script type="text/paperscript" canvas="canvas">
|
||||||
|
// Imported SVG Groups have their applyMatrix flag turned off by
|
||||||
|
// default. This is required for SVG importing to work correctly. Turn
|
||||||
|
// it on now, so we don't have to deal with nested coordinate spaces.
|
||||||
var words = project.importSVG(document.getElementById('svg'));
|
var words = project.importSVG(document.getElementById('svg'));
|
||||||
words.visible = true; // Turn off the effect of display:none;
|
words.visible = true; // Turn off the effect of display:none;
|
||||||
words.fillColor = null;
|
words.fillColor = null;
|
||||||
words.strokeColor = 'black';
|
words.strokeColor = 'black';
|
||||||
|
|
||||||
var yesGroup = words.children.yes;
|
var yesGroup = words.children.yes;
|
||||||
var noGroup = words.children.no;
|
|
||||||
// Imported SVG Groups have their applyMatrix flag turned off by
|
|
||||||
// default. This is required for SVG importing to work correctly. Turn
|
|
||||||
// it on now, so we don't have to deal with nested coordinate spaces.
|
|
||||||
yesGroup.applyMatrix = true;
|
|
||||||
noGroup.applyMatrix = true;
|
|
||||||
|
|
||||||
|
var noGroup = words.children.no;
|
||||||
// Resize the words to fit snugly inside the view:
|
// Resize the words to fit snugly inside the view:
|
||||||
project.activeLayer.fitBounds(view.bounds);
|
words.fitBounds(view.bounds);
|
||||||
project.activeLayer.scale(0.8);
|
words.scale(0.8);
|
||||||
|
|
||||||
yesGroup.position = view.center;
|
yesGroup.position = view.center;
|
||||||
noGroup.position = [-900, -900];
|
noGroup.position = [-900, -900];
|
||||||
|
|
|
@ -102,7 +102,7 @@ var Matrix = Base.extend(/** @lends Matrix# */{
|
||||||
_changed: function() {
|
_changed: function() {
|
||||||
var owner = this._owner;
|
var owner = this._owner;
|
||||||
if (owner) {
|
if (owner) {
|
||||||
// If owner has #applyMatrix set, directly bake it in now.
|
// If owner has #applyMatrix set, directly bake the change in now.
|
||||||
if (owner._applyMatrix) {
|
if (owner._applyMatrix) {
|
||||||
owner.transform(null, true);
|
owner.transform(null, true);
|
||||||
} else {
|
} else {
|
||||||
|
@ -156,16 +156,17 @@ var Matrix = Base.extend(/** @lends Matrix# */{
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Applies the matrix to the content of item that it belongs to, if
|
* Attempts to apply the matrix to the content of item that it belongs to,
|
||||||
* possible, meaning it bakes it into the item's content or children.
|
* meaning its transformation is baked into the item's content or children.
|
||||||
* @param {Boolean} recursively controls whether to apply transformations
|
* @param {Boolean} recursively controls whether to apply transformations
|
||||||
* recursively on children
|
* recursively on children
|
||||||
* @return {Boolean} {@true if the matrix was applied}
|
* @return {Boolean} {@true if the matrix was applied}
|
||||||
*/
|
*/
|
||||||
apply: function(recursively) {
|
apply: function(recursively, _setApplyMatrix) {
|
||||||
var owner = this._owner;
|
var owner = this._owner;
|
||||||
if (owner) {
|
if (owner) {
|
||||||
owner.transform(null, true, Base.pick(recursively, true));
|
owner.transform(null, true, Base.pick(recursively, true),
|
||||||
|
_setApplyMatrix);
|
||||||
// If the matrix was successfully applied, it will be reset now.
|
// If the matrix was successfully applied, it will be reset now.
|
||||||
return this.isIdentity();
|
return this.isIdentity();
|
||||||
}
|
}
|
||||||
|
|
|
@ -3021,11 +3021,12 @@ var Item = Base.extend(Emitter, /** @lends Item# */{
|
||||||
*
|
*
|
||||||
* @param {Matrix} matrix the matrix by which the item shall be transformed.
|
* @param {Matrix} matrix the matrix by which the item shall be transformed.
|
||||||
*/
|
*/
|
||||||
// Remove this for now:
|
// TODO: Implement flags:
|
||||||
// @param {String[]} flags Array of any of the following: 'objects',
|
// @param {String[]} flags Array of any of the following: 'objects',
|
||||||
// 'children', 'fill-gradients', 'fill-patterns', 'stroke-patterns',
|
// 'children', 'fill-gradients', 'fill-patterns', 'stroke-patterns',
|
||||||
// 'lines'. Default: ['objects', 'children']
|
// 'lines'. Default: ['objects', 'children']
|
||||||
transform: function(matrix, _applyMatrix, _applyRecursively) {
|
transform: function(matrix, _applyMatrix, _applyRecursively,
|
||||||
|
_setApplyMatrix) {
|
||||||
// If no matrix is provided, or the matrix is the identity, we might
|
// If no matrix is provided, or the matrix is the identity, we might
|
||||||
// still have some work to do in case _applyMatrix is true
|
// still have some work to do in case _applyMatrix is true
|
||||||
if (matrix && matrix.isIdentity())
|
if (matrix && matrix.isIdentity())
|
||||||
|
@ -3048,8 +3049,8 @@ var Item = Base.extend(Emitter, /** @lends Item# */{
|
||||||
// internal _matrix transformations to the item's content.
|
// internal _matrix transformations to the item's content.
|
||||||
// Application is not possible on Raster, PointText, PlacedSymbol, since
|
// Application is not possible on Raster, PointText, PlacedSymbol, since
|
||||||
// the matrix is where the actual transformation state is stored.
|
// the matrix is where the actual transformation state is stored.
|
||||||
if (applyMatrix = applyMatrix
|
if (applyMatrix = applyMatrix && this._transformContent(_matrix,
|
||||||
&& this._transformContent(_matrix, _applyRecursively)) {
|
_applyRecursively, _setApplyMatrix)) {
|
||||||
// When the _matrix could be applied, we also need to transform
|
// When the _matrix could be applied, we also need to transform
|
||||||
// color styles (only gradients so far) and pivot point:
|
// color styles (only gradients so far) and pivot point:
|
||||||
var pivot = this._pivot,
|
var pivot = this._pivot,
|
||||||
|
@ -3067,6 +3068,9 @@ var Item = Base.extend(Emitter, /** @lends Item# */{
|
||||||
// Reset the internal matrix to the identity transformation if it
|
// Reset the internal matrix to the identity transformation if it
|
||||||
// was possible to apply it.
|
// was possible to apply it.
|
||||||
_matrix.reset(true);
|
_matrix.reset(true);
|
||||||
|
// Set the internal _applyMatrix flag to true if we're told to do so
|
||||||
|
if (_setApplyMatrix && this._canApplyMatrix)
|
||||||
|
this._applyMatrix = true;
|
||||||
}
|
}
|
||||||
// Calling _changed will clear _bounds and _position, but depending
|
// Calling _changed will clear _bounds and _position, but depending
|
||||||
// on matrix we can calculate and set them again, so preserve them.
|
// on matrix we can calculate and set them again, so preserve them.
|
||||||
|
@ -3105,11 +3109,12 @@ var Item = Base.extend(Emitter, /** @lends Item# */{
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
_transformContent: function(matrix, applyRecursively) {
|
_transformContent: function(matrix, applyRecursively, setApplyMatrix) {
|
||||||
var children = this._children;
|
var children = this._children;
|
||||||
if (children) {
|
if (children) {
|
||||||
for (var i = 0, l = children.length; i < l; i++)
|
for (var i = 0, l = children.length; i < l; i++)
|
||||||
children[i].transform(matrix, true, applyRecursively);
|
children[i].transform(matrix, true, applyRecursively,
|
||||||
|
setApplyMatrix);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -587,13 +587,13 @@ new function() {
|
||||||
item,
|
item,
|
||||||
data = node.getAttribute && node.getAttribute('data-paper-data'),
|
data = node.getAttribute && node.getAttribute('data-paper-data'),
|
||||||
settings = scope.settings,
|
settings = scope.settings,
|
||||||
prevApplyMatrix = settings.applyMatrix;
|
applyMatrix = settings.applyMatrix;
|
||||||
// Have items imported from SVG not bake in all transformations to their
|
// Have items imported from SVG not bake in all transformations to their
|
||||||
// content and children, as this is how SVG works too, but preserve the
|
// content and children, as this is how SVG works too, but preserve the
|
||||||
// current setting so we can restore it after.
|
// current setting so we can restore it after.
|
||||||
settings.applyMatrix = false;
|
settings.applyMatrix = false;
|
||||||
item = importer && importer(node, type, options, isRoot) || null;
|
item = importer && importer(node, type, options, isRoot) || null;
|
||||||
settings.applyMatrix = prevApplyMatrix;
|
settings.applyMatrix = applyMatrix;
|
||||||
if (item) {
|
if (item) {
|
||||||
// Do not apply attributes if this is a #document node.
|
// Do not apply attributes if this is a #document node.
|
||||||
// See importGroup() for an explanation of filtering for Group:
|
// See importGroup() for an explanation of filtering for Group:
|
||||||
|
@ -612,8 +612,13 @@ new function() {
|
||||||
item._data = JSON.parse(data);
|
item._data = JSON.parse(data);
|
||||||
}
|
}
|
||||||
// Clear definitions at the end of import?
|
// Clear definitions at the end of import?
|
||||||
if (isRoot)
|
if (isRoot) {
|
||||||
definitions = {};
|
definitions = {};
|
||||||
|
// Now if settings.applyMatrix was set, apply recursively and set
|
||||||
|
// #applyMatrix = true on the item and all children.
|
||||||
|
if (applyMatrix && item)
|
||||||
|
item.matrix.apply(true, true);
|
||||||
|
}
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue