You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

120 lines
4.1 KiB
C

/*=========================================================================
Program: Visualization Toolkit
Module: vtkWidgetCallbackMapper.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkWidgetCallbackMapper
* @brief map widget events into callbacks
*
* vtkWidgetCallbackMapper maps widget events (defined in vtkWidgetEvent.h)
* into static class methods, and provides facilities to invoke the methods.
* This class is templated and meant to be used as an internal helper class
* by the widget classes. The class works in combination with the class
* vtkWidgetEventTranslator, which translates VTK events into widget events.
*
* @sa
* vtkWidgetEvent vtkWidgetEventTranslator
*/
#ifndef vtkWidgetCallbackMapper_h
#define vtkWidgetCallbackMapper_h
#include "vtkInteractionWidgetsModule.h" // For export macro
#include "vtkObject.h"
class vtkWidgetEvent;
class vtkAbstractWidget;
class vtkWidgetEventTranslator;
class vtkCallbackMap; // PIMPL encapsulation of STL map
class vtkEventData;
class VTKINTERACTIONWIDGETS_EXPORT vtkWidgetCallbackMapper : public vtkObject
{
public:
/**
* Instantiate the class.
*/
static vtkWidgetCallbackMapper* New();
//@{
/**
* Standard macros.
*/
vtkTypeMacro(vtkWidgetCallbackMapper, vtkObject);
void PrintSelf(ostream& os, vtkIndent indent) override;
//@}
//@{
/**
* Specify the vtkWidgetEventTranslator to coordinate with.
*/
void SetEventTranslator(vtkWidgetEventTranslator* t);
vtkGetObjectMacro(EventTranslator, vtkWidgetEventTranslator);
//@}
/**
* Convenient typedef for working with callbacks.
*/
typedef void (*CallbackType)(vtkAbstractWidget*);
//@{
/**
* This class works with the class vtkWidgetEventTranslator to set up the
* initial coorespondence between VTK events, widget events, and callbacks.
* Different flavors of the SetCallbackMethod() are available depending on
* what sort of modifiers are to be associated with a particular event.
* Typically the widgets should use this method to set up their event
* callbacks. If modifiers are not provided (i.e., the VTKEvent is a
* unsigned long eventId) then modifiers are ignored. Otherwise, a vtkEvent
* instance is used to fully quality the events.
*/
void SetCallbackMethod(
unsigned long VTKEvent, unsigned long widgetEvent, vtkAbstractWidget* w, CallbackType f);
void SetCallbackMethod(unsigned long VTKEvent, int modifiers, char keyCode, int repeatCount,
const char* keySym, unsigned long widgetEvent, vtkAbstractWidget* w, CallbackType f);
void SetCallbackMethod(unsigned long VTKEvent, vtkEventData* ed, unsigned long widgetEvent,
vtkAbstractWidget* w, CallbackType f);
// void SetCallbackMethod(vtkWidgetEvent *vtkEvent, unsigned long widgetEvent,
// vtkAbstractWidget *w, CallbackType f);
//@}
/**
* This method invokes the callback given a widget event. A non-zero value
* is returned if the listed event is registered.
*/
void InvokeCallback(unsigned long widgetEvent);
protected:
vtkWidgetCallbackMapper();
~vtkWidgetCallbackMapper() override;
// Translates VTK events into widget events
vtkWidgetEventTranslator* EventTranslator;
// Invoke the method associated with a particular widget event
vtkCallbackMap* CallbackMap;
/**
* This method is used to assign a callback (implemented as a static class
* method) to a particular widget event. This is an internal method used by
* widgets to map widget events into invocations of class methods.
*/
void SetCallbackMethod(unsigned long widgetEvent, vtkAbstractWidget* w, CallbackType f);
private:
vtkWidgetCallbackMapper(const vtkWidgetCallbackMapper&) = delete;
void operator=(const vtkWidgetCallbackMapper&) = delete;
};
#endif /* vtkWidgetCallbackMapper_h */