Merge pull request #19751 from Snuffleupagus/applyTransform-in-place
Change `Util.applyTransform` to use the point-argument as an in/out parameter
This commit is contained in:
commit
a45f961a1c
@ -1320,8 +1320,10 @@ class Annotation {
|
|||||||
const transform = getTransformMatrix(rect, bbox, matrix);
|
const transform = getTransformMatrix(rect, bbox, matrix);
|
||||||
transform[4] -= rect[0];
|
transform[4] -= rect[0];
|
||||||
transform[5] -= rect[1];
|
transform[5] -= rect[1];
|
||||||
coords = Util.applyTransform(coords, transform);
|
const p = coords.slice();
|
||||||
return Util.applyTransform(coords, matrix);
|
Util.applyTransform(p, transform);
|
||||||
|
Util.applyTransform(p, matrix);
|
||||||
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@ -524,11 +524,11 @@ addState(
|
|||||||
switch (buffer[k++]) {
|
switch (buffer[k++]) {
|
||||||
case DrawOPS.moveTo:
|
case DrawOPS.moveTo:
|
||||||
case DrawOPS.lineTo:
|
case DrawOPS.lineTo:
|
||||||
Util.applyTransformInPlace(buffer.subarray(k), transform);
|
Util.applyTransform(buffer.subarray(k), transform);
|
||||||
k += 2;
|
k += 2;
|
||||||
break;
|
break;
|
||||||
case DrawOPS.curveTo:
|
case DrawOPS.curveTo:
|
||||||
Util.applyTransformToBezierInPlace(buffer.subarray(k), transform);
|
Util.applyTransformToBezier(buffer.subarray(k), transform);
|
||||||
k += 6;
|
k += 6;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -340,10 +340,14 @@ class CanvasExtraState {
|
|||||||
}
|
}
|
||||||
|
|
||||||
updateRectMinMax(transform, rect) {
|
updateRectMinMax(transform, rect) {
|
||||||
const p1 = Util.applyTransform(rect, transform);
|
const p1 = [rect[0], rect[1]];
|
||||||
const p2 = Util.applyTransform(rect.slice(2), transform);
|
Util.applyTransform(p1, transform);
|
||||||
const p3 = Util.applyTransform([rect[0], rect[3]], transform);
|
const p2 = [rect[2], rect[3]];
|
||||||
const p4 = Util.applyTransform([rect[2], rect[1]], transform);
|
Util.applyTransform(p2, transform);
|
||||||
|
const p3 = [rect[0], rect[3]];
|
||||||
|
Util.applyTransform(p3, transform);
|
||||||
|
const p4 = [rect[2], rect[1]];
|
||||||
|
Util.applyTransform(p4, transform);
|
||||||
|
|
||||||
this.minX = Math.min(this.minX, p1[0], p2[0], p3[0], p4[0]);
|
this.minX = Math.min(this.minX, p1[0], p2[0], p3[0], p4[0]);
|
||||||
this.minY = Math.min(this.minY, p1[1], p2[1], p3[1], p4[1]);
|
this.minY = Math.min(this.minY, p1[1], p2[1], p3[1], p4[1]);
|
||||||
@ -2109,8 +2113,9 @@ class CanvasGraphics {
|
|||||||
this.restore();
|
this.restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
const transformed = Util.applyTransform([glyph.width, 0], fontMatrix);
|
const p = [glyph.width, 0];
|
||||||
width = transformed[0] * fontSize + spacing;
|
Util.applyTransform(p, fontMatrix);
|
||||||
|
width = p[0] * fontSize + spacing;
|
||||||
|
|
||||||
ctx.translate(width, 0);
|
ctx.translate(width, 0);
|
||||||
current.x += width * textHScale;
|
current.x += width * textHScale;
|
||||||
@ -2587,8 +2592,9 @@ class CanvasGraphics {
|
|||||||
positions[i + 1],
|
positions[i + 1],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
const [x, y] = Util.applyTransform([0, 0], trans);
|
// Here we want to apply the transform at the origin,
|
||||||
ctx.drawImage(mask.canvas, x, y);
|
// hence no additional computation is necessary.
|
||||||
|
ctx.drawImage(mask.canvas, trans[4], trans[5]);
|
||||||
}
|
}
|
||||||
ctx.restore();
|
ctx.restore();
|
||||||
this.compose();
|
this.compose();
|
||||||
|
|||||||
@ -257,7 +257,9 @@ class PageViewport {
|
|||||||
* @see {@link convertToViewportRectangle}
|
* @see {@link convertToViewportRectangle}
|
||||||
*/
|
*/
|
||||||
convertToViewportPoint(x, y) {
|
convertToViewportPoint(x, y) {
|
||||||
return Util.applyTransform([x, y], this.transform);
|
const p = [x, y];
|
||||||
|
Util.applyTransform(p, this.transform);
|
||||||
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -268,8 +270,10 @@ class PageViewport {
|
|||||||
* @see {@link convertToViewportPoint}
|
* @see {@link convertToViewportPoint}
|
||||||
*/
|
*/
|
||||||
convertToViewportRectangle(rect) {
|
convertToViewportRectangle(rect) {
|
||||||
const topLeft = Util.applyTransform([rect[0], rect[1]], this.transform);
|
const topLeft = [rect[0], rect[1]];
|
||||||
const bottomRight = Util.applyTransform([rect[2], rect[3]], this.transform);
|
Util.applyTransform(topLeft, this.transform);
|
||||||
|
const bottomRight = [rect[2], rect[3]];
|
||||||
|
Util.applyTransform(bottomRight, this.transform);
|
||||||
return [topLeft[0], topLeft[1], bottomRight[0], bottomRight[1]];
|
return [topLeft[0], topLeft[1], bottomRight[0], bottomRight[1]];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -283,7 +287,9 @@ class PageViewport {
|
|||||||
* @see {@link convertToViewportPoint}
|
* @see {@link convertToViewportPoint}
|
||||||
*/
|
*/
|
||||||
convertToPdfPoint(x, y) {
|
convertToPdfPoint(x, y) {
|
||||||
return Util.applyInverseTransform([x, y], this.transform);
|
const p = [x, y];
|
||||||
|
Util.applyInverseTransform(p, this.transform);
|
||||||
|
return p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -742,19 +742,13 @@ class Util {
|
|||||||
|
|
||||||
// For 2d affine transforms
|
// For 2d affine transforms
|
||||||
static applyTransform(p, m) {
|
static applyTransform(p, m) {
|
||||||
const xt = p[0] * m[0] + p[1] * m[2] + m[4];
|
|
||||||
const yt = p[0] * m[1] + p[1] * m[3] + m[5];
|
|
||||||
return [xt, yt];
|
|
||||||
}
|
|
||||||
|
|
||||||
static applyTransformInPlace(p, m) {
|
|
||||||
const [p0, p1] = p;
|
const [p0, p1] = p;
|
||||||
p[0] = p0 * m[0] + p1 * m[2] + m[4];
|
p[0] = p0 * m[0] + p1 * m[2] + m[4];
|
||||||
p[1] = p0 * m[1] + p1 * m[3] + m[5];
|
p[1] = p0 * m[1] + p1 * m[3] + m[5];
|
||||||
}
|
}
|
||||||
|
|
||||||
// For 2d affine transforms
|
// For 2d affine transforms
|
||||||
static applyTransformToBezierInPlace(p, [m0, m1, m2, m3, m4, m5]) {
|
static applyTransformToBezier(p, [m0, m1, m2, m3, m4, m5]) {
|
||||||
for (let i = 0; i < 6; i += 2) {
|
for (let i = 0; i < 6; i += 2) {
|
||||||
const pI = p[i];
|
const pI = p[i];
|
||||||
const pI1 = p[i + 1];
|
const pI1 = p[i + 1];
|
||||||
@ -764,19 +758,23 @@ class Util {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static applyInverseTransform(p, m) {
|
static applyInverseTransform(p, m) {
|
||||||
|
const [p0, p1] = p;
|
||||||
const d = m[0] * m[3] - m[1] * m[2];
|
const d = m[0] * m[3] - m[1] * m[2];
|
||||||
const xt = (p[0] * m[3] - p[1] * m[2] + m[2] * m[5] - m[4] * m[3]) / d;
|
p[0] = (p0 * m[3] - p1 * m[2] + m[2] * m[5] - m[4] * m[3]) / d;
|
||||||
const yt = (-p[0] * m[1] + p[1] * m[0] + m[4] * m[1] - m[5] * m[0]) / d;
|
p[1] = (-p0 * m[1] + p1 * m[0] + m[4] * m[1] - m[5] * m[0]) / d;
|
||||||
return [xt, yt];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Applies the transform to the rectangle and finds the minimum axially
|
// Applies the transform to the rectangle and finds the minimum axially
|
||||||
// aligned bounding box.
|
// aligned bounding box.
|
||||||
static getAxialAlignedBoundingBox(r, m) {
|
static getAxialAlignedBoundingBox(r, m) {
|
||||||
const p1 = this.applyTransform(r, m);
|
const p1 = [r[0], r[1]];
|
||||||
const p2 = this.applyTransform(r.slice(2, 4), m);
|
Util.applyTransform(p1, m);
|
||||||
const p3 = this.applyTransform([r[0], r[3]], m);
|
const p2 = [r[2], r[3]];
|
||||||
const p4 = this.applyTransform([r[2], r[1]], m);
|
Util.applyTransform(p2, m);
|
||||||
|
const p3 = [r[0], r[3]];
|
||||||
|
Util.applyTransform(p3, m);
|
||||||
|
const p4 = [r[2], r[1]];
|
||||||
|
Util.applyTransform(p4, m);
|
||||||
return [
|
return [
|
||||||
Math.min(p1[0], p2[0], p3[0], p4[0]),
|
Math.min(p1[0], p2[0], p3[0], p4[0]),
|
||||||
Math.min(p1[1], p2[1], p3[1], p4[1]),
|
Math.min(p1[1], p2[1], p3[1], p4[1]),
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user