zoneminder/src/zm_ffmpeg_camera.h

119 lines
3.6 KiB
C
Raw Normal View History

//
// ZoneMinder Ffmpeg Class Interface, $Date: 2008-07-25 10:33:23 +0100 (Fri, 25 Jul 2008) $, $Revision: 2611 $
// Copyright (C) 2001-2008 Philip Coombes
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
#ifndef ZM_FFMPEG_CAMERA_H
#define ZM_FFMPEG_CAMERA_H
#include "zm_camera.h"
#include "zm_buffer.h"
#include "zm_ffmpeg.h"
#include "zm_videostore.h"
2017-08-17 01:41:44 +08:00
#if HAVE_AVUTIL_HWCONTEXT_H
typedef struct DecodeContext {
AVBufferRef *hw_device_ref;
} DecodeContext;
2017-08-17 01:41:44 +08:00
#endif
//
// Class representing 'ffmpeg' cameras, i.e. those which are
// accessed using ffmpeg multimedia framework
//
class FfmpegCamera : public Camera {
protected:
std::string mPath;
std::string mMethod;
std::string mOptions;
std::string encoder_options;
int frameCount;
#if HAVE_LIBAVFORMAT
AVFormatContext *mFormatContext;
2016-09-08 21:39:04 +08:00
AVCodec *mVideoCodec;
AVCodec *mAudioCodec;
AVFrame *mRawFrame;
AVFrame *mFrame;
bool hwaccel;
2017-08-17 01:41:44 +08:00
#if HAVE_AVUTIL_HWCONTEXT_H
AVFrame *hwFrame;
2018-08-10 23:16:27 +08:00
DecodeContext decode;
2017-08-17 01:41:44 +08:00
#endif
// Need to keep track of these because apparently the stream can start with values for pts/dts and then subsequent packets start at zero.
int64_t audio_last_pts;
int64_t audio_last_dts;
int64_t video_last_pts;
int64_t video_last_dts;
2016-09-24 03:39:52 +08:00
// Used to store the incoming packet, it will get copied when queued.
// We only ever need one at a time, so instead of constantly allocating
// and freeing this structure, we will just make it a member of the object.
AVPacket packet;
int OpenFfmpeg();
int Close();
bool mCanCapture;
#endif // HAVE_LIBAVFORMAT
int error_count;
public:
FfmpegCamera(
int p_id,
const std::string &path,
const std::string &p_method,
const std::string &p_options,
int p_width,
int p_height,
int p_colours,
int p_brightness,
int p_contrast,
int p_hue,
int p_colour,
bool p_capture,
bool p_record_audio );
~FfmpegCamera();
const std::string &Path() const { return( mPath ); }
const std::string &Options() const { return( mOptions ); }
const std::string &Method() const { return( mMethod ); }
int PrimeCapture();
int PreCapture();
int Capture(ZMPacket &p);
int PostCapture();
AVStream *get_VideoStream() {
2017-10-23 21:51:41 +08:00
if ( mVideoStreamId != -1 )
return mFormatContext->streams[mVideoStreamId];
return NULL;
}
AVStream *get_AudioStream() {
2017-10-23 21:51:41 +08:00
if ( mAudioStreamId != -1 )
return mFormatContext->streams[mAudioStreamId];
return NULL;
}
AVCodecContext *get_VideoCodecContext() { return mVideoCodecContext; };
AVCodecContext *get_AudioCodecContext() { return mAudioCodecContext; };
private:
static int FfmpegInterruptCallback(void*ctx);
};
#endif // ZM_FFMPEG_CAMERA_H