mirror of
https://github.com/opencv/opencv.git
synced 2024-12-11 14:39:11 +08:00
6b5ac42a9b
Conflicts: modules/calib3d/doc/camera_calibration_and_3d_reconstruction.rst modules/features2d/doc/common_interfaces_of_descriptor_extractors.rst modules/features2d/doc/object_categorization.rst modules/gpu/doc/camera_calibration_and_3d_reconstruction.rst modules/gpu/doc/image_filtering.rst modules/gpu/doc/image_processing.rst modules/gpu/doc/video.rst modules/imgproc/doc/miscellaneous_transformations.rst modules/imgproc/doc/object_detection.rst modules/imgproc/doc/structural_analysis_and_shape_descriptors.rst modules/imgproc/src/samplers.cpp modules/ml/doc/k_nearest_neighbors.rst modules/nonfree/doc/feature_detection.rst modules/ocl/include/opencv2/ocl/ocl.hpp modules/photo/doc/inpainting.rst modules/ts/include/opencv2/ts.hpp platforms/scripts/camera_build.conf samples/android/camera-calibration/AndroidManifest.xml
157 lines
3.6 KiB
ReStructuredText
157 lines
3.6 KiB
ReStructuredText
Video Decoding
|
|
==============
|
|
|
|
.. highlight:: cpp
|
|
|
|
|
|
|
|
gpucodec::VideoReader
|
|
---------------------
|
|
Video reader interface.
|
|
|
|
.. ocv:class:: gpucodec::VideoReader
|
|
|
|
.. note::
|
|
|
|
* An example on how to use the videoReader class can be found at opencv_source_code/samples/gpu/video_reader.cpp
|
|
|
|
|
|
gpucodec::VideoReader::nextFrame
|
|
--------------------------------
|
|
Grabs, decodes and returns the next video frame.
|
|
|
|
.. ocv:function:: bool gpucodec::VideoReader::nextFrame(OutputArray frame)
|
|
|
|
If no frames has been grabbed (there are no more frames in video file), the methods return ``false`` . The method throws :ocv:class:`Exception` if error occurs.
|
|
|
|
|
|
|
|
gpucodec::VideoReader::format
|
|
-----------------------------
|
|
Returns information about video file format.
|
|
|
|
.. ocv:function:: FormatInfo gpucodec::VideoReader::format() const
|
|
|
|
|
|
|
|
gpucodec::Codec
|
|
---------------
|
|
Video codecs supported by :ocv:class:`gpucodec::VideoReader` .
|
|
|
|
.. ocv:enum:: gpucodec::Codec
|
|
|
|
.. ocv:emember:: MPEG1 = 0
|
|
.. ocv:emember:: MPEG2
|
|
.. ocv:emember:: MPEG4
|
|
.. ocv:emember:: VC1
|
|
.. ocv:emember:: H264
|
|
.. ocv:emember:: JPEG
|
|
.. ocv:emember:: H264_SVC
|
|
.. ocv:emember:: H264_MVC
|
|
|
|
.. ocv:emember:: Uncompressed_YUV420 = (('I'<<24)|('Y'<<16)|('U'<<8)|('V'))
|
|
|
|
Y,U,V (4:2:0)
|
|
|
|
.. ocv:emember:: Uncompressed_YV12 = (('Y'<<24)|('V'<<16)|('1'<<8)|('2'))
|
|
|
|
Y,V,U (4:2:0)
|
|
|
|
.. ocv:emember:: Uncompressed_NV12 = (('N'<<24)|('V'<<16)|('1'<<8)|('2'))
|
|
|
|
Y,UV (4:2:0)
|
|
|
|
.. ocv:emember:: Uncompressed_YUYV = (('Y'<<24)|('U'<<16)|('Y'<<8)|('V'))
|
|
|
|
YUYV/YUY2 (4:2:2)
|
|
|
|
.. ocv:emember:: Uncompressed_UYVY = (('U'<<24)|('Y'<<16)|('V'<<8)|('Y'))
|
|
|
|
UYVY (4:2:2)
|
|
|
|
|
|
|
|
gpucodec::ChromaFormat
|
|
----------------------
|
|
Chroma formats supported by :ocv:class:`gpucodec::VideoReader` .
|
|
|
|
.. ocv:enum:: gpucodec::ChromaFormat
|
|
|
|
.. ocv:emember:: Monochrome = 0
|
|
.. ocv:emember:: YUV420
|
|
.. ocv:emember:: YUV422
|
|
.. ocv:emember:: YUV444
|
|
|
|
|
|
|
|
gpucodec::FormatInfo
|
|
--------------------
|
|
.. ocv:struct:: gpucodec::FormatInfo
|
|
|
|
Struct providing information about video file format. ::
|
|
|
|
struct FormatInfo
|
|
{
|
|
Codec codec;
|
|
ChromaFormat chromaFormat;
|
|
int width;
|
|
int height;
|
|
};
|
|
|
|
|
|
|
|
gpucodec::createVideoReader
|
|
---------------------------
|
|
Creates video reader.
|
|
|
|
.. ocv:function:: Ptr<VideoReader> gpucodec::createVideoReader(const String& filename)
|
|
.. ocv:function:: Ptr<VideoReader> gpucodec::createVideoReader(const Ptr<RawVideoSource>& source)
|
|
|
|
:param filename: Name of the input video file.
|
|
|
|
:param source: RAW video source implemented by user.
|
|
|
|
FFMPEG is used to read videos. User can implement own demultiplexing with :ocv:class:`gpucodec::RawVideoSource` .
|
|
|
|
|
|
|
|
gpucodec::RawVideoSource
|
|
------------------------
|
|
.. ocv:class:: gpucodec::RawVideoSource
|
|
|
|
Interface for video demultiplexing. ::
|
|
|
|
class RawVideoSource
|
|
{
|
|
public:
|
|
virtual ~RawVideoSource() {}
|
|
|
|
virtual bool getNextPacket(unsigned char** data, int* size, bool* endOfFile) = 0;
|
|
|
|
virtual FormatInfo format() const = 0;
|
|
};
|
|
|
|
User can implement own demultiplexing by implementing this interface.
|
|
|
|
|
|
|
|
gpucodec::RawVideoSource::getNextPacket
|
|
---------------------------------------
|
|
Returns next packet with RAW video frame.
|
|
|
|
.. ocv:function:: bool gpucodec::VideoSource::getNextPacket(unsigned char** data, int* size, bool* endOfFile) = 0
|
|
|
|
:param data: Pointer to frame data.
|
|
|
|
:param size: Size in bytes of current frame.
|
|
|
|
:param endOfStream: Indicates that it is end of stream.
|
|
|
|
|
|
|
|
gpucodec::RawVideoSource::format
|
|
--------------------------------
|
|
Returns information about video file format.
|
|
|
|
.. ocv:function:: virtual FormatInfo gpucodec::RawVideoSource::format() const = 0
|