From cbc85b4bb66d5c1a2d50d199e8bf33836f2f12d7 Mon Sep 17 00:00:00 2001 From: ZhangShine Date: Wed, 7 Apr 2021 15:52:58 +0800 Subject: [PATCH] lineWidth should be nonnegative (#3132) --- src/modules/context2d.js | 2 +- test/specs/context2d.spec.js | 28 ++++++++++++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/src/modules/context2d.js b/src/modules/context2d.js index 495992797..eb7edee14 100644 --- a/src/modules/context2d.js +++ b/src/modules/context2d.js @@ -1722,7 +1722,7 @@ import { var strokeStyle = this.strokeStyle; var lineCap = this.lineCap; var oldLineWidth = this.lineWidth; - var lineWidth = oldLineWidth * this.ctx.transform.scaleX; + var lineWidth = Math.abs(oldLineWidth * this.ctx.transform.scaleX); var lineJoin = this.lineJoin; var origPath = JSON.parse(JSON.stringify(this.path)); diff --git a/test/specs/context2d.spec.js b/test/specs/context2d.spec.js index 8d7472553..669f5af17 100644 --- a/test/specs/context2d.spec.js +++ b/test/specs/context2d.spec.js @@ -555,4 +555,32 @@ describe("Context2D: standard tests", () => { comparePdf(doc.output(), "autoPaging10Pages.pdf", "context2d"); }); + + it("lineWidth should be nonnegative", ()=>{ + var doc = new jsPDF({ + orientation: "p", + unit: "pt", + format: "a4", + floatPrecision: 3 + }); + var ctx = doc.context2d; + var writeArray = []; + doc.__private__.setCustomOutputDestination(writeArray); + + ctx.beginPath(); + ctx.strokeStyle = "#FF0000"; + ctx.transform(-1, 0, 0, 1, 0, 0); + ctx.moveTo(0, 0); + ctx.lineTo(100, 100); + ctx.stroke(); + + expect(writeArray).toEqual([ + "1. 0. 0. RG", + "1. w", // <- should be nonnegative + "0. 841.89 m", + "-100. 741.89 l", + "S", + "1. w" + ]); + }); });