Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

129 lines
4.0 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkInteractorEventRecorder.h,v $
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.
=========================================================================*/
// .NAME vtkInteractorEventRecorder - record and play VTK events passing through a vtkRenderWindowInteractor
// .SECTION Description
// vtkInteractorEventRecorder records all VTK events invoked from a
// vtkRenderWindowInteractor. The events are recorded to a
// file. vtkInteractorEventRecorder can also be used to play those events
// back and invoke them on an vtkRenderWindowInteractor. (Note: the events
// can also be played back from a file or string.)
//
// The format of the event file is simple. It is:
// EventName X Y ctrl shift keycode repeatCount keySym
// The format also allows "#" comments.
// .SECTION See Also
// vtkInteractorObserver vtkCallback
#ifndef __vtkInteractorEventRecorder_h
#define __vtkInteractorEventRecorder_h
#include "vtkInteractorObserver.h"
// The superclass that all commands should be subclasses of
class VTK_RENDERING_EXPORT vtkInteractorEventRecorder : public vtkInteractorObserver
{
public:
static vtkInteractorEventRecorder *New();
vtkTypeRevisionMacro(vtkInteractorEventRecorder,vtkInteractorObserver);
void PrintSelf(ostream& os, vtkIndent indent);
// Satisfy the superclass API. Enable/disable listening for events.
virtual void SetEnabled(int);
virtual void SetInteractor(vtkRenderWindowInteractor* iren);
// Description:
// Set/Get the name of a file events should be written to/from.
vtkSetStringMacro(FileName);
vtkGetStringMacro(FileName);
// Description:
// Invoke this method to begin recording events. The events will be
// recorded to the filename indicated.
void Record();
// Description:
// Invoke this method to begin playing events from the current position.
// The events will be played back from the filename indicated.
void Play();
// Description:
// Invoke this method to stop recording/playing events.
void Stop();
// Description:
// Rewind to the beginning of the file.
void Rewind();
// Description:
// Enable reading from an InputString as compared to the default
// behavior, which is to read from a file.
vtkSetMacro(ReadFromInputString,int);
vtkGetMacro(ReadFromInputString,int);
vtkBooleanMacro(ReadFromInputString,int);
// Description:
// Set/Get the string to read from.
vtkSetStringMacro(InputString);
vtkGetStringMacro(InputString);
protected:
vtkInteractorEventRecorder();
~vtkInteractorEventRecorder();
// file to read/write from
char *FileName;
// control whether to read from string
int ReadFromInputString;
char *InputString;
// for reading and writing
istream *InputStream;
ostream *OutputStream;
//methods for processing events
static void ProcessCharEvent(vtkObject* object, unsigned long event,
void* clientdata, void* calldata);
static void ProcessEvents(vtkObject* object, unsigned long event,
void* clientdata, void* calldata);
virtual void WriteEvent(const char* event, int pos[2], int ctrlKey,
int shiftKey, int keyCode, int repeatCount,
char* keySym);
virtual void ReadEvent();
//BTX - manage the state of the recorder
int State;
enum WidgetState
{
Start=0,
Playing,
Recording
};
//ETX
static float StreamVersion;
private:
vtkInteractorEventRecorder(const vtkInteractorEventRecorder&); // Not implemented.
void operator=(const vtkInteractorEventRecorder&); // Not implemented.
};
#endif /* __vtkInteractorEventRecorder_h */