-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathvtkKWComboBox.h
114 lines (91 loc) · 4.08 KB
/
vtkKWComboBox.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
/*=========================================================================
Module: $RCSfile: vtkKWComboBox.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 vtkKWComboBox - a text entry widget with a pull-down menu of values
// .SECTION Description
// A simple subclass of entry that adds a pull-down menu where a predefined
// set of values can be chosed to set the entry field.
// .SECTION Thanks
// This work is part of the National Alliance for Medical Image
// Computing (NAMIC), funded by the National Institutes of Health
// through the NIH Roadmap for Medical Research, Grant U54 EB005149.
// Information on the National Centers for Biomedical Computing
// can be obtained from http://nihroadmap.nih.gov/bioinformatics.
// .SECTION See Also
// vtkKWEntry
#ifndef __vtkKWComboBox_h
#define __vtkKWComboBox_h
#include "vtkKWEntry.h"
class KWWidgets_EXPORT vtkKWComboBox : public vtkKWEntry
{
public:
static vtkKWComboBox* New();
vtkTypeRevisionMacro(vtkKWComboBox,vtkKWEntry);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Add and delete values to put in the list.
virtual void AddValue(const char* value);
virtual void AddValueAsInt(int value);
virtual void DeleteValue(int idx);
virtual int HasValue(const char* value);
virtual int GetValueIndex(const char* value);
virtual int GetNumberOfValues();
virtual void DeleteAllValues();
// Description:
// Get the corresponding value given an index
// Note that the output of GetValueFromIndex is a pointer to a
// temporary buffer that should be copied *immediately* to your own storage.
virtual const char* GetValueFromIndex(int idx);
// Description:
// Replace the nth value in the combo box with another string value.
virtual void ReplaceNthValue( int n, const char* value );
// Description:
// Set/Get the value of the entry in a few different formats.
// Overriden to comply with the Tk type
virtual void SetValue(const char *);
// 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,
// or a value is picked from the dropdown list.
// 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);
// 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:
// Set/Get the width of the listbox in the dropdown, in pixels.
virtual void SetListboxWidth(int n);
virtual int GetListboxWidth();
// Description:
// Set/Get the background color of the widget.
// Override the super to make sure all elements are set correctly.
virtual void SetBackgroundColor(double r, double g, double b);
virtual void SetBackgroundColor(double rgb[3])
{ this->SetBackgroundColor(rgb[0], rgb[1], rgb[2]); };
protected:
vtkKWComboBox();
~vtkKWComboBox();
// Description:
// Create the widget.
virtual void CreateWidget();
private:
vtkKWComboBox(const vtkKWComboBox&); // Not implemented
void operator=(const vtkKWComboBox&); // Not Implemented
};
#endif