ShapeTransformUtilTest.java
/*
This file is part of the iText (R) project.
Copyright (c) 1998-2025 Apryse Group NV
Authors: Apryse Software.
This program is offered under a commercial and under the AGPL license.
For commercial licensing, contact us at https://itextpdf.com/sales. For AGPL licensing, see below.
AGPL licensing:
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package com.itextpdf.kernel.geom;
import com.itextpdf.test.ExtendedITextTest;
import java.util.Arrays;
import java.util.Collections;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Tag;
@Tag("UnitTest")
public class ShapeTransformUtilTest extends ExtendedITextTest {
@Test
public void transformBezierCurveTest() {
BezierCurve inBezierCurve = new BezierCurve(Arrays.asList(new Point(0, 0), new Point(0, 5), new Point(5, 5), new Point(5, 0)));
Matrix ctm = new Matrix(1, 0, 0, 1, 5, 5);
BezierCurve outBezierCurve = ShapeTransformUtil.transformBezierCurve(inBezierCurve, ctm);
BezierCurve cmpBezierCurve = new BezierCurve(Arrays.asList(new Point(-5, -5), new Point(-5, 0), new Point(0, 0), new Point(0, -5)));
Assertions.assertArrayEquals(cmpBezierCurve.getBasePoints().toArray(), outBezierCurve.getBasePoints().toArray());
}
@Test
public void transformLineTest() {
Line inLine = new Line(new Point(0, 0), new Point(10, 10));
Matrix ctm = new Matrix(2, 0, 0, 1, 5, 5);
Line outLine = ShapeTransformUtil.transformLine(inLine, ctm);
Line cmpLine = new Line(new Point(-2.5, -5), new Point(2.5, 5));
Assertions.assertArrayEquals(cmpLine.getBasePoints().toArray(), outLine.getBasePoints().toArray());
}
@Test
public void transformPathTest() {
Line inLine = new Line(new Point(0, 0), new Point(10, 10));
BezierCurve inBezierCurve = new BezierCurve(Arrays.asList(new Point(0, 0), new Point(0, 5), new Point(5, 5), new Point(5, 0)));
Subpath inSubpath = new Subpath();
inSubpath.addSegment(inLine);
inSubpath.addSegment(inBezierCurve);
Path inPath = new Path(Collections.singletonList(inSubpath));
Matrix ctm = new Matrix(1, 0, 0, 1, 5, 5);
Path outPath = ShapeTransformUtil.transformPath(inPath, ctm);
Line cmpLine = new Line(new Point(-5, -5), new Point(5, 5));
BezierCurve cmpBezierCurve = new BezierCurve(Arrays.asList(new Point(-5, -5), new Point(-5, 0), new Point(0, 0), new Point(0, -5)));
Subpath cmpSubpath = new Subpath();
inSubpath.addSegment(cmpLine);
inSubpath.addSegment(cmpBezierCurve);
Path cmpPath = new Path(Collections.singletonList(cmpSubpath));
for (int i = 0; i < cmpPath.getSubpaths().size(); i++) {
Subpath subpath = cmpPath.getSubpaths().get(i);
for (int j = 0; j < subpath.getSegments().size(); j++) {
IShape cmpShape = subpath.getSegments().get(j);
IShape outShape = outPath.getSubpaths().get(i).getSegments().get(j);
Assertions.assertArrayEquals(cmpShape.getBasePoints().toArray(), outShape.getBasePoints().toArray());
}
}
}
}