diff --git a/src/mixins/object.svg_export.js b/src/mixins/object.svg_export.js
index acb86998616..20e85462027 100644
--- a/src/mixins/object.svg_export.js
+++ b/src/mixins/object.svg_export.js
@@ -60,8 +60,7 @@ fabric.util.object.extend(fabric.Object.prototype, /** @lends fabric.Object.prot
angle = this.getAngle(),
skewX = (this.getSkewX() % 360),
skewY = (this.getSkewY() % 360),
- vpt = !this.canvas || this.canvas.svgViewportTransformation ? this.getViewportTransform() : [1, 0, 0, 1, 0, 0],
- center = fabric.util.transformPoint(this.getCenterPoint(), vpt),
+ center = this.getCenterPoint(),
NUM_FRACTION_DIGITS = fabric.Object.NUM_FRACTION_DIGITS,
@@ -75,23 +74,23 @@ fabric.util.object.extend(fabric.Object.prototype, /** @lends fabric.Object.prot
? (' rotate(' + toFixed(angle, NUM_FRACTION_DIGITS) + ')')
: '',
- scalePart = (this.scaleX === 1 && this.scaleY === 1 && vpt[0] === 1 && vpt[3] === 1)
+ scalePart = (this.scaleX === 1 && this.scaleY === 1)
? '' :
(' scale(' +
- toFixed(this.scaleX * vpt[0], NUM_FRACTION_DIGITS) +
+ toFixed(this.scaleX, NUM_FRACTION_DIGITS) +
' ' +
- toFixed(this.scaleY * vpt[3], NUM_FRACTION_DIGITS) +
+ toFixed(this.scaleY, NUM_FRACTION_DIGITS) +
')'),
skewXPart = skewX !== 0 ? ' skewX(' + toFixed(skewX, NUM_FRACTION_DIGITS) + ')' : '',
skewYPart = skewY !== 0 ? ' skewY(' + toFixed(skewY, NUM_FRACTION_DIGITS) + ')' : '',
- addTranslateX = this.type === 'path-group' ? this.width * vpt[0] : 0,
+ addTranslateX = this.type === 'path-group' ? this.width : 0,
flipXPart = this.flipX ? ' matrix(-1 0 0 1 ' + addTranslateX + ' 0) ' : '',
- addTranslateY = this.type === 'path-group' ? this.height * vpt[3] : 0,
+ addTranslateY = this.type === 'path-group' ? this.height : 0,
flipYPart = this.flipY ? ' matrix(1 0 0 -1 0 ' + addTranslateY + ')' : '';
diff --git a/src/static_canvas.class.js b/src/static_canvas.class.js
index 57565a02db7..2823fdab4e5 100644
--- a/src/static_canvas.class.js
+++ b/src/static_canvas.class.js
@@ -11,6 +11,7 @@
var extend = fabric.util.object.extend,
getElementOffset = fabric.util.getElementOffset,
removeFromArray = fabric.util.removeFromArray,
+ toFixed = fabric.util.toFixed,
CANVAS_INIT_ERROR = new Error('Could not initialize `canvas` element');
@@ -1183,6 +1184,8 @@
* @param {Number} [options.viewBox.width] Width of viewbox
* @param {Number} [options.viewBox.height] Height of viewbox
* @param {String} [options.encoding=UTF-8] Encoding of SVG output
+ * @param {String} [options.width] desired width of svg with or without units
+ * @param {String} [options.height] desired height of svg with or without units
* @param {Function} [reviver] Method for further parsing of svg elements, called after each fabric object converted into svg representation.
* @return {String} SVG string
* @tutorial {@link http://fabricjs.com/fabric-intro-part-3/#serialization}
@@ -1232,32 +1235,40 @@
* @private
*/
_setSVGPreamble: function(markup, options) {
- if (!options.suppressPreamble) {
- markup.push(
- '\n',
- '\n'
- );
+ if (options.suppressPreamble) {
+ return;
}
+ markup.push(
+ '\n',
+ '\n'
+ );
},
/**
* @private
*/
_setSVGHeader: function(markup, options) {
- var width, height, vpt;
+ var width = options.width || this.width,
+ height = options.height || this.height,
+ vpt, viewBox = 'viewBox="0 0 ' + this.width + ' ' + this.height + '" ',
+ NUM_FRACTION_DIGITS = fabric.Object.NUM_FRACTION_DIGITS;
if (options.viewBox) {
- width = options.viewBox.width;
- height = options.viewBox.height;
+ viewBox = 'viewBox="' +
+ options.viewBox.x + ' ' +
+ options.viewBox.y + ' ' +
+ options.viewBox.width + ' ' +
+ options.viewBox.height + '" ';
}
else {
- width = this.width;
- height = this.height;
- if (!this.svgViewportTransformation) {
+ if (this.svgViewportTransformation) {
vpt = this.viewportTransform;
- width /= vpt[0];
- height /= vpt[3];
+ viewBox = 'viewBox="' +
+ toFixed(-vpt[4] / vpt[0], NUM_FRACTION_DIGITS) + ' ' +
+ toFixed(-vpt[5] / vpt[3], NUM_FRACTION_DIGITS) + ' ' +
+ toFixed(this.width / vpt[0], NUM_FRACTION_DIGITS) + ' ' +
+ toFixed(this.height / vpt[3], NUM_FRACTION_DIGITS) + '" ';
}
}
@@ -1271,13 +1282,7 @@
(this.backgroundColor && !this.backgroundColor.toLive
? 'style="background-color: ' + this.backgroundColor + '" '
: null),
- (options.viewBox
- ? 'viewBox="' +
- options.viewBox.x + ' ' +
- options.viewBox.y + ' ' +
- options.viewBox.width + ' ' +
- options.viewBox.height + '" '
- : null),
+ viewBox,
'xml:space="preserve">\n',
'Created with Fabric.js ', fabric.version, '\n',
'',
diff --git a/test/unit/canvas_static.js b/test/unit/canvas_static.js
index 8029671e325..359b63a37b2 100644
--- a/test/unit/canvas_static.js
+++ b/test/unit/canvas_static.js
@@ -3,10 +3,10 @@
// var emptyImageCanvasData = "";
var CANVAS_SVG = '\n\n'+
- '';
+ '';
var CANVAS_SVG_VIEWBOX = '\n\n'+
- '';
+ '';
var PATH_JSON = '{"objects": [{"type": "path", "originX": "left", "originY": "top", "left": 268, "top": 266, "width": 51, "height": 49,'+
' "fill": "rgb(0,0,0)", "stroke": null, "strokeWidth": 1, "scaleX": 1, "scaleY": 1, '+
diff --git a/test/unit/shadow.js b/test/unit/shadow.js
index 9f0fe6365bc..3fa28c7462f 100644
--- a/test/unit/shadow.js
+++ b/test/unit/shadow.js
@@ -132,15 +132,17 @@
ok(typeof shadow.toObject == 'function');
var object = shadow.toObject();
- equal(JSON.stringify(object), '{"color":"rgb(0,0,0)","blur":0,"offsetX":0,"offsetY":0}');
+ equal(JSON.stringify(object), '{"color":"rgb(0,0,0)","blur":0,"offsetX":0,"offsetY":0,"affectStroke":false}');
});
test('clone with affectStroke', function() {
var shadow = new fabric.Shadow({affectStroke: true, blur: 5});
ok(typeof shadow.toObject == 'function');
var object = shadow.toObject(),
- shadow2 = new fabric.Shadow(object);
- deepEqual(shadow, shadow2);
+ shadow2 = new fabric.Shadow(object),
+ object2 = shadow2.toObject();
+ equal(shadow.affectStroke, shadow2.affectStroke)
+ deepEqual(object, object2);
});
test('toObject without default value', function() {