|
| ArPTZ (ArRobot *robot) |
|
virtual bool | canGetFOV (void) |
| Whether we can get the FOV (field of view) or not.
|
|
virtual bool | canGetRealPanTilt (void) const |
| Whether getPan() hand getTilt() return the device's real position, or last commanded position.
|
|
virtual bool | canGetRealZoom (void) const |
| Whether getZoom() returns the device's real zoom amount, or last commanded zoom position.
|
|
virtual bool | canPanTiltSlew () |
| Can pan and tilt speed (slew rates) be set to move device?
|
|
virtual bool | canSetFocus (void) const |
| If the driver can set the focus on the camera, or not.
|
|
virtual bool | canSetGain (void) const |
| If the driver can set gain on the camera, or not.
|
|
virtual bool | canZoom (void) const =0 |
| Returns true if camera can zoom and this class can control the zoom amount.
|
|
virtual void | connectHandler (void) |
| Internal, attached to robot, inits the camera when robot connects.
|
|
virtual int | getAuxPort (void) |
| Gets the port the device is set to communicate on.
|
|
virtual ArDeviceConnection * | getDeviceConnection (void) |
| Gets the device connection used by this PTZ camera.
|
|
virtual double | getFocus (double focus) const |
| Get the focus the camera is set to. 0 if not supported.
|
|
virtual double | getFOVAtMaxZoom (void) |
| Gets the field of view at maximum zoom.
|
|
virtual double | getFOVAtMinZoom (void) |
| Gets the field of view at minimum zoom.
|
|
virtual double | getGain (double gain) const |
| Get the gain the camera is set to. 0 if not supported.
|
|
bool | getInverted () |
| Get whether the camera is inverted (upside down). If true, pan and tilt axes will be reversed.
|
|
virtual double | getMaxNegPan (void) const |
| Gets the lowest negative degree the camera can pan to (inverted if camera is inverted)
|
|
virtual double | getMaxNegTilt (void) const |
| Gets the lowest negative degree the camera can tilt to (inverted if camera is inverted)
|
|
double | getMaxPan () const |
| Gets the highest positive degree the camera can pan to (inverted if camera is inverted) More...
|
|
virtual double | getMaxPosPan (void) const |
| Gets the highest positive degree the camera can pan to (inverted if camera is inverted)
|
|
virtual double | getMaxPosTilt (void) const |
| Gets the highest positive degree the camera can tilt to (inverted if camera is inverted)
|
|
double | getMaxTilt () const |
| Gets the highest positive degree the camera can tilt to (inverted if camera is inverted) More...
|
|
virtual int | getMaxZoom (void) const |
| Gets the maximum value for the zoom on this camera.
|
|
double | getMinPan () const |
| Gets the lowest negative degree the camera can pan to (inverted if camera is inverted) More...
|
|
double | getMinTilt () const |
| Gets the lowest negative degree the camera can tilt to (inverted if camera is inverted) More...
|
|
virtual int | getMinZoom (void) const |
| Gets the lowest value for the zoom on this camera.
|
|
virtual double | getPan (void) const |
| The angle the camera is panned to (or last commanded value sent, if unable to obtain real pan position) More...
|
|
ArRobot * | getRobot () |
| Return ArRobot object this PTZ is associated with. May be NULL.
|
|
virtual double | getTilt (void) const |
| The angle the camera is tilted to (or last commanded value sent, if unable to obtain real pan position) More...
|
|
virtual const char * | getTypeName ()=0 |
| Return name of this PTZ type.
|
|
virtual int | getZoom (void) const |
| The amount the camera is zoomed to (or last commanded value sent, if unable to obtain real pan position) More...
|
|
virtual bool | haltPanTilt () |
| Halt any pan/tilt movement, if device supports it.
|
|
virtual bool | haltZoom () |
| Halt any zoom movement, if device supports that.
|
|
virtual bool | init (void)=0 |
| Initializes the camera.
|
|
virtual bool | packetHandler (ArBasePacket *packet) |
| Handles a packet that was read from the device. More...
|
|
virtual bool | pan (double degrees) |
| Pans to the given degrees. 0 is straight ahead, - is to the left, + to the right.
|
|
virtual bool | panRel (double degrees) |
| Pans relative to current position by given degrees.
|
|
virtual bool | panSlew (double s) |
| Set pan slew rate (speed) (degrees/sec) if device supports it (see canPanTiltSlew())
|
|
virtual bool | panTilt (double degreesPan, double degreesTilt) |
| Pans and tilts to the given degrees.
|
|
virtual bool | panTiltRel (double degreesPan, double degreesTilt) |
| Pans and tilts relatives to the current position by the given degrees.
|
|
virtual ArBasePacket * | readPacket (void) |
| Reads a packet from the device connection, MUST NOT BLOCK. More...
|
|
virtual void | reset (void) |
| Resets the camera. More...
|
|
virtual bool | robotPacketHandler (ArRobotPacket *packet) |
| Handles a packet that was read by the robot. More...
|
|
virtual bool | sendPacket (ArBasePacket *packet) |
| Sends a given packet to the camera (via robot or serial port, depending) More...
|
|
virtual void | sensorInterpHandler (void) |
| Internal, for attaching to the robots sensor interp to read serial port.
|
|
virtual bool | setAuxPort (int auxPort) |
| Sets the aux port on the robot to be used to communicate with this device. More...
|
|
virtual bool | setDeviceConnection (ArDeviceConnection *connection, bool driveFromRobotLoop=true) |
| Sets the device connection to be used by this PTZ camera, if set this camera will send commands via this connection, otherwise its via robot aux. More...
|
|
virtual bool | setFocus (double focus) const |
| Set focus on camera, range of 1-100. More...
|
|
virtual bool | setGain (double gain) const |
| Set gain on camera, range of 1-100. More...
|
|
void | setInverted (bool inv) |
| Set whether the camera is inverted (upside down). If true, pan and tilt axes will be reversed.
|
|
virtual bool | tilt (double degrees) |
| Tilts to the given degrees. 0 is middle, - is downward, + is upwards.
|
|
virtual bool | tiltRel (double degrees) |
| Tilts relative to the current position by given degrees.
|
|
virtual bool | tiltSlew (double s) |
| Set tilt slew rate (speed) (degrees/sec) if device supports it (see canPanTiltSlew())
|
|
virtual bool | zoom (int zoomValue) |
| Zooms to the given value.
|
|
virtual bool | zoomRel (int zoomValue) |
| Zooms relative to the current value, by the given value.
|
|
virtual | ~ArPTZ () |
| Destructor.
|
|
|
void | setLimits (double maxPosPan, double maxNegPan, double maxPosTilt, double maxNegTilt, int maxZoom=0, int minZoom=0) |
| Subclasses call this to set extents (limits) returned by getMaxPosPan(), getMaxNegPan(), getMaxPosTilt(), getMaxNegTilt(), getMaxZoom(), and getMinZoom(). More...
|
|
|
virtual double | getMaxPosPan_i (void) const |
| Versions of the pan and tilt limit accessors where inversion is not applied, for use by subclasses to check when given pan/tilt commands. More...
|
|
double | getMaxPan_i () const |
|
virtual double | getMaxPosTilt_i (void) const |
|
double | getMinPan_i () const |
|
virtual double | getMaxNegPan_i (void) const |
|
double | getMaxTilt_i () const |
|
virtual double | getMaxNegTilt_i (void) const |
|
double | getMinTilt_i () const |
|
|
virtual bool | pan_i (double degrees)=0 |
| Internal implementations by subclasses. More...
|
|
virtual bool | panRel_i (double degrees)=0 |
|
virtual bool | tilt_i (double degrees)=0 |
|
virtual bool | tiltRel_i (double degrees)=0 |
|
virtual bool | panTilt_i (double degreesPan, double degreesTilt)=0 |
|
virtual bool | panTiltRel_i (double degreesPan, double degreesTilt)=0 |
|
virtual double | getPan_i (void) const =0 |
|
virtual double | getTilt_i (void) const =0 |
|
Base class which handles the PTZ cameras.
This class is mainly concerned with making all the cameras look the same for outgoing data, it is also set up to facilitate the acquisition of incoming data but that is described in the following paragraphs. There are two ways this can be used. The first is the simplest and default behavior and should be used by those whose cameras are attached to their robot's microcontroller, a ArRobot pointer is passed in to the contructor, this is where the commands will be sent to the robot via the robot's connection which will then send it along over the second serial port. The second way is to pass an ArDeviceConnection to setDeviceConnection, if this is done commands will be sent along the given serial port, this should ONLY be done if the camera is attached straight to a serial port on the computer this program is running on.
The next two paragraphs describe how to get data back from the cameras, but this base class is set up so that by default it won't try to get data back and assumes you're not trying to do that. If you are trying to get data back the important functions are packetHandler, robotPacketHandler and readPacket and you should read the docs on those.
If the camera is attached to the robot (and you are thus using the first method described in the first paragraph) then the only way to get data back is to send an ArCommands::GETAUX, then set up a robotPacketHandler for the AUX id and have it call the packetHandler you set up in in the class.
If the camera is attached to the serial port on the computer (and thus the second method described in the first paragraph was used) then its more complicated... the default way is to just pass in an ArDeviceConnection to setDeviceConnection and implement the readPacket method (which MUST not block), and every time through the robot loop readPacket (with the sensorInterpHandler) will be called and any packets will be given to the packetHandler (which you need to implement in your class) to be processed. The other way to do this method is to pass both an ArDefaultConnection and false to setDeviceConnection, this means the camera will not be read at all by default, and you're on your own for reading the data in (ie like your own thread).
- Examples:
- cameraPTZExample.cpp.