1 /*
2  *  Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 #ifndef WEBRTC_COMMON_VIDEO_VIDEO_RENDER_FRAMES_H_
12 #define WEBRTC_COMMON_VIDEO_VIDEO_RENDER_FRAMES_H_
13 
14 #include <stdint.h>
15 
16 #include <list>
17 
18 #include "webrtc/video_frame.h"
19 
20 namespace webrtc {
21 
22 // Class definitions
23 class VideoRenderFrames {
24  public:
25   VideoRenderFrames();
26 
27   // Add a frame to the render queue
28   int32_t AddFrame(const VideoFrame& new_frame);
29 
30   // Get a frame for rendering, or a zero-size frame if it's not time to render.
31   VideoFrame FrameToRender();
32 
33   // Releases all frames
34   int32_t ReleaseAllFrames();
35 
36   // Returns the number of ms to next frame to render
37   uint32_t TimeToNextFrameRelease();
38 
39   // Sets estimates delay in renderer
40   int32_t SetRenderDelay(const uint32_t render_delay);
41 
42  private:
43   // 10 seconds for 30 fps.
44   enum { KMaxNumberOfFrames = 300 };
45   // Don't render frames with timestamp older than 500ms from now.
46   enum { KOldRenderTimestampMS = 500 };
47   // Don't render frames with timestamp more than 10s into the future.
48   enum { KFutureRenderTimestampMS = 10000 };
49 
50   // Sorted list with framed to be rendered, oldest first.
51   std::list<VideoFrame> incoming_frames_;
52 
53   // Estimated delay from a frame is released until it's rendered.
54   uint32_t render_delay_ms_;
55 };
56 
57 }  // namespace webrtc
58 
59 #endif  // WEBRTC_COMMON_VIDEO_VIDEO_RENDER_FRAMES_H_
60