src/java.desktop/share/classes/sun/java2d/marlin/PathSimplifier.java
author phh
Sat, 30 Nov 2019 14:33:05 -0800
changeset 59330 5b96c12f909d
parent 49496 1ea202af7a97
permissions -rw-r--r--
8234541: C1 emits an empty message when it inlines successfully Summary: Use "inline" as the message when successfull Reviewed-by: thartmann, mdoerr Contributed-by: navy.xliu@gmail.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
49496
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     1
/*
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     2
 * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved.
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     4
 *
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    10
 *
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    15
 * accompanied this code).
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    16
 *
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    20
 *
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    23
 * questions.
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    24
 */
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    25
package sun.java2d.marlin;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    26
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    27
import sun.awt.geom.PathConsumer2D;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    28
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    29
final class PathSimplifier implements PathConsumer2D {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    30
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    31
    // distance threshold in pixels (device)
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    32
    private static final float PIX_THRESHOLD = MarlinProperties.getPathSimplifierPixelTolerance();
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    33
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    34
    private static final float SQUARE_TOLERANCE = PIX_THRESHOLD * PIX_THRESHOLD;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    35
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    36
    // members:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    37
    private PathConsumer2D delegate;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    38
    private float cx, cy;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    39
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    40
    PathSimplifier() {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    41
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    42
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    43
    PathSimplifier init(final PathConsumer2D delegate) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    44
        this.delegate = delegate;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    45
        return this; // fluent API
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    46
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    47
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    48
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    49
    public void pathDone() {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    50
        delegate.pathDone();
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    51
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    52
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    53
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    54
    public void closePath() {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    55
        delegate.closePath();
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    56
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    57
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    58
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    59
    public long getNativeConsumer() {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    60
        return 0;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    61
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    62
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    63
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    64
    public void quadTo(final float x1, final float y1,
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    65
                       final float xe, final float ye)
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    66
    {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    67
        // Test if curve is too small:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    68
        float dx = (xe - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    69
        float dy = (ye - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    70
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    71
        if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    72
            // check control points P1:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    73
            dx = (x1 - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    74
            dy = (y1 - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    75
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    76
            if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    77
                return;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    78
            }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    79
        }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    80
        delegate.quadTo(x1, y1, xe, ye);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    81
        // final end point:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    82
        cx = xe;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    83
        cy = ye;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    84
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    85
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    86
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    87
    public void curveTo(final float x1, final float y1,
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    88
                        final float x2, final float y2,
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    89
                        final float xe, final float ye)
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    90
    {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    91
        // Test if curve is too small:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    92
        float dx = (xe - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    93
        float dy = (ye - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    94
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    95
        if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    96
            // check control points P1:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    97
            dx = (x1 - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    98
            dy = (y1 - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
    99
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   100
            if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   101
                // check control points P2:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   102
                dx = (x2 - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   103
                dy = (y2 - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   104
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   105
                if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   106
                    return;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   107
                }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   108
            }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   109
        }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   110
        delegate.curveTo(x1, y1, x2, y2, xe, ye);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   111
        // final end point:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   112
        cx = xe;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   113
        cy = ye;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   114
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   115
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   116
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   117
    public void moveTo(final float xe, final float ye) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   118
        delegate.moveTo(xe, ye);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   119
        // starting point:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   120
        cx = xe;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   121
        cy = ye;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   122
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   123
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   124
    @Override
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   125
    public void lineTo(final float xe, final float ye) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   126
        // Test if segment is too small:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   127
        float dx = (xe - cx);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   128
        float dy = (ye - cy);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   129
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   130
        if ((dx * dx + dy * dy) <= SQUARE_TOLERANCE) {
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   131
            return;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   132
        }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   133
        delegate.lineTo(xe, ye);
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   134
        // final end point:
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   135
        cx = xe;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   136
        cy = ye;
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   137
    }
1ea202af7a97 8198885: upgrade Marlin (java2d) to 0.9.1
lbourges
parents:
diff changeset
   138
}