VTK  9.1.0
vtkObject.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkObject.h
5
6 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 All rights reserved.
8 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9
10 This software is distributed WITHOUT ANY WARRANTY; without even
11 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 PURPOSE. See the above copyright notice for more information.
13
14=========================================================================*/
59#ifndef vtkObject_h
60#define vtkObject_h
61
62#include "vtkCommonCoreModule.h" // For export macro
63#include "vtkObjectBase.h"
64#include "vtkSetGet.h"
65#include "vtkTimeStamp.h"
66#include "vtkWeakPointerBase.h" // needed for vtkWeakPointer
67
68class vtkSubjectHelper;
69class vtkCommand;
70
71class VTKCOMMONCORE_EXPORT vtkObject : public vtkObjectBase
72{
73public:
75
80 static vtkObject* New();
81
82#ifdef _WIN32
83 // avoid dll boundary problems
84 void* operator new(size_t tSize);
85 void operator delete(void* p);
86#endif
87
91 virtual void DebugOn();
92
96 virtual void DebugOff();
97
101 bool GetDebug();
102
106 void SetDebug(bool debugFlag);
107
112 static void BreakOnError();
113
120 virtual void Modified();
121
126
133 void PrintSelf(ostream& os, vtkIndent indent) override;
134
136
140 static void SetGlobalWarningDisplay(int val);
145
147
159 unsigned long AddObserver(unsigned long event, vtkCommand*, float priority = 0.0f);
160 unsigned long AddObserver(const char* event, vtkCommand*, float priority = 0.0f);
161 vtkCommand* GetCommand(unsigned long tag);
163 void RemoveObservers(unsigned long event, vtkCommand*);
164 void RemoveObservers(const char* event, vtkCommand*);
165 vtkTypeBool HasObserver(unsigned long event, vtkCommand*);
166 vtkTypeBool HasObserver(const char* event, vtkCommand*);
168
169 void RemoveObserver(unsigned long tag);
170 void RemoveObservers(unsigned long event);
171 void RemoveObservers(const char* event);
172 void RemoveAllObservers(); // remove every last one of them
173 vtkTypeBool HasObserver(unsigned long event);
174 vtkTypeBool HasObserver(const char* event);
175
177
202 template <class U, class T>
203 unsigned long AddObserver(
204 unsigned long event, U observer, void (T::*callback)(), float priority = 0.0f)
205 {
206 vtkClassMemberCallback<T>* callable = new vtkClassMemberCallback<T>(observer, callback);
207 // callable is deleted when the observer is cleaned up (look at
208 // vtkObjectCommandInternal)
209 return this->AddTemplatedObserver(event, callable, priority);
210 }
211 template <class U, class T>
212 unsigned long AddObserver(unsigned long event, U observer,
213 void (T::*callback)(vtkObject*, unsigned long, void*), float priority = 0.0f)
214 {
215 vtkClassMemberCallback<T>* callable = new vtkClassMemberCallback<T>(observer, callback);
216 // callable is deleted when the observer is cleaned up (look at
217 // vtkObjectCommandInternal)
218 return this->AddTemplatedObserver(event, callable, priority);
219 }
221
223
227 template <class U, class T>
228 unsigned long AddObserver(unsigned long event, U observer,
229 bool (T::*callback)(vtkObject*, unsigned long, void*), float priority = 0.0f)
230 {
231 vtkClassMemberCallback<T>* callable = new vtkClassMemberCallback<T>(observer, callback);
232 // callable is deleted when the observer is cleaned up (look at
233 // vtkObjectCommandInternal)
234 return this->AddTemplatedObserver(event, callable, priority);
235 }
237
239
244 int InvokeEvent(unsigned long event, void* callData);
245 int InvokeEvent(const char* event, void* callData);
247
248 int InvokeEvent(unsigned long event) { return this->InvokeEvent(event, nullptr); }
249 int InvokeEvent(const char* event) { return this->InvokeEvent(event, nullptr); }
250
251protected:
253 ~vtkObject() override;
254
255 // See vtkObjectBase.h.
258
259 bool Debug; // Enable debug messages
260 vtkTimeStamp MTime; // Keep track of modification time
261 vtkSubjectHelper* SubjectHelper; // List of observers on this object
262
264
272 void InternalGrabFocus(vtkCommand* mouseEvents, vtkCommand* keypressEvents = nullptr);
275
276private:
277 vtkObject(const vtkObject&) = delete;
278 void operator=(const vtkObject&) = delete;
279
287 class vtkClassMemberCallbackBase
288 {
289 public:
291
294 virtual bool operator()(vtkObject*, unsigned long, void*) = 0;
295 virtual ~vtkClassMemberCallbackBase() = default;
297 };
298
300
304 template <class T>
305 class vtkClassMemberHandlerPointer
306 {
307 public:
308 void operator=(vtkObjectBase* o)
309 {
310 // The cast is needed in case "o" has multi-inheritance,
311 // to offset the pointer to get the vtkObjectBase.
312 if ((this->VoidPointer = dynamic_cast<T*>(o)) == nullptr)
313 {
314 // fallback to just using its vtkObjectBase as-is.
315 this->VoidPointer = o;
316 }
317 this->WeakPointer = o;
318 this->UseWeakPointer = true;
319 }
320 void operator=(void* o)
321 {
322 this->VoidPointer = o;
323 this->WeakPointer = nullptr;
324 this->UseWeakPointer = false;
325 }
326 T* GetPointer()
327 {
328 if (this->UseWeakPointer && !this->WeakPointer.GetPointer())
329 {
330 return nullptr;
331 }
332 return static_cast<T*>(this->VoidPointer);
333 }
334
335 private:
336 vtkWeakPointerBase WeakPointer;
337 void* VoidPointer;
338 bool UseWeakPointer;
339 };
341
343
346 template <class T>
347 class vtkClassMemberCallback : public vtkClassMemberCallbackBase
348 {
349 vtkClassMemberHandlerPointer<T> Handler;
350 void (T::*Method1)();
351 void (T::*Method2)(vtkObject*, unsigned long, void*);
352 bool (T::*Method3)(vtkObject*, unsigned long, void*);
353
354 public:
355 vtkClassMemberCallback(T* handler, void (T::*method)())
356 {
357 this->Handler = handler;
358 this->Method1 = method;
359 this->Method2 = nullptr;
360 this->Method3 = nullptr;
361 }
362
363 vtkClassMemberCallback(T* handler, void (T::*method)(vtkObject*, unsigned long, void*))
364 {
365 this->Handler = handler;
366 this->Method1 = nullptr;
367 this->Method2 = method;
368 this->Method3 = nullptr;
369 }
370
371 vtkClassMemberCallback(T* handler, bool (T::*method)(vtkObject*, unsigned long, void*))
372 {
373 this->Handler = handler;
374 this->Method1 = nullptr;
375 this->Method2 = nullptr;
376 this->Method3 = method;
377 }
378 ~vtkClassMemberCallback() override = default;
379
380 // Called when the event is invoked
381 bool operator()(vtkObject* caller, unsigned long event, void* calldata) override
382 {
383 T* handler = this->Handler.GetPointer();
384 if (handler)
385 {
386 if (this->Method1)
387 {
388 (handler->*this->Method1)();
389 }
390 else if (this->Method2)
391 {
392 (handler->*this->Method2)(caller, event, calldata);
393 }
394 else if (this->Method3)
395 {
396 return (handler->*this->Method3)(caller, event, calldata);
397 }
398 }
399 return false;
400 }
401 };
403
405
408 unsigned long AddTemplatedObserver(
409 unsigned long event, vtkClassMemberCallbackBase* callable, float priority);
410 // Friend to access AddTemplatedObserver().
411 friend class vtkObjectCommandInternal;
413};
414
415#endif
416// VTK-HeaderTest-Exclude: vtkObject.h
superclass for callback/observer methods
Definition: vtkCommand.h:394
a simple class to control print indentation
Definition: vtkIndent.h:43
abstract base class for most VTK objects
Definition: vtkObjectBase.h:79
void operator=(const vtkObjectBase &)
abstract base class for most VTK objects
Definition: vtkObject.h:72
vtkBaseTypeMacro(vtkObject, vtkObjectBase)
void InternalReleaseFocus()
These methods allow a command to exclusively grab all events.
virtual void DebugOn()
Turn debugging output on.
vtkTypeBool HasObserver(unsigned long event)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void RemoveObservers(const char *event)
vtkSubjectHelper * SubjectHelper
Definition: vtkObject.h:261
unsigned long AddObserver(unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f)
Allow user to set the AbortFlagOn() with the return value of the callback method.
Definition: vtkObject.h:228
vtkTypeBool HasObserver(const char *event, vtkCommand *)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
virtual void DebugOff()
Turn debugging output off.
unsigned long AddObserver(unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f)
Overloads to AddObserver that allow developers to add class member functions as callbacks for events.
Definition: vtkObject.h:212
~vtkObject() override
vtkTimeStamp MTime
Definition: vtkObject.h:260
void InternalGrabFocus(vtkCommand *mouseEvents, vtkCommand *keypressEvents=nullptr)
These methods allow a command to exclusively grab all events.
static void SetGlobalWarningDisplay(int val)
This is a global flag that controls whether any debug, warning or error messages are displayed.
void RemoveObserver(vtkCommand *)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
void RemoveObservers(unsigned long event, vtkCommand *)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
int InvokeEvent(unsigned long event)
Definition: vtkObject.h:248
void UnRegisterInternal(vtkObjectBase *, vtkTypeBool check) override
void RemoveAllObservers()
void RegisterInternal(vtkObjectBase *, vtkTypeBool check) override
static void GlobalWarningDisplayOff()
This is a global flag that controls whether any debug, warning or error messages are displayed.
Definition: vtkObject.h:142
int InvokeEvent(const char *event, void *callData)
This method invokes an event and return whether the event was aborted or not.
virtual void Modified()
Update the modification time for this object.
vtkTypeBool HasObserver(unsigned long event, vtkCommand *)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
int InvokeEvent(unsigned long event, void *callData)
This method invokes an event and return whether the event was aborted or not.
bool Debug
Definition: vtkObject.h:259
static int GetGlobalWarningDisplay()
This is a global flag that controls whether any debug, warning or error messages are displayed.
unsigned long AddObserver(unsigned long event, vtkCommand *, float priority=0.0f)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
void RemoveObservers(const char *event, vtkCommand *)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
unsigned long AddObserver(const char *event, vtkCommand *, float priority=0.0f)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on.
void SetDebug(bool debugFlag)
Set the value of the debug flag.
vtkTypeBool HasObserver(const char *event)
static void BreakOnError()
This method is called when vtkErrorMacro executes.
static void GlobalWarningDisplayOn()
This is a global flag that controls whether any debug, warning or error messages are displayed.
Definition: vtkObject.h:141
bool GetDebug()
Get the value of the debug flag.
virtual vtkMTimeType GetMTime()
Return this object's modified time.
void RemoveObservers(unsigned long event)
int InvokeEvent(const char *event)
Definition: vtkObject.h:249
void RemoveObserver(unsigned long tag)
unsigned long AddObserver(unsigned long event, U observer, void(T::*callback)(), float priority=0.0f)
Overloads to AddObserver that allow developers to add class member functions as callbacks for events.
Definition: vtkObject.h:203
vtkCommand * GetCommand(unsigned long tag)
Allow people to add/remove/invoke observers (callbacks) to any VTK object.
record modification and/or execution time
Definition: vtkTimeStamp.h:42
Non-templated superclass for vtkWeakPointer.
int vtkTypeBool
Definition: vtkABI.h:69
vtkTypeUInt32 vtkMTimeType
Definition: vtkType.h:287