/* The node controller for objects that offer a configure command.
Copyright (c) 1998-2008 The Regents of the University of California.
All rights reserved.
Permission is hereby granted, without written agreement and without
license or royalty fees, to use, copy, modify, and distribute this
software and its documentation for any purpose, provided that the above
copyright notice and the following two paragraphs appear in all copies
of this software.
IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY
FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGE.
THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
CALIFORNIA HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES,
ENHANCEMENTS, OR MODIFICATIONS.
PT_COPYRIGHT_VERSION_2
COPYRIGHTENDKEY
*/
package ptolemy.vergil.basic;
import java.util.Iterator;
import java.util.List;
import ptolemy.actor.gui.Configuration;
import ptolemy.vergil.toolbox.ConfigureAction;
import ptolemy.vergil.toolbox.MenuActionFactory;
import ptolemy.vergil.toolbox.PtolemyMenuFactory;
import diva.canvas.event.MouseFilter;
import diva.canvas.interactor.ActionInteractor;
import diva.canvas.interactor.SelectionModel;
import diva.graph.GraphController;
import diva.graph.NodeInteractor;
import diva.gui.toolbox.MenuCreator;
//////////////////////////////////////////////////////////////////////////
//// ParameterizedNodeController
/**
This class provides interaction with nodes that represent Ptolemy II
components with parameters. It provides a context menu item labeled
"Configure" for editing those parameters, and binds double click
to invoke the dialog that edits those parameters.
@author Steve Neuendorffer and Edward A. Lee
@version $Id: ParameterizedNodeController.java,v 1.30 2008/01/26 02:51:29 cxh Exp $
@since Ptolemy II 2.0
@Pt.ProposedRating Red (eal)
@Pt.AcceptedRating Red (johnr)
*/
public class ParameterizedNodeController extends NamedObjController {
/** Create an attribute controller associated with the specified graph
* controller.
* @param controller The associated graph controller.
*/
public ParameterizedNodeController(GraphController controller) {
super(controller);
// Add a menu creator.
_menuCreator = new MenuCreator(null);
_menuCreator.setMouseFilter(new PopupMouseFilter());
// FIXME: Why doesn't getNodeInteractor() return a NodeInteractor?
NodeInteractor interactor = (NodeInteractor) getNodeInteractor();
interactor.addInteractor(_menuCreator);
// The contents of the menu is determined by the associated
// menu factory, which is a protected member of this class.
// Derived classes can add menu items to it.
_menuFactory = new PtolemyMenuFactory(controller);
List configsList = Configuration.configurations();
Configuration config = null;
for (Iterator it = configsList.iterator(); it.hasNext();) {
config = (Configuration) it.next();
if (config != null)
break;
}
//If a MenuFactory has been defined in the configuration, use this
//one; otherwise, use the default Ptolemy one:
if (config != null && _contextMenuFactoryCreator == null) {
_contextMenuFactoryCreator = (ContextMenuFactoryCreator) config
.getAttribute("contextMenuFactory");
}
if (_contextMenuFactoryCreator != null) {
try {
_menuFactory = (PtolemyMenuFactory) _contextMenuFactoryCreator
.createContextMenuFactory(controller);
} catch (Exception ex) {
//do nothing - will default to ptii right-click menus
System.out
.println("Unable to use the alternative right-click menu "
+ "handler that was specified in the "
+ "configuration; defaulting to ptii handler. "
+ "Exception was: " + ex);
}
}
// If the above has failed in any way, _menuFactory will still be null,
// in which case we should default to ptii context menus
if (_menuFactory == null) {
_menuFactory = new PtolemyMenuFactory(controller);
}
// In this base class, there is only one configure command, so
// there won't be a submenu. Subclasses convert this to a submenu.
_configureMenuFactory = new MenuActionFactory(_configureAction);
_menuFactory.addMenuItemFactory(_configureMenuFactory);
_menuCreator.setMenuFactory(_menuFactory);
// Add a double click interactor.
ActionInteractor doubleClickInteractor = new ActionInteractor(
_configureAction);
doubleClickInteractor.setConsuming(false);
doubleClickInteractor.setMouseFilter(new MouseFilter(1, 0, 0, 2));
interactor.addInteractor(doubleClickInteractor);
// NOTE: This dance is so that the
// doubleClickInteractor gets the events before the drag interactor.
interactor.setDragInteractor(interactor.getDragInteractor());
// Set the selection model to allow this to be independently selected.
SelectionModel sm = controller.getSelectionModel();
interactor.setSelectionModel(sm);
}
///////////////////////////////////////////////////////////////////
//// protected members ////
/** The submenu for configure actions. */
protected MenuActionFactory _configureMenuFactory;
/** The factory belonging to the menu creator. */
protected PtolemyMenuFactory _menuFactory;
/** The menu creator. */
protected MenuCreator _menuCreator;
/** The configure action, which handles edit parameters requests. */
protected static ConfigureAction _configureAction = new ConfigureAction(
"Configure");
/** A configurable object that allows a different MenuFactory
* to be specified instead of the default ptII one.
* The MenuFactory constructs the right-click context menus.
*/
private static ContextMenuFactoryCreator _contextMenuFactoryCreator;
}