-
-
Notifications
You must be signed in to change notification settings - Fork 3.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Resize filter should include canvas zoom and group zoom (#5117)
* change in zoom * added a test * fixed * disable gl * add percentage * more group things * more group things * added unit test * display percentage * lint
- Loading branch information
Showing
7 changed files
with
226 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
(function() { | ||
fabric.enableGLFiltering = false; | ||
var _pixelMatch = pixelmatch; | ||
if (fabric.isLikelyNode) { | ||
var fs = global.fs; | ||
_pixelMatch = global.pixelmatch; | ||
} | ||
var fabricCanvas = this.canvas = new fabric.Canvas(null, {enableRetinaScaling: false, renderOnAddRemove: false}); | ||
var pixelmatchOptions = { | ||
includeAA: false, | ||
threshold: 0.095 | ||
}; | ||
fabric.Object.prototype.objectCaching = false; | ||
|
||
function getAbsolutePath(path) { | ||
var isAbsolute = /^https?:/.test(path); | ||
if (isAbsolute) { return path; }; | ||
var imgEl = fabric.document.createElement('img'); | ||
imgEl.src = path; | ||
var src = imgEl.src; | ||
imgEl = null; | ||
return src; | ||
} | ||
|
||
function getFixtureName(filename) { | ||
var finalName = '/../fixtures/' + filename; | ||
return fabric.isLikelyNode ? (__dirname + finalName) : getAbsolutePath('test/fixtures/' + filename); | ||
} | ||
|
||
function getGoldeName(filename) { | ||
var finalName = '/golden/' + filename; | ||
return fabric.isLikelyNode ? (__dirname + finalName) : getAbsolutePath('test/visual/golden/' + filename); | ||
} | ||
|
||
function getImage(filename, original, callback) { | ||
if (fabric.isLikelyNode && original) { | ||
try { | ||
fs.statSync(filename); | ||
} | ||
catch (err) { | ||
var dataUrl = original.toDataURL().split(',')[1]; | ||
console.log('creating original for ', filename); | ||
fs.writeFileSync(filename, dataUrl, { encoding: 'base64' }); | ||
} | ||
} | ||
var img = fabric.document.createElement('img'); | ||
img.onload = function() { | ||
callback(img); | ||
}; | ||
img.onerror = function(err) { | ||
console.log('Image loading errored', err); | ||
}; | ||
img.src = filename; | ||
} | ||
|
||
QUnit.module('Image resize filter test', { | ||
afterEach: function() { | ||
fabricCanvas.setZoom(1); | ||
fabricCanvas.setDimensions({ | ||
width: 300, | ||
height: 150, | ||
}); | ||
fabricCanvas.clear(); | ||
fabricCanvas.renderAll(); | ||
} | ||
}); | ||
|
||
var tests = []; | ||
|
||
function imageResizeTest(canvas, callback) { | ||
getImage(getFixtureName('parrot.png'), false, function(img) { | ||
canvas.setDimensions({ | ||
width: 200, | ||
height: 200, | ||
}); | ||
var zoom = 8; | ||
var image = new fabric.Image(img); | ||
image.resizeFilter = new fabric.Image.filters.Resize({ resizeType: 'lanczos' }); | ||
canvas.setZoom(zoom); | ||
image.scaleToWidth(canvas.width / zoom); | ||
canvas.add(image); | ||
canvas.renderAll(); | ||
callback(canvas.lowerCanvasEl); | ||
}); | ||
} | ||
|
||
tests.push({ | ||
test: 'Image resize with canvas zoom', | ||
code: imageResizeTest, | ||
golden: 'parrot.png', | ||
percentage: 0.06, | ||
}); | ||
|
||
function imageResizeTestNoZoom(canvas, callback) { | ||
getImage(getFixtureName('parrot.png'), false, function(img) { | ||
canvas.setDimensions({ | ||
width: 200, | ||
height: 200, | ||
}); | ||
var image = new fabric.Image(img); | ||
image.resizeFilter = new fabric.Image.filters.Resize({ resizeType: 'lanczos' }); | ||
image.scaleToWidth(canvas.width); | ||
canvas.add(image); | ||
canvas.renderAll(); | ||
callback(canvas.lowerCanvasEl); | ||
}); | ||
} | ||
|
||
tests.push({ | ||
test: 'Image resize without zoom', | ||
code: imageResizeTestNoZoom, | ||
golden: 'parrot.png', | ||
percentage: 0.06, | ||
}); | ||
|
||
function imageResizeTestGroup(canvas, callback) { | ||
getImage(getFixtureName('parrot.png'), false, function(img) { | ||
canvas.setDimensions({ | ||
width: 200, | ||
height: 200, | ||
}); | ||
var image = new fabric.Image(img, { strokeWidth: 0 }); | ||
image.resizeFilter = new fabric.Image.filters.Resize({ resizeType: 'lanczos' }); | ||
var group = new fabric.Group([image]); | ||
group.strokeWidth = 0; | ||
group.scaleToWidth(canvas.width); | ||
canvas.add(group); | ||
canvas.renderAll(); | ||
callback(canvas.lowerCanvasEl); | ||
}); | ||
} | ||
|
||
tests.push({ | ||
test: 'Image resize with scaled group', | ||
code: imageResizeTestGroup, | ||
golden: 'parrot.png', | ||
percentage: 0.06, | ||
}); | ||
|
||
tests.forEach(function(testObj) { | ||
var testName = testObj.test; | ||
var code = testObj.code; | ||
var percentage = testObj.percentage; | ||
var golden = testObj.golden; | ||
QUnit.test(testName, function(assert) { | ||
var done = assert.async(); | ||
code(fabricCanvas, function(renderedCanvas) { | ||
var width = renderedCanvas.width; | ||
var height = renderedCanvas.height; | ||
var totalPixels = width * height; | ||
var imageDataCanvas = renderedCanvas.getContext('2d').getImageData(0, 0, width, height).data; | ||
var canvas = fabric.document.createElement('canvas'); | ||
canvas.width = width; | ||
canvas.height = height; | ||
var ctx = canvas.getContext('2d'); | ||
var output = ctx.getImageData(0, 0, width, height).data; | ||
getImage(getGoldeName(golden), renderedCanvas, function(golden) { | ||
ctx.drawImage(golden, 0, 0); | ||
var imageDataGolden = ctx.getImageData(0, 0, width, height).data; | ||
var differentPixels = _pixelMatch(imageDataCanvas, imageDataGolden, output, width, height, pixelmatchOptions); | ||
var percDiff = differentPixels / totalPixels * 100; | ||
var okDiff = totalPixels * percentage; | ||
assert.ok( | ||
differentPixels < okDiff, | ||
testName + ' has too many different pixels ' + differentPixels + '(' + okDiff + ') representing ' + percDiff + '%' | ||
); | ||
console.log('Different pixels:', differentPixels, '/', totalPixels, ' diff:', percDiff.toFixed(3), '%'); | ||
done(); | ||
}); | ||
}); | ||
}); | ||
}); | ||
})(); |