2018-02-21 14:30:34 +01:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2016 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_ENCODED_FRAME_H_
|
|
|
|
|
#define API_VIDEO_ENCODED_FRAME_H_
|
|
|
|
|
|
2018-11-28 16:47:49 +01:00
|
|
|
#include <stddef.h>
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
2022-03-02 15:13:55 +01:00
|
|
|
#include "absl/types/optional.h"
|
|
|
|
|
#include "api/units/timestamp.h"
|
2018-02-21 14:30:34 +01:00
|
|
|
#include "modules/video_coding/encoded_frame.h"
|
2019-07-05 19:08:33 +02:00
|
|
|
|
2018-02-21 14:30:34 +01:00
|
|
|
namespace webrtc {
|
|
|
|
|
|
|
|
|
|
// TODO(philipel): Remove webrtc::VCMEncodedFrame inheritance.
|
2018-03-19 15:34:53 +01:00
|
|
|
// TODO(philipel): Move transport specific info out of EncodedFrame.
|
|
|
|
|
// NOTE: This class is still under development and may change without notice.
|
2018-02-22 14:35:06 +01:00
|
|
|
class EncodedFrame : public webrtc::VCMEncodedFrame {
|
2018-02-21 14:30:34 +01:00
|
|
|
public:
|
|
|
|
|
static const uint8_t kMaxFrameReferences = 5;
|
|
|
|
|
|
2018-02-22 14:35:06 +01:00
|
|
|
EncodedFrame() = default;
|
2019-06-20 11:13:03 +02:00
|
|
|
EncodedFrame(const EncodedFrame&) = default;
|
2018-02-22 14:35:06 +01:00
|
|
|
virtual ~EncodedFrame() {}
|
2018-02-21 14:30:34 +01:00
|
|
|
|
|
|
|
|
// When this frame was received.
|
2022-03-02 15:13:55 +01:00
|
|
|
// TODO(bugs.webrtc.org/13756): Use Timestamp instead of int.
|
2018-02-21 14:30:34 +01:00
|
|
|
virtual int64_t ReceivedTime() const = 0;
|
2022-03-07 14:50:51 +01:00
|
|
|
// Returns a Timestamp from `ReceivedTime`, or nullopt if there is no receive
|
|
|
|
|
// time.
|
|
|
|
|
absl::optional<webrtc::Timestamp> ReceivedTimestamp() const;
|
2018-02-21 14:30:34 +01:00
|
|
|
|
|
|
|
|
// When this frame should be rendered.
|
2022-03-02 15:13:55 +01:00
|
|
|
// TODO(bugs.webrtc.org/13756): Use Timestamp instead of int.
|
2018-02-21 14:30:34 +01:00
|
|
|
virtual int64_t RenderTime() const = 0;
|
2022-03-02 15:13:55 +01:00
|
|
|
// Returns a Timestamp from `RenderTime`, or nullopt if there is no
|
|
|
|
|
// render time.
|
|
|
|
|
absl::optional<webrtc::Timestamp> RenderTimestamp() const;
|
2018-02-21 14:30:34 +01:00
|
|
|
|
|
|
|
|
// This information is currently needed by the timing calculation class.
|
|
|
|
|
// TODO(philipel): Remove this function when a new timing class has
|
|
|
|
|
// been implemented.
|
2018-03-27 08:31:45 +02:00
|
|
|
virtual bool delayed_by_retransmission() const;
|
2018-02-21 14:30:34 +01:00
|
|
|
|
|
|
|
|
bool is_keyframe() const { return num_references == 0; }
|
|
|
|
|
|
2021-02-16 11:13:25 +01:00
|
|
|
void SetId(int64_t id) { id_ = id; }
|
|
|
|
|
int64_t Id() const { return id_; }
|
2021-02-15 13:31:29 +01:00
|
|
|
|
2018-02-21 14:30:34 +01:00
|
|
|
// TODO(philipel): Add simple modify/access functions to prevent adding too
|
2021-07-25 21:50:14 +02:00
|
|
|
// many `references`.
|
2018-02-21 14:30:34 +01:00
|
|
|
size_t num_references = 0;
|
|
|
|
|
int64_t references[kMaxFrameReferences];
|
2018-12-04 15:54:52 +01:00
|
|
|
// Is this subframe the last one in the superframe (In RTP stream that would
|
|
|
|
|
// mean that the last packet has a marker bit set).
|
|
|
|
|
bool is_last_spatial_layer = true;
|
2021-02-16 11:13:25 +01:00
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
// The ID of the frame is determined from RTP level information. The IDs are
|
|
|
|
|
// used to describe order and dependencies between frames.
|
|
|
|
|
int64_t id_ = -1;
|
2018-02-21 14:30:34 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace webrtc
|
|
|
|
|
|
|
|
|
|
#endif // API_VIDEO_ENCODED_FRAME_H_
|