blob: 7cb9ed1aa5eb54116d705a38c2ccccc46e47cdec [file] [log] [blame]
pbos@webrtc.org1ecee9a2013-05-29 11:34:321/*
2 * Copyright (c) 2013 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
Peter Boström7623ce42015-12-09 11:13:3011#ifndef WEBRTC_VIDEO_RENDERER_H_
12#define WEBRTC_VIDEO_RENDERER_H_
pbos@webrtc.org1ecee9a2013-05-29 11:34:3213
14namespace webrtc {
15
Miguel Casas-Sanchez47650702015-05-30 00:21:4016class VideoFrame;
pbos@webrtc.org1ecee9a2013-05-29 11:34:3217
pbos@webrtc.org1ecee9a2013-05-29 11:34:3218class VideoRenderer {
19 public:
20 // This function should return as soon as possible and not block until it's
21 // time to render the frame.
Miguel Casas-Sanchez47650702015-05-30 00:21:4022 // TODO(mflodman) Remove time_to_render_ms when VideoFrame contains NTP.
23 virtual void RenderFrame(const VideoFrame& video_frame,
pbos@webrtc.org1ecee9a2013-05-29 11:34:3224 int time_to_render_ms) = 0;
25
pbos@webrtc.org0d852d52015-02-09 15:14:3626 virtual bool IsTextureSupported() const = 0;
27
qiangchen444682a2015-11-25 02:07:5628 // This function returns true if WebRTC should not delay frames for
29 // smoothness. In general, this case means the renderer can schedule frames to
30 // optimize smoothness.
31 virtual bool SmoothsRenderedFrames() const { return false; }
32
pbos@webrtc.org1ecee9a2013-05-29 11:34:3233 protected:
34 virtual ~VideoRenderer() {}
35};
pbos@webrtc.org1ecee9a2013-05-29 11:34:3236} // namespace webrtc
37
Peter Boström7623ce42015-12-09 11:13:3038#endif // WEBRTC_VIDEO_RENDERER_H_