webrtc_m130/api/video/recordable_encoded_frame.h
Markus Handell 588f9b3705 VideoReceiveStream2: AV1 encoded sink support.
This change adds support for emitting encoded frames
for recording when the decoder can't easily read out
encoded width and height as is the case for AV1 streams,
in which case the information is buried in OBUs. Downstream
project relies on resolution information being present for key
frames. With the change, VideoReceiveStream2 infers the
resolution from decoded frames, and supplies it in the
RecordableEncodedFrames.

Bug: chromium:1191972
Change-Id: I07beda6526206c80a732976e8e19d3581489b8fe
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/214126
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Philip Eliasson <philipel@webrtc.org>
Reviewed-by: Erik Språng <sprang@webrtc.org>
Commit-Queue: Markus Handell <handellm@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#33662}
2021-04-08 20:07:22 +00:00

62 lines
1.9 KiB
C++

/*
* 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 API_VIDEO_RECORDABLE_ENCODED_FRAME_H_
#define API_VIDEO_RECORDABLE_ENCODED_FRAME_H_
#include "api/array_view.h"
#include "api/scoped_refptr.h"
#include "api/units/timestamp.h"
#include "api/video/color_space.h"
#include "api/video/encoded_image.h"
#include "api/video/video_codec_type.h"
#include "rtc_base/ref_count.h"
namespace webrtc {
// Interface for accessing recordable elements of an encoded frame.
class RecordableEncodedFrame {
public:
// Encoded resolution in pixels
struct EncodedResolution {
bool empty() const { return width == 0 && height == 0; }
unsigned width = 0;
unsigned height = 0;
};
virtual ~RecordableEncodedFrame() = default;
// Provides access to encoded data
virtual rtc::scoped_refptr<const EncodedImageBufferInterface> encoded_buffer()
const = 0;
// Optionally returns the colorspace of the encoded frame. This can differ
// from the eventually decoded frame's colorspace.
virtual absl::optional<webrtc::ColorSpace> color_space() const = 0;
// Returns the codec of the encoded frame
virtual VideoCodecType codec() const = 0;
// Returns whether the encoded frame is a key frame
virtual bool is_key_frame() const = 0;
// Returns the frame's encoded resolution. May be 0x0 if the frame
// doesn't contain resolution information
virtual EncodedResolution resolution() const = 0;
// Returns the computed render time
virtual Timestamp render_time() const = 0;
};
} // namespace webrtc
#endif // API_VIDEO_RECORDABLE_ENCODED_FRAME_H_