1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

refactor(video): update code and documentation to honour QSize validity

This commit is contained in:
initramfs 2016-08-05 08:43:15 +08:00
parent df3345dce5
commit 07f5cf3a65
No known key found for this signature in database
GPG Key ID: 78B8BDF87E9EF0AF
3 changed files with 21 additions and 15 deletions

View File

@ -360,7 +360,7 @@ void CoreAV::sendCallVideo(uint32_t callId, std::shared_ptr<VideoFrame> vframe)
call.nullVideoBitrate = false; call.nullVideoBitrate = false;
} }
ToxYUVFrame frame = vframe->toToxAVFrame(); ToxYUVFrame frame = vframe->toToxYUVFrame();
if(frame.width == 0 || frame.height == 0) if(frame.width == 0 || frame.height == 0)
{ {

View File

@ -293,8 +293,8 @@ void VideoFrame::releaseFrame()
* If a given frame does not exist, this function will perform appropriate conversions to * If a given frame does not exist, this function will perform appropriate conversions to
* return a frame that fulfills the given parameters. * return a frame that fulfills the given parameters.
* *
* @param frameSize the dimensions of the frame to get. If frame size is 0, defaults to source * @param frameSize the dimensions of the frame to get. Defaults to source frame size if frameSize
* frame size. * is invalid.
* @param pixelFormat the desired pixel format of the frame. * @param pixelFormat the desired pixel format of the frame.
* @param requireAligned true if the returned frame must be frame aligned, false if not. * @param requireAligned true if the returned frame must be frame aligned, false if not.
* @return a pointer to a AVFrame with the given parameters or nullptr if the VideoFrame is no * @return a pointer to a AVFrame with the given parameters or nullptr if the VideoFrame is no
@ -302,6 +302,11 @@ void VideoFrame::releaseFrame()
*/ */
const AVFrame* VideoFrame::getAVFrame(QSize frameSize, const int pixelFormat, const bool requireAligned) const AVFrame* VideoFrame::getAVFrame(QSize frameSize, const int pixelFormat, const bool requireAligned)
{ {
if(!frameSize.isValid())
{
frameSize = sourceDimensions.size();
}
// Since we are retrieving the AVFrame* directly, we merely need to pass the arguement through // Since we are retrieving the AVFrame* directly, we merely need to pass the arguement through
const std::function<AVFrame*(AVFrame* const)> converter = [](AVFrame* const frame) const std::function<AVFrame*(AVFrame* const)> converter = [](AVFrame* const frame)
{ {
@ -321,14 +326,14 @@ const AVFrame* VideoFrame::getAVFrame(QSize frameSize, const int pixelFormat, co
* The VideoFrame will be scaled into the RGB24 pixel format along with the given * The VideoFrame will be scaled into the RGB24 pixel format along with the given
* dimension. * dimension.
* *
* @param frameSize the given frame size of QImage to generate. If frame size is 0, defaults to * @param frameSize the given frame size of QImage to generate. Defaults to source frame size if
* source frame size. * frameSize is invalid.
* @return a QImage that represents this VideoFrame, sharing it's buffers or a null image if * @return a QImage that represents this VideoFrame, sharing it's buffers or a null image if
* this VideoFrame is no longer valid. * this VideoFrame is no longer valid.
*/ */
QImage VideoFrame::toQImage(QSize frameSize) QImage VideoFrame::toQImage(QSize frameSize)
{ {
if(frameSize.width() == 0 && frameSize.height() == 0) if(!frameSize.isValid())
{ {
frameSize = sourceDimensions.size(); frameSize = sourceDimensions.size();
} }
@ -349,14 +354,15 @@ QImage VideoFrame::toQImage(QSize frameSize)
* The given ToxAVFrame will be frame aligned under a pixel format of planar YUV with a chroma * The given ToxAVFrame will be frame aligned under a pixel format of planar YUV with a chroma
* subsampling format of 4:2:0 (i.e. AV_PIX_FMT_YUV420P). * subsampling format of 4:2:0 (i.e. AV_PIX_FMT_YUV420P).
* *
* @param frameSize the given frame size of ToxAVFrame to generate. If frame size is 0, defaults * @param frameSize the given frame size of ToxAVFrame to generate. Defaults to source frame size
* if frameSize is invalid.
* to source frame size. * to source frame size.
* @return a ToxAVFrame structure that represents this VideoFrame, sharing it's buffers or an * @return a ToxAVFrame structure that represents this VideoFrame, sharing it's buffers or an
* empty structure if this VideoFrame is no longer valid. * empty structure if this VideoFrame is no longer valid.
*/ */
ToxYUVFrame VideoFrame::toToxAVFrame(QSize frameSize) ToxYUVFrame VideoFrame::toToxYUVFrame(QSize frameSize)
{ {
if(frameSize.width() == 0 && frameSize.height() == 0) if(!frameSize.isValid())
{ {
frameSize = sourceDimensions.size(); frameSize = sourceDimensions.size();
} }
@ -386,7 +392,7 @@ ToxYUVFrame VideoFrame::toToxAVFrame(QSize frameSize)
* Note: this function differs from getAVFrame() in that it returns a nullptr if no frame was * Note: this function differs from getAVFrame() in that it returns a nullptr if no frame was
* found. * found.
* *
* @param dimensions the dimensions of the frame. * @param dimensions the dimensions of the frame, must be valid.
* @param pixelFormat the desired pixel format of the frame. * @param pixelFormat the desired pixel format of the frame.
* @param requireAligned true if the frame must be frame aligned, false otherwise. * @param requireAligned true if the frame must be frame aligned, false otherwise.
* @return a pointer to a AVFrame with the given parameters or nullptr if no such frame was * @return a pointer to a AVFrame with the given parameters or nullptr if no such frame was
@ -425,7 +431,7 @@ AVFrame* VideoFrame::retrieveAVFrame(const QSize& dimensions, const int pixelFor
* *
* This function is not thread-safe and must be called from a thread-safe context. * This function is not thread-safe and must be called from a thread-safe context.
* *
* @param dimensions the required dimensions for the frame. * @param dimensions the required dimensions for the frame, must be valid.
* @param pixelFormat the required pixel format for the frame. * @param pixelFormat the required pixel format for the frame.
* @param requireAligned true if the generated frame needs to be frame aligned, false otherwise. * @param requireAligned true if the generated frame needs to be frame aligned, false otherwise.
* @return an AVFrame with the given specifications. * @return an AVFrame with the given specifications.
@ -499,7 +505,7 @@ AVFrame* VideoFrame::generateAVFrame(const QSize& dimensions, const int pixelFor
* This function is not thread-safe and must be called from a thread-safe context. * This function is not thread-safe and must be called from a thread-safe context.
* *
* @param frame the given frame to store. * @param frame the given frame to store.
* @param dimensions the dimensions of the frame. * @param dimensions the dimensions of the frame, must be valid.
* @param pixelFormat the pixel format of the frame. * @param pixelFormat the pixel format of the frame.
*/ */
void VideoFrame::storeAVFrame(AVFrame* frame, const QSize& dimensions, const int pixelFormat) void VideoFrame::storeAVFrame(AVFrame* frame, const QSize& dimensions, const int pixelFormat)

View File

@ -76,8 +76,8 @@ public:
void releaseFrame(); void releaseFrame();
const AVFrame* getAVFrame(QSize frameSize, const int pixelFormat, const bool requireAligned); const AVFrame* getAVFrame(QSize frameSize, const int pixelFormat, const bool requireAligned);
QImage toQImage(QSize frameSize = {0, 0}); QImage toQImage(QSize frameSize = {});
ToxYUVFrame toToxAVFrame(QSize frameSize = {0, 0}); ToxYUVFrame toToxYUVFrame(QSize frameSize = {});
/** /**
* @brief Returns the ID for the given frame. * @brief Returns the ID for the given frame.
@ -237,7 +237,7 @@ private:
* a null object of type T that represents an invalid/null object for when the generation * a null object of type T that represents an invalid/null object for when the generation
* process fails (e.g. when the VideoFrame is no longer valid). * process fails (e.g. when the VideoFrame is no longer valid).
* *
* @param dimensions the dimensions of the frame. * @param dimensions the dimensions of the frame, must be valid.
* @param pixelFormat the pixel format of the frame. * @param pixelFormat the pixel format of the frame.
* @param requireAligned true if the generated frame needs to be frame aligned, false otherwise. * @param requireAligned true if the generated frame needs to be frame aligned, false otherwise.
* @param objectConstructor a std::function that takes the generated AVFrame and converts it * @param objectConstructor a std::function that takes the generated AVFrame and converts it