PTLib
Version 2.18.8
|
This class defines a video device. More...
#include <videoio.h>
Classes | |
struct | Attributes |
struct | OpenArgs |
Public Member Functions | |
virtual | ~PVideoDevice () |
Delete structures created by PVideoDevice();. More... | |
virtual void | PrintOn (ostream &strm) const |
Output the contents of the object to the stream. More... | |
P_DECLARE_STREAMABLE_ENUM (VideoFormat, PAL, NTSC, SECAM, Auto) | |
virtual PString | GetDeviceName () const |
Get the device name of the open device. More... | |
virtual PStringArray | GetDeviceNames () const =0 |
Get a list of all of the drivers available. More... | |
virtual PBoolean | OpenFull (const OpenArgs &args, PBoolean startImmediate=true) |
Open the device given the device name. More... | |
virtual PBoolean | Open (const PString &deviceName, PBoolean startImmediate=true)=0 |
Open the device given the device name. More... | |
virtual PBoolean | IsOpen ()=0 |
Determine if the device is currently open. More... | |
virtual PBoolean | Close ()=0 |
Close the device. More... | |
virtual PBoolean | Start ()=0 |
Start the video device I/O capture. More... | |
virtual PBoolean | Stop ()=0 |
Stop the video device I/O capture. More... | |
virtual PBoolean | SetVideoFormat (VideoFormat videoFormat) |
Set the video format to be used. More... | |
virtual VideoFormat | GetVideoFormat () const |
Get the video format being used. More... | |
virtual int | GetNumChannels () |
Get the number of video channels available on the device. More... | |
virtual PStringArray | GetChannelNames () |
Get the names of video channels available on the device. More... | |
virtual PBoolean | SetChannel (int channelNumber) |
Set the video channel to be used on the device. More... | |
virtual int | GetChannel () const |
Get the video channel to be used on the device. More... | |
virtual bool | SetFrameInfoConverter (const PVideoFrameInfo &info) |
Set the frame info to be used, trying converters if available. More... | |
virtual PBoolean | SetColourFormatConverter (const PString &colourFormat) |
Set the colour format to be used, trying converters if available. More... | |
virtual PBoolean | GetVFlipState () |
Get the video conversion vertical flip state. More... | |
virtual PBoolean | SetVFlipState (PBoolean newVFlipState) |
Set the video conversion vertical flip state. More... | |
virtual PBoolean | GetFrameSizeLimits (unsigned &minWidth, unsigned &minHeight, unsigned &maxWidth, unsigned &maxHeight) |
Get the minimum & maximum size of a frame on the device. More... | |
virtual PBoolean | SetFrameSizeConverter (unsigned width, unsigned height, ResizeMode resizeMode=eMaxResizeMode) |
Set the frame size to be used, trying converters if available. More... | |
virtual PBoolean | SetNearestFrameSize (unsigned width, unsigned height) |
Set the nearest available frame size to be used. More... | |
virtual PBoolean | SetFrameSize (unsigned width, unsigned height) |
Set the frame size to be used. More... | |
virtual PBoolean | GetFrameSize (unsigned &width, unsigned &height) const |
Get the frame size being used. More... | |
virtual PString | GetColourFormat () const |
Get the colour format being used. More... | |
virtual PINDEX | GetMaxFrameBytes () |
Get the maximum frame size in bytes. More... | |
virtual int | GetLastError () const |
Get the last error code. More... | |
virtual PBoolean | CanCaptureVideo () const =0 |
Is the device a camera, and obtain video. More... | |
virtual bool | GetAttributes (Attributes &attributes) |
Get video attributes. More... | |
virtual bool | SetAttributes (const Attributes &attributes) |
Set video attributes. More... | |
virtual PBoolean | SetVideoChannelFormat (int channelNumber, VideoFormat videoFormat) |
Set VideoFormat and VideoChannel in one ioctl. More... | |
virtual void | SetPreferredColourFormat (const PString &colourFmt) |
Set preferred native colour format from video capture device. More... | |
virtual PString | GetPreferredColourFormat () |
Get preferred native colour format from video capture device. More... | |
![]() | |
P_DECLARE_ENUM_EX (ResizeMode, eMaxResizeMode, eScale, 0, eCropCentre, eCropTopLeft, eScaleKeepAspect) | |
PVideoFrameInfo () | |
Construct video frame information. More... | |
PVideoFrameInfo (unsigned frameWidth, unsigned frameHeight, const PString &colourFormat=PVideoFrameInfo::YUV420P(), unsigned frameRate=15, ResizeMode resizeMode=eScale) | |
virtual Comparison | Compare (const PObject &obj) const |
Compare the two PVideoFrameInfo and return their relative rank. More... | |
virtual unsigned | GetFrameWidth () const |
Get the width of the frame being used. More... | |
virtual unsigned | GetFrameHeight () const |
Get the height of the frame being used. More... | |
virtual PBoolean | SetFrameSar (unsigned width, unsigned height) |
Set the Storage Aspect Ratio size to be used. More... | |
virtual PBoolean | GetSarSize (unsigned &width, unsigned &height) const |
Get the Storage Aspect Ratio size being used. More... | |
virtual unsigned | GetSarWidth () const |
Get the width of the Storage Aspect Ratio being used. More... | |
virtual unsigned | GetSarHeight () const |
Get the height of the Storage Aspect Ratio being used. More... | |
virtual PBoolean | SetFrameRate (unsigned rate) |
Set the video frame rate to be used on the device. More... | |
virtual unsigned | GetFrameRate () const |
Get the video frame rate used on the device. More... | |
virtual PBoolean | SetColourFormat (const PString &colourFormat) |
Set the colour format to be used. More... | |
virtual void | SetResizeMode (ResizeMode mode) |
Set the resize mode to be used. More... | |
virtual ResizeMode | GetResizeMode () const |
Get the resize mode to be used. More... | |
virtual PINDEX | CalculateFrameBytes () const |
Get the number of bytes of an image, given a particular width, height and colour format. More... | |
virtual bool | Parse (const PString &str) |
Parse a descriptor string for the video format. More... | |
![]() | |
__inline unsigned | GetTraceContextIdentifier () const |
Get PTRACE context identifier. More... | |
__inline void | SetTraceContextIdentifier (unsigned id) |
__inline void | SetTraceContextIdentifier (const PObject &obj) |
__inline void | SetTraceContextIdentifier (const PObject *obj) |
__inline void | CopyTraceContextIdentifier (PObject &obj) const |
__inline void | CopyTraceContextIdentifier (PObject *obj) const |
virtual | ~PObject () |
__inline const char * | GetClass () const |
__inline bool | IsClass (const char *name) const |
__inline const PObject * | PTraceObjectInstance () const |
virtual PObject * | Clone () const |
Create a copy of the class on the heap. More... | |
template<class CLS > | |
CLS * | CloneAs () const |
As for Clone() but converts to specified type. More... | |
virtual PINDEX | HashFunction () const |
This function yields a hash value required by the PDictionary class. More... | |
virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
Determine the byte wise comparison of two objects. More... | |
bool | operator== (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator!= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator< (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator> (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator<= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator>= (const PObject &obj) const |
Compare the two objects. More... | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
Protected Member Functions | |
PVideoDevice () | |
Create a new video device (input or output). More... | |
PINDEX | GetMaxFrameBytesConverted (PINDEX rawFrameBytes) const |
PString | GetDeviceNameFromOpenArgs (const OpenArgs &args) const |
PString | ParseDeviceNameTokenString (const char *token, const char *defaultValue) |
int | ParseDeviceNameTokenInt (const char *token, int defaultValue) |
uint64_t | ParseDeviceNameTokenUnsigned (const char *token, uint64_t defaultValue) |
![]() | |
PObject () | |
Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Protected Attributes | |
PCaselessString | m_deviceName |
int | m_lastError |
VideoFormat | m_videoFormat |
int | m_channelNumber |
PString | m_preferredColourFormat |
bool | m_nativeVerticalFlip |
PColourConverter * | m_converter |
PBYTEArray | m_frameStore |
![]() | |
unsigned | m_frameWidth |
unsigned | m_frameHeight |
unsigned | m_sarWidth |
unsigned | m_sarHeight |
unsigned | m_frameRate |
PString | m_colourFormat |
ResizeMode | m_resizeMode |
![]() | |
unsigned | m_traceContextIdentifier |
Additional Inherited Members | |
![]() | |
enum | StandardSizes { SQCIFWidth = 128, SQCIFHeight = 96, QCIFWidth = 176, QCIFHeight = 144, CIFWidth = 352, CIFHeight = 288, CIF4Width = 704, CIF4Height = 576, CIF16Width = 1408, CIF16Height = 1152, HD480Width = 704, HD480Height = 480, i480Width = 704, i480Height = 480, HD720Width = 1280, HD720Height = 720, p720Width = 1280, p720Height = 720, HD1080Width = 1920, HD1080Height = 1080, i1080Width = 1920, i1080Height = 1080, HDTVWidth = 1920, HDTVHeight = 1080, MaxWidth = 1920, MaxHeight = 1200 } |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
![]() | |
static const PString & | YUV420P () |
static PINDEX | CalculateFrameBytes (unsigned width, unsigned height, const PString &colourFormat=PVideoFrameInfo::YUV420P()) |
static bool | ParseSize (const PString &str, unsigned &width, unsigned &height) |
Parse the standard size string names. More... | |
static PString | AsString (unsigned width, unsigned height) |
Get a width/height as a standard size string name. More... | |
static PStringArray | GetSizeNames () |
Get all "known" image size names. More... | |
![]() | |
static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject &from) |
static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject *from) |
static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject &from) |
static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject *from) |
static __inline const char * | Class () |
static __inline const PObject * | PTraceObjectInstance (const char *) |
static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
template<typename T > | |
static Comparison | Compare2 (T v1, T v2) |
Compare two types, returning Comparison type. More... | |
static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
Internal function caled from CompareObjectMemoryDirect() More... | |
This class defines a video device.
This class is used to abstract the few parameters that are common to both\ input and output devices.
Example colour formats are:
"Grey" Simple 8 bit linear grey scale "Gray" Synonym for Grey "RGB32" 32 bit RGB "RGB24" 24 bit RGB "RGB565" 16 bit RGB (6 bit green) "RGB555" 15 bit RGB "YUV422" YUV 4:2:2 packed "YUV422P" YUV 4:2:2 planar "YUV411" YUV 4:1:1 packed "YUV411P" YUV 4:1:1 planar "YUV420" YUV 4:2:0 packed "YUV420P" YUV 4:2:0 planar, use PTLIB_VIDEO_YUV420P or PVideoFrameInfo::YUV420P() "YUV410" YUV 4:1:0 packed "YUV410P" YUV 4:1:0 planar "MJPEG" Motion JPEG "UYVY422" YUV 4:2:2 packed as U Y V Y U Y V Y ... "UYV444" YUV 4:4:4 packed as U Y V U Y V ... They are used in IEEE 1394 digital cameras. The specification is found at http://www.1394ta.org/Download/Technology/Specifications/2000/IIDC_Spec_v1_30.pdf
|
protected |
Create a new video device (input or output).
|
virtual |
Delete structures created by PVideoDevice();.
|
pure virtual |
Is the device a camera, and obtain video.
Implemented in PVideoInputDevice, and PVideoOutputDevice.
|
pure virtual |
Close the device.
Implemented in PVideoInputDeviceIndirect, PVideoInputDevice, PVideoOutputDevice, P_WXWINDOWS_DEVICE_CLASS, and PVideoInput1394DcDevice.
|
virtual |
Get video attributes.
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Get the video channel to be used on the device.
Default behaviour returns the value of the channelNumber variable.
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Get the names of video channels available on the device.
Reimplemented in PVideoInputEmulatedDevice, and PVideoInputDeviceIndirect.
|
virtual |
Get the colour format being used.
If a converter exists, the destination colour format of the converter is returned, not the underlying physical device. If you wish the physical device colout format use PVideoFrameInfo::GetColourFormat().
Reimplemented from PVideoFrameInfo.
|
inlinevirtual |
Get the device name of the open device.
Reimplemented in PVideoInputDeviceIndirect.
References m_deviceName.
|
pure virtual |
Get a list of all of the drivers available.
Implemented in PVideoInputDeviceIndirect, and P_WXWINDOWS_DEVICE_CLASS.
|
virtual |
Get the frame size being used.
If a converter exists, the destination frame size of the converter is returned, not the underlying physical device. If you wish the physical device frame size use PVideoFrameInfo::GetFrameSize().
Reimplemented from PVideoFrameInfo.
|
virtual |
Get the minimum & maximum size of a frame on the device.
Default behaviour returns the value 1 to UINT_MAX for both and returns false.
minWidth | Variable to receive minimum width |
minHeight | Variable to receive minimum height |
maxWidth | Variable to receive maximum width |
maxHeight | Variable to receive maximum height |
Reimplemented in PVideoInputEmulatedDevice, PVideoInputDeviceIndirect, and PVideoInput1394DcDevice.
|
inlinevirtual |
Get the last error code.
This is a platform dependent number.
Reimplemented in PVideoInputDeviceIndirect.
References m_lastError.
|
virtual |
Get the maximum frame size in bytes.
This gets the maximum of the physical device or the converted frame size and colour format. It is guranteed to be enought memory space for any video grab or output.
Note, a particular device may be able to provide variable length frames (eg motion JPEG) so this will be the maximum size of all frames.
Reimplemented in PVideoOutputDeviceRGB, and PVideoInput1394DcDevice.
|
protected |
|
virtual |
Get the number of video channels available on the device.
Default behaviour returns 1.
Reimplemented in PVideoInputEmulatedDevice, PVideoInputDeviceIndirect, and PVideoInput1394DcDevice.
|
inlinevirtual |
Get preferred native colour format from video capture device.
Returns empty == no preference
References m_preferredColourFormat.
|
virtual |
Get the video conversion vertical flip state.
Default action is to return false.
|
virtual |
Get the video format being used.
Default behaviour returns the value of the videoFormat variable.
|
pure virtual |
Determine if the device is currently open.
Implemented in PVideoInputDeviceIndirect, P_WXWINDOWS_DEVICE_CLASS, and PVideoInput1394DcDevice.
|
pure virtual |
Open the device given the device name.
deviceName | Device name to open |
startImmediate | Immediately start device |
Implemented in PVideoInputDeviceIndirect, PVideoInputDevice, P_WXWINDOWS_DEVICE_CLASS, and PVideoInput1394DcDevice.
|
virtual |
Open the device given the device name.
args | Parameters to set on opened device |
startImmediate | Immediately start device |
Reimplemented in PVideoInputDeviceIndirect.
PVideoDevice::P_DECLARE_STREAMABLE_ENUM | ( | VideoFormat | , |
PAL | , | ||
NTSC | , | ||
SECAM | , | ||
Auto | |||
) |
|
protected |
Referenced by P_WXWINDOWS_DEVICE_CLASS::InternalOpen().
|
protected |
Referenced by P_WXWINDOWS_DEVICE_CLASS::InternalOpen().
|
protected |
|
virtual |
Output the contents of the object to the stream.
The exact output is dependent on the exact semantics of the descendent class. This is primarily used by the standard operator<<
function.
The default behaviour is to print the class name.
Reimplemented from PVideoFrameInfo.
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set video attributes.
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set the video channel to be used on the device.
The channel number is an integer from 0 to GetNumChannels()-1. The special value of -1 will find the first working channel number.
Default behaviour sets the value of the channelNumber variable and then returns true.
channelNumber | New channel number for device. |
Reimplemented in PVideoInputDeviceIndirect, and PVideoInput1394DcDevice.
Set the colour format to be used, trying converters if available.
This function will set the colour format on the device to one that is compatible with a registered converter, and install that converter so that the correct format is used.
Reimplemented in PVideoInputDeviceIndirect, and PVideoInput1394DcDevice.
|
virtual |
Set the frame info to be used, trying converters if available.
This function will simply call SetColourFormatConverter(), SetFrameSizeConverter() and SetFrameRate().
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set the frame size to be used.
Note that devices may not be able to produce the requested size, and this function will fail. See SetFrameSizeConverter().
Default behaviour sets the frameWidth and frameHeight variables and then sets the converter sizes.
width | New width of frame |
height | New height of frame |
Reimplemented from PVideoFrameInfo.
Reimplemented in PVideoInputEmulatedDevice, PVideoInputDeviceIndirect, PVideoOutputDeviceRGB, PVideoInput1394DcDevice, and P_WXWINDOWS_DEVICE_CLASS.
|
virtual |
Set the frame size to be used, trying converters if available.
If the device does not support the size, a set of alternate resolutions are attempted. A converter is setup if possible.
width | New width of frame |
height | New height of frame |
resizeMode | Mode to use if resizing is required. |
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set the nearest available frame size to be used.
Note that devices may not be able to produce the requested size, so this function picks the nearest available size.
Default behaviour simply calls SetFrameSize().
width | New width of frame |
height | New height of frame |
Reimplemented in PVideoInputDeviceIndirect, and PVideoInputDevice.
|
inlinevirtual |
Set preferred native colour format from video capture device.
Note empty == no preference.
References m_preferredColourFormat.
Set the video conversion vertical flip state.
Default action is to return false.
newVFlipState | New vertical flip state |
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set VideoFormat and VideoChannel in one ioctl.
Reimplemented in PVideoInputDeviceIndirect.
|
virtual |
Set the video format to be used.
Default behaviour sets the value of the videoFormat variable and then returns true.
videoFormat | New video format |
Reimplemented in PVideoInputDeviceIndirect, and PVideoInput1394DcDevice.
|
pure virtual |
Start the video device I/O capture.
Implemented in PVideoInputEmulatedDevice, PVideoInputDeviceIndirect, PVideoOutputDevice, and PVideoInput1394DcDevice.
|
pure virtual |
Stop the video device I/O capture.
Implemented in PVideoInputEmulatedDevice, PVideoInputDeviceIndirect, PVideoOutputDevice, PVideoInput1394DcDevice, and P_WXWINDOWS_DEVICE_CLASS.
|
protected |
|
protected |
|
protected |
Referenced by GetDeviceName(), and P_WXWINDOWS_DEVICE_CLASS::Open().
|
protected |
Referenced by P_WXWINDOWS_DEVICE_CLASS::FrameComplete().
|
protected |
Referenced by GetLastError().
|
protected |
Referenced by P_WXWINDOWS_DEVICE_CLASS::P_WXWINDOWS_DEVICE_CLASS().
|
protected |
Referenced by GetPreferredColourFormat(), and SetPreferredColourFormat().
|
protected |