Skip to content

Commit

Permalink
Merge pull request #7184 from yurydelendik/pad-mesh
Browse files Browse the repository at this point in the history
[Bug 1260585] Stops bleeding of pattern edges for mesh.
  • Loading branch information
Snuffleupagus committed Apr 12, 2016
2 parents be6754a + 398e6ac commit 127e6d7
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 5 deletions.
20 changes: 15 additions & 5 deletions src/display/pattern_helper.js
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,9 @@ var createMeshCanvas = (function createMeshCanvasClosure() {
var EXPECTED_SCALE = 1.1;
// MAX_PATTERN_SIZE is used to avoid OOM situation.
var MAX_PATTERN_SIZE = 3000; // 10in @ 300dpi shall be enough
// We need to keep transparent border around our pattern for fill():
// createPattern with 'no-repeat' will bleed edges accross entire area.
var BORDER_SIZE = 2;

var offsetX = Math.floor(bounds[0]);
var offsetY = Math.floor(bounds[1]);
Expand All @@ -191,17 +194,22 @@ var createMeshCanvas = (function createMeshCanvasClosure() {
scaleY: 1 / scaleY
};

var paddedWidth = width + BORDER_SIZE * 2;
var paddedHeight = height + BORDER_SIZE * 2;

var canvas, tmpCanvas, i, ii;
if (WebGLUtils.isEnabled) {
canvas = WebGLUtils.drawFigures(width, height, backgroundColor,
figures, context);

// https://bugzilla.mozilla.org/show_bug.cgi?id=972126
tmpCanvas = cachedCanvases.getCanvas('mesh', width, height, false);
tmpCanvas.context.drawImage(canvas, 0, 0);
tmpCanvas = cachedCanvases.getCanvas('mesh', paddedWidth, paddedHeight,
false);
tmpCanvas.context.drawImage(canvas, BORDER_SIZE, BORDER_SIZE);
canvas = tmpCanvas.canvas;
} else {
tmpCanvas = cachedCanvases.getCanvas('mesh', width, height, false);
tmpCanvas = cachedCanvases.getCanvas('mesh', paddedWidth, paddedHeight,
false);
var tmpCtx = tmpCanvas.context;

var data = tmpCtx.createImageData(width, height);
Expand All @@ -217,11 +225,13 @@ var createMeshCanvas = (function createMeshCanvasClosure() {
for (i = 0; i < figures.length; i++) {
drawFigure(data, figures[i], context);
}
tmpCtx.putImageData(data, 0, 0);
tmpCtx.putImageData(data, BORDER_SIZE, BORDER_SIZE);
canvas = tmpCanvas.canvas;
}

return {canvas: canvas, offsetX: offsetX, offsetY: offsetY,
return {canvas: canvas,
offsetX: offsetX - BORDER_SIZE * scaleX,
offsetY: offsetY - BORDER_SIZE * scaleY,
scaleX: scaleX, scaleY: scaleY};
}
return createMeshCanvas;
Expand Down
1 change: 1 addition & 0 deletions test/pdfs/bug1260585.pdf.link
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
https://bugzilla.mozilla.org/attachment.cgi?id=8736063
8 changes: 8 additions & 0 deletions test/test_manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -2204,6 +2204,14 @@
"link": true,
"type": "load"
},
{ "id": "bug1260585",
"file": "pdfs/bug1260585.pdf",
"md5": "9415b1eb00a43c97c15328cd4c8d136a",
"rounds": 1,
"lastPage": 1,
"link": true,
"type": "load"
},
{ "id": "issue3062",
"file": "pdfs/issue3062.pdf",
"md5": "206715f1258f0e117df4180d98dd4d68",
Expand Down

0 comments on commit 127e6d7

Please sign in to comment.