/*===========================================================================*\
* *
* OpenFlipper *
* Copyright (C) 2001-2010 by Computer Graphics Group, RWTH Aachen *
* www.openflipper.org *
* *
*--------------------------------------------------------------------------- *
* This file is part of OpenFlipper. *
* *
* OpenFlipper is free software: you can redistribute it and/or modify *
* it under the terms of the GNU Lesser General Public License as *
* published by the Free Software Foundation, either version 3 of *
* the License, or (at your option) any later version with the *
* following exceptions: *
* *
* If other files instantiate templates or use macros *
* or inline functions from this file, or you compile this file and *
* link it with other files to produce an executable, this file does *
* not by itself cause the resulting executable to be covered by the *
* GNU Lesser General Public License. This exception does not however *
* invalidate any other reasons why the executable file might be *
* covered by the GNU Lesser General Public License. *
* *
* OpenFlipper 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 Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU LesserGeneral Public *
* License along with OpenFlipper. If not, *
* see . *
* *
\*===========================================================================*/
/*===========================================================================*\
* *
* $Revision$ *
* $LastChangedBy$ *
* $Date$ *
* *
\*===========================================================================*/
//
// C++ Interface: PickingInterface
//
// Description:
//
//
// Author: Jan Moebius , (C) 2007
//
#ifndef PICKINGINTERFACE_HH
#define PICKINGINTERFACE_HH
#include
#include
#include
/**
* \brief Allow access to picking functions.
*
* Interface Class which allows access to picking functions.
*
* Read tutorial \ref ex3 for an example of how to use mouse picking.
*/
class PickingInterface {
signals :
/** \brief Add a new picking mode to the examiner
*
* @param _mode Identifier of Picking mode or "Separator" to add a Separator
*/
virtual void addPickMode( const std::string /*_mode*/) {};
/** \brief Add a new picking mode to the examiner which will be invisible
*
* The added PickMode will not appear in the context menus Picking menu.
* You have to provide a button or menuentry yourself if you want to switch to
* the picking mode provided here.
*
* @param _mode Identifier of Picking mode or "Separator" to add a Separator
*/
virtual void addHiddenPickMode( const std::string /*_mode*/ ) {};
/** \brief Set the cursor of the given PickMode
*
* Set the cursor that should be used inside the pickMode
*
* @param _mode Identifier of Picking mode
* @param _cursor the new cursor
*/
virtual void setPickModeCursor( const std::string /*_mode*/ , QCursor /*_cursor*/ ) {};
/** \brief Set mouse tracking for the given PickMode
*
* Enable mouseTracking for the given PickMode. When MouseTracking is enabled
* you receive mouseMove events also when no button is pressed (via MouseInterface)
*
* @param _mode Identifier of Picking mode
* @param _mouseTracking new state of mouseTracking
*/
virtual void setPickModeMouseTracking( const std::string /*_mode*/ , bool /*_mouseTracking*/ ) {};
/** \brief Set the additinal toolbar of the given PickMode
*
* Set the additional toolbar that should be shown in the pickMode
*
* @param _mode Identifier of Picking mode
* @param _toolbar the toolbar
*/
virtual void setPickModeToolbar( const std::string /*_mode*/ , QToolBar * /*_toolbar*/ ) {};
/** \brief Removes the additinal toolbar of the given PickMode
*
* Set the additional toolbar that should be shown in the pickMode
*
* @param _mode Identifier of Picking mode
*/
virtual void removePickModeToolbar( const std::string /*_mode*/ ) {};
private slots:
/** \brief The pickingMode has changed
*
* This slot is called if the user changes the current picking mode
* @param _mode Identifier of Picking mode
*/
virtual void slotPickModeChanged( const std::string& /*_mode*/) {};
public :
/// Destructor
virtual ~PickingInterface() {};
};
Q_DECLARE_INTERFACE(PickingInterface,"OpenFlipper.PickingInterface/1.1")
#endif // PICKINGINTERFACE_HH