Package cn.edu.pku.dr.requirement.elicitation.tools

Source Code of cn.edu.pku.dr.requirement.elicitation.tools.PopupMenuAction

package cn.edu.pku.dr.requirement.elicitation.tools;

import org.netbeans.api.visual.widget.Scene;
import org.netbeans.api.visual.widget.Widget;
import org.netbeans.api.visual.action.WidgetAction;
import org.netbeans.api.visual.action.PopupMenuProvider;

import javax.swing.*;
import java.awt.*;

/**
* @author William Headrick, David Kaspar
*/
public final class PopupMenuAction extends WidgetAction.Adapter {

    private PopupMenuProvider provider;

    public PopupMenuAction(PopupMenuProvider provider) {
        this.provider = provider;
    }

    /**
     * Conditionally display a {@link JPopupMenu} for the given Widget if the
     * WidgetMouseEvent is a popup trigger. Delegates check code to
     * {@link #handleMouseEvent(Widget, WidgetMouseEvent)}.
     *
     * @param widget
     * @param event
     * @return {@link State#REJECTED} if no JPopupMenu is displayed, or
     *         {@link State#CONSUMED} if a JPopupMenu is displayed.
     * @see #handleMouseEvent(Widget, WidgetMouseEvent)
     */
    public State mousePressed(Widget widget, WidgetMouseEvent event) {
        System.out.println("Popupmenu mousePressed");
        return handleMouseEvent(widget, event);
    }

    /**
     * Conditionally display a {@link JPopupMenu} for the given Widget if the
     * WidgetMouseEvent is a popup trigger. Delegates check code to
     * {@link #handleMouseEvent(Widget, WidgetMouseEvent)}.
     *
     * @param widget
     * @param event
     * @return {@link State#REJECTED} if no JPopupMenu is displayed, or
     *         {@link State#CONSUMED} if a JPopupMenu is displayed.
     * @see #handleMouseEvent(Widget, WidgetMouseEvent)
     */
    public State mouseReleased(Widget widget, WidgetMouseEvent event) {
        return handleMouseEvent(widget, event);
    }

    /**
     * Conditionally display a {@link JPopupMenu} for the given Widget if the
     * WidgetMouseEvent is a popup trigger. This method is called by both
     * {@link #mousePressed(Widget, WidgetMouseEvent)} and
     * {@link #mouseReleased(Widget, WidgetMouseEvent)} methods to handle
     * displaying a popup menu for the given widget and event. Uses
     * {@link WidgetMouseEvent#isPopupTrigger() event.isPopupTrigger()} to
     * determine whether or not a popup menu should be displayed.
     *
     * @param widget
     * @param event
     * @return {@link State#REJECTED} if no JPopupMenu is displayed, or
     *         {@link State#CONSUMED} if a JPopupMenu is displayed.
     * @see #mousePressed(Widget, WidgetMouseEvent)
     * @see #mouseReleased(Widget, WidgetMouseEvent)
     */
    protected State handleMouseEvent(Widget widget, WidgetMouseEvent event) {
        // Different OSes use different MouseEvents (Pressed/Released) to
        // signal that an event is a PopupTrigger. So, the mousePressed(...)
        // and mouseReleased(...) methods delegate to this method to
        // handle the MouseEvent.
        if (event.isPopupTrigger()) {
            JPopupMenu popupMenu = provider.getPopupMenu(widget, event
                    .getPoint());
            if (popupMenu != null) {
                Scene scene = widget.getScene();
                Point point = scene.convertSceneToView(widget
                        .convertLocalToScene(event.getPoint()));
                popupMenu.show(scene.getView(), point.x, point.y);
            }
            return State.CONSUMED;
        }
        return State.CONSUMED;
    }

}
TOP

Related Classes of cn.edu.pku.dr.requirement.elicitation.tools.PopupMenuAction

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.