/* * Copyright (c) 2008, 2009, 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. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * 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. */ package com.sun.awt; import java.awt.*; import java.awt.geom.*; import sun.awt.AWTAccessor; /** * Security Warning control interface. * * This class provides a couple of methods that help a developer relocate * the AWT security warning to an appropriate position relative to the current * window size. A "top-level window" is an instance of the {@code Window} * class (or its descendant, such as {@code JFrame}). The security warning * is applied to all windows created by an untrusted code. All such windows * have a non-null "warning string" (see {@link Window#getWarningString()}). * <p> * <b>WARNING</b>: This class is an implementation detail and only meant * for limited use outside of the core platform. This API may change * drastically between update release, and it may even be * removed or be moved to some other packages or classes. */ public final class SecurityWarning { /** * The SecurityWarning class should not be instantiated */ private SecurityWarning() { } /** * Gets the size of the security warning. * * The returned value is not valid until the peer has been created. Before * invoking this method a developer must call the {@link Window#pack()}, * {@link Window#setVisible()}, or some other method that creates the peer. * * @param window the window to get the security warning size for * * @throws NullPointerException if the window argument is null * @throws IllegalArgumentException if the window is trusted (i.e. * the {@code getWarningString()} returns null) */ public static Dimension getSize(Window window) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } if (window.getWarningString() == null) { throw new IllegalArgumentException( "The window must have a non-null warning string."); } // We don't check for a non-null peer since it may be destroyed // after assigning a valid value to the security warning size. return AWTAccessor.getWindowAccessor().getSecurityWarningSize(window); } /** * Sets the position of the security warning. * <p> * The {@code alignmentX} and {@code alignmentY} arguments specify the * origin of the coordinate system used to calculate the position of the * security warning. The values must be in the range [0.0f...1.0f]. The * {@code 0.0f} value represents the left (top) edge of the rectangular * bounds of the window. The {@code 1.0f} value represents the right * (bottom) edge of the bounds. Whenever the size of the window changes, * the origin of the coordinate system gets relocated accordingly. For * convenience a developer may use the {@code Component.*_ALIGNMENT} * constants to pass predefined values for these arguments. * <p> * The {@code point} argument specifies the location of the security * warning in the coordinate system described above. If both {@code x} and * {@code y} coordinates of the point are equal to zero, the warning will * be located right in the origin of the coordinate system. On the other * hand, if both {@code alignmentX} and {@code alignmentY} are equal to * zero (i.e. the origin of the coordinate system is placed at the top-left * corner of the window), then the {@code point} argument represents the * absolute location of the security warning relative to the location of * the window. The "absolute" in this case means that the position of the * security warning is not effected by resizing of the window. * <p> * Note that the security warning managment code guarantees that: * <ul> * <li>The security warning cannot be located farther than two pixels from * the rectangular bounds of the window (see {@link Window#getBounds}), and * <li>The security warning is always visible on the screen. * </ul> * If either of the conditions is violated, the calculated position of the * security warning is adjusted by the system to meet both these * conditions. * <p> * The default position of the security warning is in the upper-right * corner of the window, two pixels to the right from the right edge. This * corresponds to the following arguments passed to this method: * <ul> * <li>{@code alignmentX = Component.RIGHT_ALIGNMENT} * <li>{@code alignmentY = Component.TOP_ALIGNMENT} * <li>{@code point = (2, 0)} * </ul> * * @param window the window to set the position of the security warning for * @param alignmentX the horizontal origin of the coordinate system * @param alignmentY the vertical origin of the coordinate system * @param point the position of the security warning in the specified * coordinate system * * @throws NullPointerException if the window argument is null * @throws NullPointerException if the point argument is null * @throws IllegalArgumentException if the window is trusted (i.e. * the {@code getWarningString()} returns null * @throws IllegalArgumentException if the alignmentX or alignmentY * arguments are not within the range [0.0f ... 1.0f] */ public static void setPosition(Window window, Point2D point, float alignmentX, float alignmentY) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } if (window.getWarningString() == null) { throw new IllegalArgumentException( "The window must have a non-null warning string."); } if (point == null) { throw new NullPointerException( "The point argument must not be null"); } if (alignmentX < 0.0f || alignmentX > 1.0f) { throw new IllegalArgumentException( "alignmentX must be in the range [0.0f ... 1.0f]."); } if (alignmentY < 0.0f || alignmentY > 1.0f) { throw new IllegalArgumentException( "alignmentY must be in the range [0.0f ... 1.0f]."); } AWTAccessor.getWindowAccessor().setSecurityWarningPosition(window, point, alignmentX, alignmentY); } }