-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathvtkKWKeyBindingsManager.h
143 lines (122 loc) · 5.8 KB
/
vtkKWKeyBindingsManager.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*=========================================================================
Module: vtkKWKeyBindingsManager.h,v
Copyright (c) Kitware, Inc.
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.
=========================================================================*/
// .NAME vtkKWKeyBindingsManager - a keyboard shortcut manager.
// .SECTION Description
// This class is basically a manager that acts as a container for a set of
// key bindings.
// Any object that define a key binding can register it here.
// This manager can be queried later on to list all key bindings, for example.
// This class does not support reassigning key bindings yet.
// .SECTION See Also
// vtkKWKeyBindingsWidget
#ifndef __vtkKWKeyBindingsManager_h
#define __vtkKWKeyBindingsManager_h
#include "vtkKWObject.h"
class vtkKWKeyBindingsManagerInternals;
class vtkKWEventMap;
class KWWidgets_EXPORT vtkKWKeyBindingsManager : public vtkKWObject
{
public:
static vtkKWKeyBindingsManager* New();
vtkTypeRevisionMacro(vtkKWKeyBindingsManager,vtkKWObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Add or set or remove a key binding. Setting a key binding will remove any
// items that were previously associated to that specific binding.
// 'target' is generally a pointer to the class that set up this binding.
// 'binding' is the binding itself, in a Tk event form (say, <KeyPress-p>)
// 'callback_object' and 'callback_command' define the callback associated
// to this binding. The 'object' argument is the object that will have
// the 'command' (method) called on it. The 'method' argument is the
// name of the method to be called and any arguments in string form.
// If the 'object' is NULL, the method is still evaluated as a
// simple Tcl command.
// simple Tcl command.
// 'context' is a string in plain English (or preferably localized) that
// explains in which context this key binding is valid. For example:
// "Any 2D View", or "Any Main Window". It usually is a simple/short
// description of the class setting the binding (i.e. the 'target').
// 'description' is a string in plain English (or preferably localized) that
// explains what that binding does. For example: "Reset the camera".
virtual void AddKeyBinding(
vtkObject *target,
const char *binding,
vtkObject *callback_object = NULL,
const char *callback_command = NULL,
const char *context = NULL,
const char *description = NULL);
virtual void SetKeyBinding(
vtkObject *target,
const char *binding,
vtkObject *callback_object = NULL,
const char *callback_command = NULL,
const char *context = NULL,
const char *description = NULL);
virtual void RemoveKeyBinding(
vtkObject *target,
const char *binding = NULL,
vtkObject *callback_object = NULL,
const char *callback_command = NULL);
// Description:
// Query the key bindings. While a little convoluted, this is the fastest
// way to query the internal bindings: iterate over the targets, then
// iterate over the bindings for each target, then iterate over the callback
// objects for each binding, then iterate over the key bindings entries
// themselves for each callback objet; for each entry (given a target,
// binding, callback object and index), you can retrieve the callback
// command, context and description.
// See vtkKWKeyBindingsWidget.cxx for an example.
virtual int GetNumberOfTargets();
virtual vtkObject* GetNthTarget(int idx);
virtual int GetNumberOfBindings(vtkObject *target);
virtual const char* GetNthBinding(vtkObject *target, int idx);
virtual int GetNumberOfCallbackObjects(
vtkObject *target, const char *binding);
virtual vtkObject* GetNthCallbackObject(
vtkObject *target, const char *binding, int idx);
virtual int GetNumberOfKeyBindings(
vtkObject *target, const char *binding, vtkObject *callback_object);
virtual const char* GetNthCallbackCommand(
vtkObject *target, const char *binding,vtkObject *callback_object,int idx);
virtual const char* GetNthContext(
vtkObject *target, const char *binding,vtkObject *callback_object,int idx);
virtual const char* GetNthDescription(
vtkObject *target, const char *binding,vtkObject *callback_object,int idx);
// Description:
// Convenience method that can be used to add all the key and keysym
// bindings found in a vtkKWEventMap.
virtual void SetKeyBindingsFromEventMap(vtkKWEventMap *map);
// Description:
// Get a "pretty" representation of a binding (remove trailing <>, Key-,
// KeyPress-, translate some keysyms, change - into +, uppercase the key).
virtual const char* GetPrettyBinding(const char *binding);
// Description:
// Get a "pretty" representation of a context (if the context is a single
// word, i.e. maybe a class name, remove the usual prefixes, and separate
// each words).
virtual const char* GetPrettyContext(const char *context);
protected:
vtkKWKeyBindingsManager();
~vtkKWKeyBindingsManager();
//BTX
// PIMPL Encapsulation for STL containers
vtkKWKeyBindingsManagerInternals *Internals;
//ETX
// Description:
// Processes the events that are passed through CallbackCommand (or others).
// Subclasses can oberride this method to process their own events, but
// should call the superclass too.
virtual void ProcessCallbackCommandEvents(
vtkObject *caller, unsigned long event, void *calldata);
private:
vtkKWKeyBindingsManager(const vtkKWKeyBindingsManager&); // Not implemented
void operator=(const vtkKWKeyBindingsManager&); // Not implemented
};
#endif