189 lines
5.3 KiB
Java
189 lines
5.3 KiB
Java
|
/*
|
||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||
|
*
|
||
|
* This code is free software; you can redistribute it and/or modify it
|
||
|
* under the terms of the GNU General Public License version 2 only, as
|
||
|
* published by the Free Software Foundation.
|
||
|
*
|
||
|
* This code 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 General Public License
|
||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||
|
* accompanied this code).
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License version
|
||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||
|
*
|
||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||
|
* or visit www.oracle.com if you need additional information or have any
|
||
|
* questions.
|
||
|
*/
|
||
|
|
||
|
import java.awt.geom.GeneralPath;
|
||
|
import java.awt.geom.Path2D;
|
||
|
|
||
|
/**
|
||
|
* @test
|
||
|
* @bug 8078464
|
||
|
* @summary Check the growth algorithm (needRoom) in Path2D implementations
|
||
|
* @run main Path2DGrow
|
||
|
*/
|
||
|
public class Path2DGrow {
|
||
|
|
||
|
public static final int N = 1000 * 1000;
|
||
|
|
||
|
public static boolean verbose = false;
|
||
|
public static boolean force = false;
|
||
|
|
||
|
static void echo(String msg) {
|
||
|
System.out.println(msg);
|
||
|
}
|
||
|
|
||
|
static void log(String msg) {
|
||
|
if (verbose || force) {
|
||
|
echo(msg);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public static void main(String argv[]) {
|
||
|
verbose = (argv.length != 0);
|
||
|
|
||
|
testEmptyDoublePaths();
|
||
|
testDoublePaths();
|
||
|
|
||
|
testEmptyFloatPaths();
|
||
|
testFloatPaths();
|
||
|
|
||
|
testEmptyGeneralPath();
|
||
|
testGeneralPath();
|
||
|
}
|
||
|
|
||
|
static void testEmptyDoublePaths() {
|
||
|
echo("\n - Test(Path2D.Double[0]) ---");
|
||
|
test(() -> new Path2D.Double(Path2D.WIND_NON_ZERO, 0));
|
||
|
}
|
||
|
|
||
|
static void testDoublePaths() {
|
||
|
echo("\n - Test(Path2D.Double) ---");
|
||
|
test(() -> new Path2D.Double());
|
||
|
}
|
||
|
|
||
|
static void testEmptyFloatPaths() {
|
||
|
echo("\n - Test(Path2D.Float[0]) ---");
|
||
|
test(() -> new Path2D.Float(Path2D.WIND_NON_ZERO, 0));
|
||
|
}
|
||
|
|
||
|
static void testFloatPaths() {
|
||
|
echo("\n - Test(Path2D.Float) ---");
|
||
|
test(() -> new Path2D.Float());
|
||
|
}
|
||
|
|
||
|
static void testEmptyGeneralPath() {
|
||
|
echo("\n - Test(GeneralPath[0]) ---");
|
||
|
test(() -> new GeneralPath(Path2D.WIND_NON_ZERO, 0));
|
||
|
}
|
||
|
|
||
|
static void testGeneralPath() {
|
||
|
echo("\n - Test(GeneralPath) ---");
|
||
|
test(() -> new GeneralPath());
|
||
|
}
|
||
|
|
||
|
interface PathFactory {
|
||
|
Path2D makePath();
|
||
|
}
|
||
|
|
||
|
static void test(PathFactory pf) {
|
||
|
long start, end;
|
||
|
|
||
|
for (int n = 1; n <= N; n *= 10) {
|
||
|
force = (n == N);
|
||
|
|
||
|
start = System.nanoTime();
|
||
|
testAddMoves(pf.makePath(), n);
|
||
|
end = System.nanoTime();
|
||
|
log("testAddMoves[" + n + "] duration= "
|
||
|
+ (1e-6 * (end - start)) + " ms.");
|
||
|
|
||
|
start = System.nanoTime();
|
||
|
testAddLines(pf.makePath(), n);
|
||
|
end = System.nanoTime();
|
||
|
log("testAddLines[" + n + "] duration= "
|
||
|
+ (1e-6 * (end - start)) + " ms.");
|
||
|
|
||
|
start = System.nanoTime();
|
||
|
testAddQuads(pf.makePath(), n);
|
||
|
end = System.nanoTime();
|
||
|
log("testAddQuads[" + n + "] duration= "
|
||
|
+ (1e-6 * (end - start)) + " ms.");
|
||
|
|
||
|
start = System.nanoTime();
|
||
|
testAddCubics(pf.makePath(), n);
|
||
|
end = System.nanoTime();
|
||
|
log("testAddCubics[" + n + "] duration= "
|
||
|
+ (1e-6 * (end - start)) + " ms.");
|
||
|
|
||
|
start = System.nanoTime();
|
||
|
testAddMoveAndCloses(pf.makePath(), n);
|
||
|
end = System.nanoTime();
|
||
|
log("testAddMoveAndCloses[" + n + "] duration= "
|
||
|
+ (1e-6 * (end - start)) + " ms.");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void addMove(Path2D p2d, int i) {
|
||
|
p2d.moveTo(1.0 * i, 0.5 * i);
|
||
|
}
|
||
|
|
||
|
static void addLine(Path2D p2d, int i) {
|
||
|
p2d.lineTo(1.1 * i, 2.3 * i);
|
||
|
}
|
||
|
|
||
|
static void addCubic(Path2D p2d, int i) {
|
||
|
p2d.curveTo(1.1 * i, 1.2 * i, 1.3 * i, 1.4 * i, 1.5 * i, 1.6 * i);
|
||
|
}
|
||
|
|
||
|
static void addQuad(Path2D p2d, int i) {
|
||
|
p2d.quadTo(1.1 * i, 1.2 * i, 1.3 * i, 1.4 * i);
|
||
|
}
|
||
|
|
||
|
static void addClose(Path2D p2d) {
|
||
|
p2d.closePath();
|
||
|
}
|
||
|
|
||
|
static void testAddMoves(Path2D pathA, int n) {
|
||
|
for (int i = 0; i < n; i++) {
|
||
|
addMove(pathA, i);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void testAddLines(Path2D pathA, int n) {
|
||
|
addMove(pathA, 0);
|
||
|
for (int i = 0; i < n; i++) {
|
||
|
addLine(pathA, i);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void testAddQuads(Path2D pathA, int n) {
|
||
|
addMove(pathA, 0);
|
||
|
for (int i = 0; i < n; i++) {
|
||
|
addQuad(pathA, i);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void testAddCubics(Path2D pathA, int n) {
|
||
|
addMove(pathA, 0);
|
||
|
for (int i = 0; i < n; i++) {
|
||
|
addCubic(pathA, i);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void testAddMoveAndCloses(Path2D pathA, int n) {
|
||
|
for (int i = 0; i < n; i++) {
|
||
|
addMove(pathA, i);
|
||
|
addClose(pathA);
|
||
|
}
|
||
|
}
|
||
|
}
|