All Downloads are FREE. Search and download functionalities are using the official Maven repository.

META-INF.modules.java.desktop.classes.java.awt.dnd.DragSourceEvent Maven / Gradle / Ivy

/*
 * Copyright (c) 1997, 2013, 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 java.awt.dnd;

import java.awt.Point;

import java.util.EventObject;

/**
 * This class is the base class for
 * {@code DragSourceDragEvent} and
 * {@code DragSourceDropEvent}.
 * 

* {@code DragSourceEvent}s are generated whenever the drag enters, moves * over, or exits a drop site, when the drop action changes, and when the drag * ends. The location for the generated {@code DragSourceEvent} specifies * the mouse cursor location in screen coordinates at the moment this event * occurred. *

* In a multi-screen environment without a virtual device, the cursor location is * specified in the coordinate system of the initiator * {@code GraphicsConfiguration}. The initiator * {@code GraphicsConfiguration} is the {@code GraphicsConfiguration} * of the {@code Component} on which the drag gesture for the current drag * operation was recognized. If the cursor location is outside the bounds of * the initiator {@code GraphicsConfiguration}, the reported coordinates are * clipped to fit within the bounds of that {@code GraphicsConfiguration}. *

* In a multi-screen environment with a virtual device, the location is specified * in the corresponding virtual coordinate system. If the cursor location is * outside the bounds of the virtual device the reported coordinates are * clipped to fit within the bounds of the virtual device. * * @since 1.2 */ public class DragSourceEvent extends EventObject { private static final long serialVersionUID = -763287114604032641L; /** * The {@code boolean} indicating whether the cursor location * is specified for this event. * * @serial */ private final boolean locationSpecified; /** * The horizontal coordinate for the cursor location at the moment this * event occurred if the cursor location is specified for this event; * otherwise zero. * * @serial */ private final int x; /** * The vertical coordinate for the cursor location at the moment this event * occurred if the cursor location is specified for this event; * otherwise zero. * * @serial */ private final int y; /** * Construct a {@code DragSourceEvent} * given a specified {@code DragSourceContext}. * The coordinates for this {@code DragSourceEvent} * are not specified, so {@code getLocation} will return * {@code null} for this event. * * @param dsc the {@code DragSourceContext} * * @throws IllegalArgumentException if {@code dsc} is {@code null}. * * @see #getLocation */ public DragSourceEvent(DragSourceContext dsc) { super(dsc); locationSpecified = false; this.x = 0; this.y = 0; } /** * Construct a {@code DragSourceEvent} given a specified * {@code DragSourceContext}, and coordinates of the cursor * location. * * @param dsc the {@code DragSourceContext} * @param x the horizontal coordinate for the cursor location * @param y the vertical coordinate for the cursor location * * @throws IllegalArgumentException if {@code dsc} is {@code null}. * * @since 1.4 */ public DragSourceEvent(DragSourceContext dsc, int x, int y) { super(dsc); locationSpecified = true; this.x = x; this.y = y; } /** * This method returns the {@code DragSourceContext} that * originated the event. * * @return the {@code DragSourceContext} that originated the event */ public DragSourceContext getDragSourceContext() { return (DragSourceContext)getSource(); } /** * This method returns a {@code Point} indicating the cursor * location in screen coordinates at the moment this event occurred, or * {@code null} if the cursor location is not specified for this * event. * * @return the {@code Point} indicating the cursor location * or {@code null} if the cursor location is not specified * @since 1.4 */ public Point getLocation() { if (locationSpecified) { return new Point(x, y); } else { return null; } } /** * This method returns the horizontal coordinate of the cursor location in * screen coordinates at the moment this event occurred, or zero if the * cursor location is not specified for this event. * * @return an integer indicating the horizontal coordinate of the cursor * location or zero if the cursor location is not specified * @since 1.4 */ public int getX() { return x; } /** * This method returns the vertical coordinate of the cursor location in * screen coordinates at the moment this event occurred, or zero if the * cursor location is not specified for this event. * * @return an integer indicating the vertical coordinate of the cursor * location or zero if the cursor location is not specified * @since 1.4 */ public int getY() { return y; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy