forked from FNNDSC/KWWidgets
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vtkKWEntry.h
309 lines (271 loc) · 12.3 KB
/
vtkKWEntry.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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
/*=========================================================================
Module: vtkKWEntry.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 vtkKWEntry - a single line text entry widget
// .SECTION Description
// A simple widget used for collecting keyboard input from the user. This
// widget provides support for single line input.
#ifndef __vtkKWEntry_h
#define __vtkKWEntry_h
#include "vtkKWCoreWidget.h"
class KWWidgets_EXPORT vtkKWEntry : public vtkKWCoreWidget
{
public:
static vtkKWEntry* New();
vtkTypeMacro(vtkKWEntry,vtkKWCoreWidget);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Set/Get the value of the entry in a few different formats.
// In the SetValue method with double, values are printed in printf's %f
// or %e format, whichever is more compact for the given value and precision.
// The %e format is used only when the exponent of the value is less than
// -4 or greater than or equal to the precision argument (which can be
// controlled using the second parameter of SetValue). Trailing zeros
// are truncated, and the decimal point appears only if one or more digits
// follow it.
// Set/GetHexadecimalValueAsRGB provides a convenience way to enter/parse
// a RGB triplet formatted in hexadecimal. Note that the values are
// int, not double (i.e. 0 to 255 instead of VTK's normalized 0.0 to 1.0)
// IMPORTANT: whenever possible, use any of the GetValueAs...() methods
// GetHexadecimalValueAsRGB will set r,g,b to -1, -1, -1 if the hexadecimal
// value could not be parsed.
// to retrieve the value if it is meant to be a number. This is faster
// than calling GetValue() and converting the resulting string to a number.
virtual void SetValue(const char *);
virtual const char* GetValue();
virtual void SetValueAsInt(int a);
virtual int GetValueAsInt();
virtual void SetValueAsFormattedDouble(double f, int size);
virtual void SetValueAsDouble(double f);
virtual double GetValueAsDouble();
virtual void SetHexadecimalValueAsRGB(int r, int g, int b);
virtual void GetHexadecimalValueAsRGB(int &r, int &g, int &b);
// Description:
// The width is the number of charaters wide the entry box can fit.
// To keep from changing behavior of the entry, the default
// value is -1 wich means the width is not explicitly set and will default
// to whatever value Tk is using (at this point, 20). Set it to 0
// and the widget should pick a size just large enough to hold its text.
virtual void SetWidth(int width);
vtkGetMacro(Width, int);
// Description:
// Set/Get readonly flag. This flags makes the entry read only.
virtual void SetReadOnly(int);
vtkBooleanMacro(ReadOnly, int);
vtkGetMacro(ReadOnly, int);
// Description:
// Set/Get password mode flag. If this flag is set, then the true contents
// of the entry are not displayed in the window. Instead, each character in
// the entry's value will be displayed as '*'. This is useful, for example,
// if the entry is to be used to enter a password. If characters in the entry
// are selected and copied elsewhere, the information copied will be what is
// displayed, not the true contents of the entry.
vtkBooleanMacro(PasswordMode, int);
virtual void SetPasswordMode(int);
virtual int GetPasswordMode();
// Description:
// Select all text in the entry
virtual void SelectAll();
// Description:
// Set/Get if the entry's contents should be selected automatically
// when the entry receives focus. Off by default, this variable can be
// turned on to On to emulate the effect of the URL entry in a browser
// window.
vtkBooleanMacro(SelectAllOnFocusIn, int);
virtual void SetSelectAllOnFocusIn(int);
vtkGetMacro(SelectAllOnFocusIn, int);
// Description:
// Restrict the value to a given type (integer, hexadecimal, double, or
// no restriction).
// Note: checks against RestrictValue are performed before ValidationCommand.
//BTX
enum
{
RestrictNone = 0,
RestrictInteger,
RestrictDouble,
RestrictHexadecimal
};
//ETX
vtkGetMacro(RestrictValue, int);
virtual void SetRestrictValue(int);
virtual void SetRestrictValueToInteger();
virtual void SetRestrictValueToDouble();
virtual void SetRestrictValueToHexadecimal();
virtual void SetRestrictValueToNone();
// Description:
// Specifies a command to associate with this step. This command can
// be used to validate the contents of the widget.
// Note: checks against RestrictValue are performed before ValidationCommand.
// The 'object' argument is the object that will have the 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 command.
// This command should return 1 if the contents is valid, 0 otherwise.
// The following parameters are also passed to the command:
// - current value: const char*
virtual void SetValidationCommand(vtkObject *object, const char *method);
virtual int InvokeValidationCommand(const char *value);
// Description:
// Set/Get the background color of the widget.
virtual void GetBackgroundColor(double *r, double *g, double *b);
virtual double* GetBackgroundColor();
virtual void SetBackgroundColor(double r, double g, double b);
virtual void SetBackgroundColor(double rgb[3])
{ this->SetBackgroundColor(rgb[0], rgb[1], rgb[2]); };
// Description:
// Set/Get the foreground color of the widget.
virtual void GetForegroundColor(double *r, double *g, double *b);
virtual double* GetForegroundColor();
virtual void SetForegroundColor(double r, double g, double b);
virtual void SetForegroundColor(double rgb[3])
{ this->SetForegroundColor(rgb[0], rgb[1], rgb[2]); };
// Description:
// Set/Get the background color of the widget when it is disabled.
virtual void GetDisabledBackgroundColor(double *r, double *g, double *b);
virtual double* GetDisabledBackgroundColor();
virtual void SetDisabledBackgroundColor(double r, double g, double b);
virtual void SetDisabledBackgroundColor(double rgb[3])
{ this->SetDisabledBackgroundColor(rgb[0], rgb[1], rgb[2]); };
// Description:
// Set/Get the foreground color of the widget when it is disabled.
virtual void GetDisabledForegroundColor(double *r, double *g, double *b);
virtual double* GetDisabledForegroundColor();
virtual void SetDisabledForegroundColor(double r, double g, double b);
virtual void SetDisabledForegroundColor(double rgb[3])
{ this->SetDisabledForegroundColor(rgb[0], rgb[1], rgb[2]); };
// Description:
// Set/Get the background color of the widget when it is read-only.
virtual void GetReadOnlyBackgroundColor(double *r, double *g, double *b);
virtual double* GetReadOnlyBackgroundColor();
virtual void SetReadOnlyBackgroundColor(double r, double g, double b);
virtual void SetReadOnlyBackgroundColor(double rgb[3])
{ this->SetReadOnlyBackgroundColor(rgb[0], rgb[1], rgb[2]); };
// Description:
// Set/Get the highlight thickness, a non-negative value indicating the
// width of the highlight rectangle to draw around the outside of the
// widget when it has the input focus.
virtual void SetHighlightThickness(int);
virtual int GetHighlightThickness();
// Description:
// Set/Get the border width, a non-negative value indicating the width of
// the 3-D border to draw around the outside of the widget (if such a border
// is being drawn; the Relief option typically determines this).
virtual void SetBorderWidth(int);
virtual int GetBorderWidth();
// Description:
// Set/Get the 3-D effect desired for the widget.
// The value indicates how the interior of the widget should appear
// relative to its exterior.
// Valid constants can be found in vtkKWOptions::ReliefType.
virtual void SetRelief(int);
virtual int GetRelief();
virtual void SetReliefToRaised();
virtual void SetReliefToSunken();
virtual void SetReliefToFlat();
virtual void SetReliefToRidge();
virtual void SetReliefToSolid();
virtual void SetReliefToGroove();
// Description:
// Specifies the font to use when drawing text inside the widget.
// You can use predefined font names (e.g. 'system'), or you can specify
// a set of font attributes with a platform-independent name, for example,
// 'times 12 bold'. In this example, the font is specified with a three
// element list: the first element is the font family, the second is the
// size, the third is a list of style parameters (normal, bold, roman,
// italic, underline, overstrike). Example: 'times 12 {bold italic}'.
// The Times, Courier and Helvetica font families are guaranteed to exist
// and will be matched to the corresponding (closest) font on your system.
// If you are familiar with the X font names specification, you can also
// describe the font that way (say, '*times-medium-r-*-*-12*').
virtual void SetFont(const char *font);
virtual const char* GetFont();
// Description:
// Specifies a command to associate with the widget. This command is
// typically invoked when the return key is pressed, or the focus is lost,
// as specified by the CommandTrigger variable.
// The 'object' argument is the object that will have the 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 command.
// The following parameters are also passed to the command:
// - current value: const char*
virtual void SetCommand(vtkObject *object, const char *method);
virtual void InvokeCommand(const char *value);
// Description:
// Specify when Command should be invoked. Default to losing focus and
// return key.
//BTX
enum
{
TriggerOnFocusOut = 1,
TriggerOnReturnKey = 2,
TriggerOnAnyChange = 4
};
//ETX
vtkGetMacro(CommandTrigger, int);
virtual void SetCommandTrigger(int);
virtual void SetCommandTriggerToReturnKeyAndFocusOut();
virtual void SetCommandTriggerToAnyChange();
// Description:
// Events. The EntryValueChangedEvent is triggered when the widget value
// is changed. It is similar in concept to the 'Command' callback but can be
// used by multiple listeners/observers at a time.
// Important: since there is no way to robustly find out when the user
// is done inputing characters in the text entry, the EntryValueChangedEvent
// event is also generated when <Return> is pressed, or the entry widget
// is losing focus (i.e. the user clicked outside the text field).
// The following parameters are also passed as client data:
// - current value: const char*
//BTX
enum
{
EntryValueChangedEvent = 10000
};
//ETX
// Description:
// Update the "enable" state of the object and its internal parts.
// Depending on different Ivars (this->Enabled, the application's
// Limited Edition Mode, etc.), the "enable" state of the object is updated
// and propagated to its internal parts/subwidgets. This will, for example,
// enable/disable parts of the widget UI, enable/disable the visibility
// of 3D widgets, etc.
virtual void UpdateEnableState();
// Description:
// Callbacks. Internal, do not use.
virtual void ValueCallback();
virtual int ValidationCallback(const char *value);
virtual void TracedVariableChangedCallback(
const char *, const char *, const char *);
protected:
vtkKWEntry();
~vtkKWEntry();
// Description:
// Create the widget.
virtual void CreateWidget();
int Width;
int ReadOnly;
int RestrictValue;
int CommandTrigger;
int SelectAllOnFocusIn;
char *Command;
char *ValidationCommand;
// Description:
// Configure.
virtual void Configure();
virtual void ConfigureValidation();
virtual void ConfigureTraceCallback(int state);
private:
char *InternalValueString;
vtkGetStringMacro(InternalValueString);
vtkSetStringMacro(InternalValueString);
vtkKWEntry(const vtkKWEntry&); // Not implemented
void operator=(const vtkKWEntry&); // Not Implemented
};
#endif