blob: 00c0186a26d9419b5db5e226ca8609e3b44f695a [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
mflodman@webrtc.org9ba151b2012-06-21 10:02:13 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
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
pbos@webrtc.orgf5d4cb12013-05-17 13:44:48 +000011#include "webrtc/video_engine/vie_render_impl.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000012
pbos@webrtc.orgf5d4cb12013-05-17 13:44:48 +000013#include "webrtc/engine_configurations.h"
andrew@webrtc.org9841d922012-10-31 05:22:11 +000014#include "webrtc/modules/video_render/include/video_render.h"
15#include "webrtc/modules/video_render/include/video_render_defines.h"
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000016#include "webrtc/system_wrappers/interface/logging.h"
pbos@webrtc.orgf5d4cb12013-05-17 13:44:48 +000017#include "webrtc/video_engine/include/vie_errors.h"
18#include "webrtc/video_engine/vie_capturer.h"
19#include "webrtc/video_engine/vie_channel.h"
20#include "webrtc/video_engine/vie_channel_manager.h"
21#include "webrtc/video_engine/vie_defines.h"
22#include "webrtc/video_engine/vie_frame_provider_base.h"
23#include "webrtc/video_engine/vie_impl.h"
24#include "webrtc/video_engine/vie_input_manager.h"
25#include "webrtc/video_engine/vie_render_manager.h"
26#include "webrtc/video_engine/vie_renderer.h"
27#include "webrtc/video_engine/vie_shared_data.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000028
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000029namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000030
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000031ViERender* ViERender::GetInterface(VideoEngine* video_engine) {
niklase@google.com470e71d2011-07-07 08:21:25 +000032#ifdef WEBRTC_VIDEO_ENGINE_RENDER_API
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000033 if (!video_engine) {
niklase@google.com470e71d2011-07-07 08:21:25 +000034 return NULL;
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000035 }
andrew@webrtc.orgd72262d2013-05-09 02:12:07 +000036 VideoEngineImpl* vie_impl = static_cast<VideoEngineImpl*>(video_engine);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000037 ViERenderImpl* vie_render_impl = vie_impl;
38 // Increase ref count.
39 (*vie_render_impl)++;
40 return vie_render_impl;
41#else
42 return NULL;
niklase@google.com470e71d2011-07-07 08:21:25 +000043#endif
44}
45
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000046int ViERenderImpl::Release() {
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000047 // Decrease ref count
48 (*this)--;
pbos@webrtc.orgb238d122013-04-09 13:41:51 +000049 int32_t ref_count = GetCount();
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000050 if (ref_count < 0) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000051 LOG(LS_ERROR) << "ViERender release too many times";
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000052 return -1;
53 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000054 return ref_count;
niklase@google.com470e71d2011-07-07 08:21:25 +000055}
56
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000057ViERenderImpl::ViERenderImpl(ViESharedData* shared_data)
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000058 : shared_data_(shared_data) {}
niklase@google.com470e71d2011-07-07 08:21:25 +000059
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000060ViERenderImpl::~ViERenderImpl() {}
niklase@google.com470e71d2011-07-07 08:21:25 +000061
niklase@google.com470e71d2011-07-07 08:21:25 +000062int ViERenderImpl::RegisterVideoRenderModule(
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000063 VideoRender& render_module) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000064 LOG_F(LS_INFO);
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000065 if (shared_data_->render_manager()->RegisterVideoRenderModule(
mflodman@webrtc.orgcee447a2012-06-28 07:29:46 +000066 &render_module) != 0) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000067 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000068 return -1;
69 }
70 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +000071}
72
niklase@google.com470e71d2011-07-07 08:21:25 +000073int ViERenderImpl::DeRegisterVideoRenderModule(
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000074 VideoRender& render_module) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000075 LOG_F(LS_INFO);
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000076 if (shared_data_->render_manager()->DeRegisterVideoRenderModule(
mflodman@webrtc.orgcee447a2012-06-28 07:29:46 +000077 &render_module) != 0) {
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000078 // Error logging is done in ViERenderManager::DeRegisterVideoRenderModule.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000079 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000080 return -1;
81 }
82 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +000083}
84
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000085int ViERenderImpl::AddRenderer(const int render_id, void* window,
86 const unsigned int z_order, const float left,
niklase@google.com470e71d2011-07-07 08:21:25 +000087 const float top, const float right,
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000088 const float bottom) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000089 LOG_F(LS_INFO) << "render_id: " << render_id << " z_order: " << z_order
90 << " left: " << left << " top: " << top << " right: " << right
91 << " bottom: " << bottom;
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000092 {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000093 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org42d07f02011-12-20 13:20:36 +000094 if (rs.Renderer(render_id)) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +000095 LOG(LS_ERROR) << "Renderer for render_id: " << render_id
96 << " already exists.";
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +000097 shared_data_->SetLastError(kViERenderAlreadyExists);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +000098 return -1;
niklase@google.com470e71d2011-07-07 08:21:25 +000099 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000100 }
101 if (render_id >= kViEChannelIdBase && render_id <= kViEChannelIdMax) {
102 // This is a channel.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000103 ViEChannelManagerScoped cm(*(shared_data_->channel_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000104 ViEFrameProviderBase* frame_provider = cm.Channel(render_id);
105 if (!frame_provider) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000106 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000107 return -1;
108 }
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000109 ViERenderer* renderer = shared_data_->render_manager()->AddRenderStream(
110 render_id, window, z_order, left, top, right, bottom);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000111 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000112 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000113 return -1;
114 }
115 return frame_provider->RegisterFrameCallback(render_id, renderer);
116 } else {
117 // Camera or file.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000118 ViEInputManagerScoped is(*(shared_data_->input_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000119 ViEFrameProviderBase* frame_provider = is.FrameProvider(render_id);
120 if (!frame_provider) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000121 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000122 return -1;
123 }
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000124 ViERenderer* renderer = shared_data_->render_manager()->AddRenderStream(
125 render_id, window, z_order, left, top, right, bottom);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000126 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000127 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000128 return -1;
129 }
130 return frame_provider->RegisterFrameCallback(render_id, renderer);
131 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000132}
niklase@google.com470e71d2011-07-07 08:21:25 +0000133
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000134int ViERenderImpl::RemoveRenderer(const int render_id) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000135 LOG_F(LS_INFO) << "render_id: " << render_id;
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000136 ViERenderer* renderer = NULL;
137 {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000138 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000139 renderer = rs.Renderer(render_id);
140 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000141 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000142 return -1;
niklase@google.com470e71d2011-07-07 08:21:25 +0000143 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000144 // Leave the scope lock since we don't want to lock two managers
145 // simultanousely.
146 }
147 if (render_id >= kViEChannelIdBase && render_id <= kViEChannelIdMax) {
148 // This is a channel.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000149 ViEChannelManagerScoped cm(*(shared_data_->channel_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000150 ViEChannel* channel = cm.Channel(render_id);
151 if (!channel) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000152 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000153 return -1;
niklase@google.com470e71d2011-07-07 08:21:25 +0000154 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000155 channel->DeregisterFrameCallback(renderer);
156 } else {
157 // Provider owned by inputmanager, i.e. file or capture device.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000158 ViEInputManagerScoped is(*(shared_data_->input_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000159 ViEFrameProviderBase* provider = is.FrameProvider(render_id);
160 if (!provider) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000161 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000162 return -1;
163 }
164 provider->DeregisterFrameCallback(renderer);
165 }
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000166 if (shared_data_->render_manager()->RemoveRenderStream(render_id) != 0) {
167 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000168 return -1;
169 }
170 return 0;
171}
172
173int ViERenderImpl::StartRender(const int render_id) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000174 LOG_F(LS_INFO) << "render_id: " << render_id;
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000175 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000176 ViERenderer* renderer = rs.Renderer(render_id);
177 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000178 shared_data_->SetLastError(kViERenderInvalidRenderId);
niklase@google.com470e71d2011-07-07 08:21:25 +0000179 return -1;
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000180 }
181 if (renderer->StartRender() != 0) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000182 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000183 return -1;
184 }
185 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000186}
187
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000188int ViERenderImpl::StopRender(const int render_id) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000189 LOG_F(LS_INFO) << "render_id: " << render_id;
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000190 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000191 ViERenderer* renderer = rs.Renderer(render_id);
192 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000193 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000194 return -1;
195 }
196 if (renderer->StopRender() != 0) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000197 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000198 return -1;
199 }
200 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000201}
202
mflodman@webrtc.orgf4f21452012-09-28 11:27:35 +0000203int ViERenderImpl::SetExpectedRenderDelay(int render_id, int render_delay) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000204 LOG_F(LS_INFO) << "render_id: " << render_id
205 << " render_delay: " << render_delay;
mflodman@webrtc.orgf4f21452012-09-28 11:27:35 +0000206 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
207 ViERenderer* renderer = rs.Renderer(render_id);
208 if (!renderer) {
mflodman@webrtc.orgf4f21452012-09-28 11:27:35 +0000209 shared_data_->SetLastError(kViERenderInvalidRenderId);
210 return -1;
211 }
212 if (renderer->SetExpectedRenderDelay(render_delay) != 0) {
213 shared_data_->SetLastError(kViERenderUnknownError);
214 return -1;
215 }
216 return 0;
217}
218
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000219int ViERenderImpl::ConfigureRender(int render_id, const unsigned int z_order,
niklase@google.com470e71d2011-07-07 08:21:25 +0000220 const float left, const float top,
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000221 const float right, const float bottom) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000222 LOG_F(LS_INFO) << "render_id: " << render_id << " z_order: " << z_order
223 << " left: " << left << " top: " << top << " right: " << right
224 << " bottom: " << bottom;
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000225 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000226 ViERenderer* renderer = rs.Renderer(render_id);
227 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000228 shared_data_->SetLastError(kViERenderInvalidRenderId);
niklase@google.com470e71d2011-07-07 08:21:25 +0000229 return -1;
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000230 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000231
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000232 if (renderer->ConfigureRenderer(z_order, left, top, right, bottom) != 0) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000233 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000234 return -1;
235 }
236 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000237}
238
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000239int ViERenderImpl::MirrorRenderStream(const int render_id, const bool enable,
240 const bool mirror_xaxis,
241 const bool mirror_yaxis) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000242 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000243 ViERenderer* renderer = rs.Renderer(render_id);
244 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000245 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000246 return -1;
247 }
248 if (renderer->EnableMirroring(render_id, enable, mirror_xaxis, mirror_yaxis)
249 != 0) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000250 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000251 return -1;
252 }
253 return 0;
254}
255
256int ViERenderImpl::AddRenderer(const int render_id,
257 RawVideoType video_input_format,
258 ExternalRenderer* external_renderer) {
259 // Check if the client requested a format that we can convert the frames to.
260 if (video_input_format != kVideoI420 &&
261 video_input_format != kVideoYV12 &&
262 video_input_format != kVideoYUY2 &&
263 video_input_format != kVideoUYVY &&
264 video_input_format != kVideoARGB &&
265 video_input_format != kVideoRGB24 &&
266 video_input_format != kVideoRGB565 &&
267 video_input_format != kVideoARGB4444 &&
268 video_input_format != kVideoARGB1555) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000269 LOG(LS_ERROR) << "Unsupported video frame format requested.";
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000270 shared_data_->SetLastError(kViERenderInvalidFrameFormat);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000271 return -1;
272 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000273 {
mflodman@webrtc.org42d07f02011-12-20 13:20:36 +0000274 // Verify the renderer doesn't exist.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000275 ViERenderManagerScoped rs(*(shared_data_->render_manager()));
mflodman@webrtc.org42d07f02011-12-20 13:20:36 +0000276 if (rs.Renderer(render_id)) {
pbos@webrtc.org4e2806d2014-05-14 08:02:22 +0000277 LOG_F(LS_ERROR) << "Renderer already exists for render_id: " << render_id;
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000278 shared_data_->SetLastError(kViERenderAlreadyExists);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000279 return -1;
280 }
281 }
282 if (render_id >= kViEChannelIdBase && render_id <= kViEChannelIdMax) {
283 // This is a channel.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000284 ViEChannelManagerScoped cm(*(shared_data_->channel_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000285 ViEFrameProviderBase* frame_provider = cm.Channel(render_id);
286 if (!frame_provider) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000287 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000288 return -1;
289 }
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000290 ViERenderer* renderer = shared_data_->render_manager()->AddRenderStream(
291 render_id, NULL, 0, 0.0f, 0.0f, 1.0f, 1.0f);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000292 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000293 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000294 return -1;
295 }
296 if (renderer->SetExternalRenderer(render_id, video_input_format,
297 external_renderer) == -1) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000298 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000299 return -1;
300 }
301
302 return frame_provider->RegisterFrameCallback(render_id, renderer);
303 } else {
304 // Camera or file.
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000305 ViEInputManagerScoped is(*(shared_data_->input_manager()));
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000306 ViEFrameProviderBase* frame_provider = is.FrameProvider(render_id);
307 if (!frame_provider) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000308 shared_data_->SetLastError(kViERenderInvalidRenderId);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000309 return -1;
310 }
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000311 ViERenderer* renderer = shared_data_->render_manager()->AddRenderStream(
312 render_id, NULL, 0, 0.0f, 0.0f, 1.0f, 1.0f);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000313 if (!renderer) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000314 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000315 return -1;
316 }
317 if (renderer->SetExternalRenderer(render_id, video_input_format,
318 external_renderer) == -1) {
mflodman@webrtc.orgb11424b2012-01-25 13:42:03 +0000319 shared_data_->SetLastError(kViERenderUnknownError);
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000320 return -1;
321 }
322 return frame_provider->RegisterFrameCallback(render_id, renderer);
323 }
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000324}
325
pbos@webrtc.orgd29d4e92013-11-20 13:19:54 +0000326int ViERenderImpl::AddRenderCallback(int render_id,
327 VideoRenderCallback* callback) {
328 if (render_id < kViEChannelIdBase || render_id > kViEChannelIdMax)
329 return -1;
330 // This is a channel.
331 ViEChannelManagerScoped cm(*(shared_data_->channel_manager()));
332 ViEFrameProviderBase* frame_provider = cm.Channel(render_id);
333 if (!frame_provider) {
pbos@webrtc.orgd29d4e92013-11-20 13:19:54 +0000334 shared_data_->SetLastError(kViERenderInvalidRenderId);
335 return -1;
336 }
337 ViERenderer* renderer = shared_data_->render_manager()->AddRenderStream(
338 render_id, NULL, 0, 0.0f, 0.0f, 1.0f, 1.0f);
339 if (!renderer) {
340 shared_data_->SetLastError(kViERenderUnknownError);
341 return -1;
342 }
343 if (renderer->SetVideoRenderCallback(render_id, callback) != 0) {
344 shared_data_->SetLastError(kViERenderUnknownError);
345 return -1;
346 }
347
348 return frame_provider->RegisterFrameCallback(render_id, renderer);
349}
350
mflodman@webrtc.org8da24172011-12-19 14:18:41 +0000351} // namespace webrtc