0N/A/*
2362N/A * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
2362N/A * published by the Free Software Foundation. Oracle designates this
0N/A * particular file as subject to the "Classpath" exception as provided
2362N/A * by Oracle in the LICENSE file that accompanied this code.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
2362N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2362N/A * or visit www.oracle.com if you need additional information or have any
2362N/A * questions.
0N/A */
0N/Apackage javax.swing.event;
0N/A
0N/Aimport javax.swing.MenuElement;
0N/Aimport javax.swing.MenuSelectionManager;
0N/Aimport java.util.EventObject;
0N/Aimport java.awt.event.MouseEvent;
0N/Aimport java.awt.Component;
0N/A
0N/A
0N/A/**
0N/A * MenuDragMouseEvent is used to notify interested parties that
0N/A * the menu element has received a MouseEvent forwarded to it
0N/A * under drag conditions.
0N/A * <p>
0N/A * <strong>Warning:</strong>
0N/A * Serialized objects of this class will not be compatible with
0N/A * future Swing releases. The current serialization support is
0N/A * appropriate for short term storage or RMI between applications running
0N/A * the same version of Swing. As of 1.4, support for long term storage
0N/A * of all JavaBeans<sup><font size="-2">TM</font></sup>
0N/A * has been added to the <code>java.beans</code> package.
0N/A * Please see {@link java.beans.XMLEncoder}.
0N/A *
0N/A * @author Georges Saab
0N/A */
0N/Apublic class MenuDragMouseEvent extends MouseEvent {
0N/A private MenuElement path[];
0N/A private MenuSelectionManager manager;
0N/A
0N/A /**
0N/A * Constructs a MenuDragMouseEvent object.
0N/A * <p>Absolute coordinates xAbs and yAbs are set to source's location on screen plus
0N/A * relative coordinates x and y. xAbs and yAbs are set to zero if the source is not showing.
0N/A *
0N/A * @param source the Component that originated the event
0N/A * (typically <code>this</code>)
0N/A * @param id an int specifying the type of event, as defined
0N/A * in {@link java.awt.event.MouseEvent}
0N/A * @param when a long identifying the time the event occurred
0N/A * @param modifiers an int specifying any modifier keys held down,
0N/A * as specified in {@link java.awt.event.InputEvent}
0N/A * @param x an int specifying the horizontal position at which
0N/A * the event occurred, in pixels
0N/A * @param y an int specifying the vertical position at which
0N/A * the event occurred, in pixels
0N/A * @param clickCount an int specifying the number of mouse-clicks
0N/A * @param popupTrigger a boolean -- true if the event {should?/did?}
0N/A * trigger a popup
0N/A * @param p an array of MenuElement objects specifying a path
0N/A * to a menu item affected by the drag
0N/A * @param m a MenuSelectionManager object that handles selections
0N/A * @see MouseEvent#MouseEvent(java.awt.Component, int, long, int, int, int, int, int, int, boolean, int)
0N/A */
0N/A public MenuDragMouseEvent(Component source, int id, long when,
0N/A int modifiers, int x, int y, int clickCount,
0N/A boolean popupTrigger, MenuElement p[],
0N/A MenuSelectionManager m) {
0N/A super(source, id, when, modifiers, x, y, clickCount, popupTrigger);
0N/A path = p;
0N/A manager = m;
0N/A }
0N/A
0N/A /**
0N/A * Constructs a MenuDragMouseEvent object.
0N/A * <p>Even if inconsistent values for relative and absolute coordinates are
0N/A * passed to the constructor, the MenuDragMouseEvent instance is still
0N/A * created.
0N/A * @param source the Component that originated the event
0N/A * (typically <code>this</code>)
0N/A * @param id an int specifying the type of event, as defined
0N/A * in {@link java.awt.event.MouseEvent}
0N/A * @param when a long identifying the time the event occurred
0N/A * @param modifiers an int specifying any modifier keys held down,
0N/A * as specified in {@link java.awt.event.InputEvent}
0N/A * @param x an int specifying the horizontal position at which
0N/A * the event occurred, in pixels
0N/A * @param y an int specifying the vertical position at which
0N/A * the event occurred, in pixels
0N/A * @param xAbs an int specifying the horizontal absolute position at which
0N/A * the event occurred, in pixels
0N/A * @param yAbs an int specifying the vertical absolute position at which
0N/A * the event occurred, in pixels
0N/A * @param clickCount an int specifying the number of mouse-clicks
0N/A * @param popupTrigger a boolean -- true if the event {should?/did?}
0N/A * trigger a popup
0N/A * @param p an array of MenuElement objects specifying a path
0N/A * to a menu item affected by the drag
0N/A * @param m a MenuSelectionManager object that handles selections
0N/A * @see MouseEvent#MouseEvent(java.awt.Component, int, long, int, int, int, int, int, int, boolean, int)
0N/A * @since 1.6
0N/A */
0N/A public MenuDragMouseEvent(Component source, int id, long when,
0N/A int modifiers, int x, int y, int xAbs,
0N/A int yAbs, int clickCount,
0N/A boolean popupTrigger, MenuElement p[],
0N/A MenuSelectionManager m) {
0N/A super(source, id, when, modifiers, x, y, xAbs, yAbs, clickCount,
0N/A popupTrigger, MouseEvent.NOBUTTON);
0N/A path = p;
0N/A manager = m;
0N/A }
0N/A
0N/A /**
0N/A * Returns the path to the selected menu item.
0N/A *
0N/A * @return an array of MenuElement objects representing the path value
0N/A */
0N/A public MenuElement[] getPath() {
0N/A return path;
0N/A }
0N/A
0N/A /**
0N/A * Returns the current menu selection manager.
0N/A *
0N/A * @return a MenuSelectionManager object
0N/A */
0N/A public MenuSelectionManager getMenuSelectionManager() {
0N/A return manager;
0N/A }
0N/A}