jdk/src/share/classes/java/awt/Cursor.java
author mchung
Tue, 08 Dec 2009 09:02:09 -0800
changeset 4374 f672d9cf521e
parent 3938 ef327bd847c0
child 5506 202f599c92aa
permissions -rw-r--r--
6907568: java/awt/KeyboardFocusManager.java inproperly merged and lost a changeset Summary: Reapply fix for 6879044 in java.awt.KeyboardFocusManager Reviewed-by: dcherepanov, asaha
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
90ce3da70b43 Initial load
duke
parents:
diff changeset
     2
 * Copyright 1996-2007 Sun Microsystems, Inc.  All Rights Reserved.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Sun designates this
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 * by Sun in the LICENSE file that accompanied this code.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 * CA 95054 USA or visit www.sun.com if you need additional information or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
 * have any questions.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
package java.awt;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
import java.awt.AWTException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
import java.awt.Point;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
import java.awt.Toolkit;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
import java.io.File;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
import java.io.FileInputStream;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
import java.beans.ConstructorProperties;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
import java.util.Hashtable;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
import java.util.Properties;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
import java.util.StringTokenizer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
3938
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
    39
import java.security.AccessController;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
3938
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
    41
import sun.util.logging.PlatformLogger;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
 * A class to encapsulate the bitmap representation of the mouse cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
 * @see Component#setCursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
 * @author      Amy Fowler
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
public class Cursor implements java.io.Serializable {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
     * The default cursor type (gets set if no cursor is defined).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
    public static final int     DEFAULT_CURSOR                  = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
     * The crosshair cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
    public static final int     CROSSHAIR_CURSOR                = 1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
     * The text cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
    public static final int     TEXT_CURSOR                     = 2;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
     * The wait cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
    public static final int     WAIT_CURSOR                     = 3;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
     * The south-west-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
    public static final int     SW_RESIZE_CURSOR                = 4;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
     * The south-east-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
    public static final int     SE_RESIZE_CURSOR                = 5;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
     * The north-west-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
    public static final int     NW_RESIZE_CURSOR                = 6;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
     * The north-east-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
    public static final int     NE_RESIZE_CURSOR                = 7;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
     * The north-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
    public static final int     N_RESIZE_CURSOR                 = 8;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
     * The south-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
    public static final int     S_RESIZE_CURSOR                 = 9;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
     * The west-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
    public static final int     W_RESIZE_CURSOR                 = 10;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
     * The east-resize cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
    public static final int     E_RESIZE_CURSOR                 = 11;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
     * The hand cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
    public static final int     HAND_CURSOR                     = 12;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
     * The move cursor type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
    public static final int     MOVE_CURSOR                     = 13;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   121
    /**
3711
675253c23780 6877122: Many javadoc warnings from java.awt.Window, other awt classes
darcy
parents: 3445
diff changeset
   122
      * @deprecated As of JDK version 1.7, the {@link #getPredefinedCursor(int)}
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   123
      * method should be used instead.
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   124
      */
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   125
    @Deprecated
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
    protected static Cursor predefined[] = new Cursor[14];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   128
    /**
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   129
     * This field is a private replacement for 'predefined' array.
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   130
     */
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   131
    private final static Cursor[] predefinedPrivate = new Cursor[14];
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   132
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
    /* Localization names and default values */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
    static final String[][] cursorProperties = {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
        { "AWT.DefaultCursor", "Default Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
        { "AWT.CrosshairCursor", "Crosshair Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
        { "AWT.TextCursor", "Text Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
        { "AWT.WaitCursor", "Wait Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
        { "AWT.SWResizeCursor", "Southwest Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
        { "AWT.SEResizeCursor", "Southeast Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
        { "AWT.NWResizeCursor", "Northwest Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
        { "AWT.NEResizeCursor", "Northeast Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
        { "AWT.NResizeCursor", "North Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
        { "AWT.SResizeCursor", "South Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
        { "AWT.WResizeCursor", "West Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
        { "AWT.EResizeCursor", "East Resize Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
        { "AWT.HandCursor", "Hand Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
        { "AWT.MoveCursor", "Move Cursor" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
    };
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
     * The chosen cursor type initially set to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
     * the <code>DEFAULT_CURSOR</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
     * @serial
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
     * @see #getType()
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
    int type = DEFAULT_CURSOR;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
     * The type associated with all custom cursors.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
    public static final int     CUSTOM_CURSOR                   = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
     * hashtable, filesystem dir prefix, filename, and properties for custom cursors support
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
    private static final Hashtable  systemCustomCursors         = new Hashtable(1);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
    private static final String systemCustomCursorDirPrefix = initCursorDir();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
    private static String initCursorDir() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
        String jhome =  (String) java.security.AccessController.doPrivileged(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
               new sun.security.action.GetPropertyAction("java.home"));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
        return jhome +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
            File.separator + "lib" + File.separator + "images" +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
            File.separator + "cursors" + File.separator;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
    private static final String     systemCustomCursorPropertiesFile = systemCustomCursorDirPrefix + "cursors.properties";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
    private static       Properties systemCustomCursorProperties = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
    private static final String CursorDotPrefix  = "Cursor.";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
    private static final String DotFileSuffix    = ".File";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
    private static final String DotHotspotSuffix = ".HotSpot";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
    private static final String DotNameSuffix    = ".Name";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
     * JDK 1.1 serialVersionUID
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
    private static final long serialVersionUID = 8028237497568985504L;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
3938
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
   194
    private static final PlatformLogger log = PlatformLogger.getLogger("java.awt.Cursor");
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
90ce3da70b43 Initial load
duke
parents:
diff changeset
   196
    static {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
        /* ensure that the necessary native libraries are loaded */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
        Toolkit.loadLibraries();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
        if (!GraphicsEnvironment.isHeadless()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
            initIDs();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   201
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   202
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   203
90ce3da70b43 Initial load
duke
parents:
diff changeset
   204
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   205
     * Initialize JNI field and method IDs for fields that may be
90ce3da70b43 Initial load
duke
parents:
diff changeset
   206
     * accessed from C.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   207
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
    private static native void initIDs();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   209
90ce3da70b43 Initial load
duke
parents:
diff changeset
   210
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   211
     * Hook into native data.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
    private transient long pData;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   214
90ce3da70b43 Initial load
duke
parents:
diff changeset
   215
    private transient Object anchor = new Object();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   216
90ce3da70b43 Initial load
duke
parents:
diff changeset
   217
    static class CursorDisposer implements sun.java2d.DisposerRecord {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   218
        volatile long pData;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   219
        public CursorDisposer(long pData) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   220
            this.pData = pData;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   221
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
        public void dispose() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   223
            if (pData != 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
                finalizeImpl(pData);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   226
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   227
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
    transient CursorDisposer disposer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
    private void setPData(long pData) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
        this.pData = pData;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
        if (GraphicsEnvironment.isHeadless()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
        if (disposer == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
            disposer = new CursorDisposer(pData);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
            // anchor is null after deserialization
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
            if (anchor == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
                anchor = new Object();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   239
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
            sun.java2d.Disposer.addRecord(anchor, disposer);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
            disposer.pData = pData;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
90ce3da70b43 Initial load
duke
parents:
diff changeset
   246
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   247
     * The user-visible name of the cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   248
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   249
     * @serial
90ce3da70b43 Initial load
duke
parents:
diff changeset
   250
     * @see #getName()
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   252
    protected String name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   253
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   255
     * Returns a cursor object with the specified predefined type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   256
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   257
     * @param type the type of predefined cursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
   258
     * @return the specified predefined cursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
   259
     * @throws IllegalArgumentException if the specified cursor type is
90ce3da70b43 Initial load
duke
parents:
diff changeset
   260
     *         invalid
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
    static public Cursor getPredefinedCursor(int type) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   263
        if (type < Cursor.DEFAULT_CURSOR || type > Cursor.MOVE_CURSOR) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
            throw new IllegalArgumentException("illegal cursor type");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
        }
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   266
        Cursor c = predefinedPrivate[type];
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   267
        if (c == null) {
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   268
            predefinedPrivate[type] = c = new Cursor(type);
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   269
        }
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   270
        // fill 'predefined' array for backwards compatibility.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
        if (predefined[type] == null) {
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   272
            predefined[type] = c;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
        }
3445
39d00a6cac5e 6656586: Cursor.predefined is protected static mutable (findbugs)
art
parents: 2
diff changeset
   274
        return c;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
     * Returns a system-specific custom cursor object matching the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
     * specified name.  Cursor names are, for example: "Invalid.16x16"
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
     * @param name a string describing the desired system-specific custom cursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
   282
     * @return the system specific custom cursor named
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
     * @exception HeadlessException if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
     * <code>GraphicsEnvironment.isHeadless</code> returns true
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
    static public Cursor getSystemCustomCursor(final String name)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
        throws AWTException, HeadlessException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
        GraphicsEnvironment.checkHeadless();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
        Cursor cursor = (Cursor)systemCustomCursors.get(name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
        if (cursor == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
            synchronized(systemCustomCursors) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
                if (systemCustomCursorProperties == null)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
                    loadSystemCustomCursorProperties();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
            String prefix = CursorDotPrefix + name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
            String key    = prefix + DotFileSuffix;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
            if (!systemCustomCursorProperties.containsKey(key)) {
3938
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
   301
                if (log.isLoggable(PlatformLogger.FINER)) {
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
   302
                    log.finer("Cursor.getSystemCustomCursor(" + name + ") returned null");
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   303
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   304
                return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
            final String fileName =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
                systemCustomCursorProperties.getProperty(key);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   309
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
            String localized = (String)systemCustomCursorProperties.getProperty(prefix + DotNameSuffix);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   311
90ce3da70b43 Initial load
duke
parents:
diff changeset
   312
            if (localized == null) localized = name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
90ce3da70b43 Initial load
duke
parents:
diff changeset
   314
            String hotspot = (String)systemCustomCursorProperties.getProperty(prefix + DotHotspotSuffix);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   315
90ce3da70b43 Initial load
duke
parents:
diff changeset
   316
            if (hotspot == null)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   317
                throw new AWTException("no hotspot property defined for cursor: " + name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   318
90ce3da70b43 Initial load
duke
parents:
diff changeset
   319
            StringTokenizer st = new StringTokenizer(hotspot, ",");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   320
90ce3da70b43 Initial load
duke
parents:
diff changeset
   321
            if (st.countTokens() != 2)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   322
                throw new AWTException("failed to parse hotspot property for cursor: " + name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   323
90ce3da70b43 Initial load
duke
parents:
diff changeset
   324
            int x = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   325
            int y = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   326
90ce3da70b43 Initial load
duke
parents:
diff changeset
   327
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   328
                x = Integer.parseInt(st.nextToken());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   329
                y = Integer.parseInt(st.nextToken());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   330
            } catch (NumberFormatException nfe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   331
                throw new AWTException("failed to parse hotspot property for cursor: " + name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   332
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   333
90ce3da70b43 Initial load
duke
parents:
diff changeset
   334
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   335
                final int fx = x;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   336
                final int fy = y;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   337
                final String flocalized = localized;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   338
90ce3da70b43 Initial load
duke
parents:
diff changeset
   339
                cursor = (Cursor) java.security.AccessController.doPrivileged(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   340
                    new java.security.PrivilegedExceptionAction() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   341
                    public Object run() throws Exception {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   342
                        Toolkit toolkit = Toolkit.getDefaultToolkit();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   343
                        Image image = toolkit.getImage(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   344
                           systemCustomCursorDirPrefix + fileName);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   345
                        return toolkit.createCustomCursor(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   346
                                    image, new Point(fx,fy), flocalized);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   347
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   348
                });
90ce3da70b43 Initial load
duke
parents:
diff changeset
   349
            } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   350
                throw new AWTException(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   351
                    "Exception: " + e.getClass() + " " + e.getMessage() +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   352
                    " occurred while creating cursor " + name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   353
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   354
90ce3da70b43 Initial load
duke
parents:
diff changeset
   355
            if (cursor == null) {
3938
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
   356
                if (log.isLoggable(PlatformLogger.FINER)) {
ef327bd847c0 6879044: Eliminate the dependency on logging from the AWT/2D/Swing classes
mchung
parents: 3711
diff changeset
   357
                    log.finer("Cursor.getSystemCustomCursor(" + name + ") returned null");
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   358
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   359
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   360
                systemCustomCursors.put(name, cursor);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   361
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   362
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   363
90ce3da70b43 Initial load
duke
parents:
diff changeset
   364
        return cursor;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   365
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   366
90ce3da70b43 Initial load
duke
parents:
diff changeset
   367
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   368
     * Return the system default cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   369
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   370
    static public Cursor getDefaultCursor() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   371
        return getPredefinedCursor(Cursor.DEFAULT_CURSOR);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   372
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   373
90ce3da70b43 Initial load
duke
parents:
diff changeset
   374
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   375
     * Creates a new cursor object with the specified type.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   376
     * @param type the type of cursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
   377
     * @throws IllegalArgumentException if the specified cursor type
90ce3da70b43 Initial load
duke
parents:
diff changeset
   378
     * is invalid
90ce3da70b43 Initial load
duke
parents:
diff changeset
   379
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   380
    @ConstructorProperties({"type"})
90ce3da70b43 Initial load
duke
parents:
diff changeset
   381
    public Cursor(int type) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   382
        if (type < Cursor.DEFAULT_CURSOR || type > Cursor.MOVE_CURSOR) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   383
            throw new IllegalArgumentException("illegal cursor type");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   384
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   385
        this.type = type;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   386
90ce3da70b43 Initial load
duke
parents:
diff changeset
   387
        // Lookup localized name.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   388
        name = Toolkit.getProperty(cursorProperties[type][0],
90ce3da70b43 Initial load
duke
parents:
diff changeset
   389
                                   cursorProperties[type][1]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   390
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   391
90ce3da70b43 Initial load
duke
parents:
diff changeset
   392
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   393
     * Creates a new custom cursor object with the specified name.<p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   394
     * Note:  this constructor should only be used by AWT implementations
90ce3da70b43 Initial load
duke
parents:
diff changeset
   395
     * as part of their support for custom cursors.  Applications should
90ce3da70b43 Initial load
duke
parents:
diff changeset
   396
     * use Toolkit.createCustomCursor().
90ce3da70b43 Initial load
duke
parents:
diff changeset
   397
     * @param name the user-visible name of the cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   398
     * @see java.awt.Toolkit#createCustomCursor
90ce3da70b43 Initial load
duke
parents:
diff changeset
   399
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   400
    protected Cursor(String name) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   401
        this.type = Cursor.CUSTOM_CURSOR;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   402
        this.name = name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   403
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   404
90ce3da70b43 Initial load
duke
parents:
diff changeset
   405
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   406
     * Returns the type for this cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   407
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   408
    public int getType() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   409
        return type;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   410
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   411
90ce3da70b43 Initial load
duke
parents:
diff changeset
   412
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   413
     * Returns the name of this cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   414
     * @return    a localized description of this cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   415
     * @since     1.2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   416
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   417
    public String getName() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   418
        return name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   419
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   420
90ce3da70b43 Initial load
duke
parents:
diff changeset
   421
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   422
     * Returns a string representation of this cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   423
     * @return    a string representation of this cursor.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   424
     * @since     1.2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   425
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   426
    public String toString() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   427
        return getClass().getName() + "[" + getName() + "]";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   428
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   429
90ce3da70b43 Initial load
duke
parents:
diff changeset
   430
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   431
     * load the cursor.properties file
90ce3da70b43 Initial load
duke
parents:
diff changeset
   432
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   433
    private static void loadSystemCustomCursorProperties() throws AWTException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   434
        synchronized(systemCustomCursors) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   435
            systemCustomCursorProperties = new Properties();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   436
90ce3da70b43 Initial load
duke
parents:
diff changeset
   437
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   438
                AccessController.doPrivileged(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   439
                      new java.security.PrivilegedExceptionAction() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   440
                    public Object run() throws Exception {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   441
                        FileInputStream fis = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   442
                        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   443
                            fis = new FileInputStream(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   444
                                           systemCustomCursorPropertiesFile);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   445
                            systemCustomCursorProperties.load(fis);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   446
                        } finally {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   447
                            if (fis != null)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   448
                                fis.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   449
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   450
                        return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   451
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   452
                });
90ce3da70b43 Initial load
duke
parents:
diff changeset
   453
            } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   454
                systemCustomCursorProperties = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   455
                 throw new AWTException("Exception: " + e.getClass() + " " +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   456
                   e.getMessage() + " occurred while loading: " +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   457
                                        systemCustomCursorPropertiesFile);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   458
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   459
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   460
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   461
90ce3da70b43 Initial load
duke
parents:
diff changeset
   462
    private native static void finalizeImpl(long pData);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   463
}