новые иконки в OpenBoard
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.
OpenBoard/src/podcast/quicktime/UBQuickTimeFile.h

143 lines
4.0 KiB

/*
* Copyright (C) 2012 Webdoc SA
*
* This file is part of Open-Sankoré.
*
* Open-Sankoré is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation, version 2,
* with a specific linking exception for the OpenSSL project's
* "OpenSSL" library (or with modified versions of it that use the
* same license as the "OpenSSL" library).
*
* Open-Sankoré is distributed in the hope that it will be useful,
14 years ago
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
14 years ago
*
* You should have received a copy of the GNU Library General Public
* License along with Open-Sankoré; if not, see
* <http://www.gnu.org/licenses/>.
*/
#ifndef UBQUICKTIMEFILE_H_
#define UBQUICKTIMEFILE_H_
#include <QtCore>
#include <ApplicationServices/ApplicationServices.h>
#include <QuickTime/QuickTime.h>
#include <AudioToolbox/AudioToolbox.h>
#include "UBAudioQueueRecorder.h"
class UBQuickTimeFile : public QThread
{
Q_OBJECT;
public:
UBQuickTimeFile(QObject * pParent = 0);
virtual ~UBQuickTimeFile();
bool init(const QString& videoFileName, const QString& profileData
, int pFramesPerSecond, const QSize& pFrameSize
, bool recordAudio = true, const QString& audioDeviceName = QString("Default"));
void stop();
CVPixelBufferRef newPixelBuffer();
bool isCompressionSessionRunning()
{
return mCompressionSessionRunning;
}
QString lastErrorMessage() const
{
return mLastErrorMessage;
}
struct VideoFrame
{
CVPixelBufferRef buffer;
long timestamp;
};
static QQueue<VideoFrame> frameQueue;
static QMutex frameQueueMutex;
static QWaitCondition frameBufferNotEmpty;
signals:
void audioLevelChanged(quint8 level);
void compressionSessionStarted();
protected:
void run();
private slots:
void appendAudioBuffer(void* pBuffer, long pLength, int inNumberPacketDescriptions
, const AudioStreamPacketDescription* inPacketDescs);
private:
static OSStatus addEncodedFrameToMovie(void *encodedFrameOutputRefCon,
ICMCompressionSessionRef session,
OSStatus err,
ICMEncodedFrameRef encodedFrame,
void *reserved);
void appendVideoFrame(CVPixelBufferRef pixelBuffer, long msTimeStamp);
void addEncodedFrame(ICMEncodedFrameRef encodedFrame, OSStatus err);
bool createCompressionSession();
bool closeCompressionSession();
bool createMovie();
bool createVideoMedia();
bool createAudioMedia();
void setLastErrorMessage(const QString& error);
bool flushPendingFrames();
ICMCompressionSessionRef mVideoCompressionSession;
Media mVideoMedia;
Media mSoundMedia;
Track mVideoOutputTrack;
Track mSoundOutputTrack;
volatile CVPixelBufferPoolRef mCVPixelBufferPool;
SoundDescriptionHandle mSoundDescription;
Movie mOutputMovie;
DataHandler mOutputMovieDataHandler;
int mFramesPerSecond;
QSize mFrameSize;
QString mVideoFileName;
long mTimeScale;
bool mRecordAudio;
QString mLastErrorMessage;
AudioStreamBasicDescription mAudioDataFormat;
QPointer<UBAudioQueueRecorder> mWaveRecorder;
CodecQ mSpatialQuality;
volatile bool mSouldStopCompression;
volatile bool mCompressionSessionRunning;
QString mAudioRecordingDeviceName;
volatile int mPendingFrames;
};
#endif /* UBQUICKTIMEFILE_H_ */