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:
parent
df3345dce5
commit
07f5cf3a65
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue
Block a user