mirror of
https://github.com/Hopiu/fabric.js.git
synced 2026-03-16 22:10:32 +00:00
added test for dataUrl (#4705)
This commit is contained in:
parent
d8dab88a46
commit
361db0b8a2
2 changed files with 77 additions and 2 deletions
|
|
@ -41,7 +41,7 @@
|
|||
|
||||
var format = options.format || 'png',
|
||||
quality = options.quality || 1,
|
||||
multiplier = options.multiplier || (options.enableRetinaScaling ? 1 : 1 / this.getRetinaScaling()),
|
||||
multiplier = (options.multiplier || 1) * (options.enableRetinaScaling ? 1 : 1 / this.getRetinaScaling()),
|
||||
cropping = {
|
||||
left: options.left || 0,
|
||||
top: options.top || 0,
|
||||
|
|
|
|||
|
|
@ -470,7 +470,7 @@
|
|||
}
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: true', function(assert) {
|
||||
QUnit.test('toDataURL with enableRetinaScaling: true and no multiplier', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
|
|
@ -485,6 +485,81 @@
|
|||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: true and multiplier = 1', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
var dataUrl = c.toDataURL({ enableRetinaScaling: true, multiplier: 1 });
|
||||
var img = fabric.document.createElement('img');
|
||||
img.onload = function() {
|
||||
assert.equal(img.width, c.width * fabric.devicePixelRatio, 'output width is bigger');
|
||||
assert.equal(img.height, c.height * fabric.devicePixelRatio, 'output height is bigger');
|
||||
fabric.devicePixelRatio = 1;
|
||||
done();
|
||||
};
|
||||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: true and multiplier = 3', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
var dataUrl = c.toDataURL({ enableRetinaScaling: true, multiplier: 3 });
|
||||
var img = fabric.document.createElement('img');
|
||||
img.onload = function() {
|
||||
assert.equal(img.width, c.width * fabric.devicePixelRatio * 3, 'output width is bigger by 6');
|
||||
assert.equal(img.height, c.height * fabric.devicePixelRatio * 3, 'output height is bigger by 6');
|
||||
fabric.devicePixelRatio = 1;
|
||||
done();
|
||||
};
|
||||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: false and no multiplier', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
var dataUrl = c.toDataURL({ enableRetinaScaling: false });
|
||||
var img = fabric.document.createElement('img');
|
||||
img.onload = function() {
|
||||
assert.equal(img.width, c.width, 'output width is not bigger');
|
||||
assert.equal(img.height, c.height, 'output height is not bigger');
|
||||
fabric.devicePixelRatio = 1;
|
||||
done();
|
||||
};
|
||||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: false and multiplier = 1', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
var dataUrl = c.toDataURL({ enableRetinaScaling: false, multiplier: 1 });
|
||||
var img = fabric.document.createElement('img');
|
||||
img.onload = function() {
|
||||
assert.equal(img.width, c.width, 'output width is not bigger');
|
||||
assert.equal(img.height, c.height, 'output height is not bigger');
|
||||
fabric.devicePixelRatio = 1;
|
||||
done();
|
||||
};
|
||||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: false and multiplier = 3', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
var c = new fabric.StaticCanvas(null, { enableRetinaScaling: true, width: 10, height: 10 });
|
||||
var dataUrl = c.toDataURL({ enableRetinaScaling: false, multiplier: 3 });
|
||||
var img = fabric.document.createElement('img');
|
||||
img.onload = function() {
|
||||
assert.equal(img.width, c.width * 3, 'output width is bigger by 3');
|
||||
assert.equal(img.height, c.height * 3, 'output height is bigger by 3');
|
||||
fabric.devicePixelRatio = 1;
|
||||
done();
|
||||
};
|
||||
img.src = dataUrl;
|
||||
});
|
||||
|
||||
QUnit.test('toDataURL with enableRetinaScaling: false', function(assert) {
|
||||
var done = assert.async();
|
||||
fabric.devicePixelRatio = 2;
|
||||
|
|
|
|||
Loading…
Reference in a new issue