blob: 9106bf867bb00861d3d1b4efc60904ced36e43a3 [file] [log] [blame]
/*
* Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#ifndef VIDEO_PARTIAL_FRAME_ASSEMBLER_H_
#define VIDEO_PARTIAL_FRAME_ASSEMBLER_H_
#include "api/video/i420_buffer.h"
#include "api/video/video_frame.h"
namespace webrtc {
// Maintains cache of a full resolution frame buffer and applies partial
// updates to it.
// This class is not thread-safe.
class PartialFrameAssembler {
public:
PartialFrameAssembler();
~PartialFrameAssembler();
// Applies |input_buffer| to the cached buffer and sets buffer for
// |uncompresed_frame| to a full updated image.
// Returns false on any error. In that case the buffer will be invalidated
// and subsequent updates will also return error until full resolution frame
// is processed.
bool ApplyPartialUpdate(
const rtc::scoped_refptr<VideoFrameBuffer>& buffer,
VideoFrame* uncompressed_frame,
const VideoFrame::PartialFrameDescription* partial_desc);
// Clears internal buffer.
void Reset();
private:
rtc::scoped_refptr<I420Buffer> cached_frame_buffer_;
};
} // namespace webrtc
#endif // VIDEO_PARTIAL_FRAME_ASSEMBLER_H_