Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(369)

Unified Diff: webrtc/modules/video_render/linux/video_x11_render.cc

Issue 1923613003: Revert of Delete video_render module. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/modules/video_render/linux/video_x11_render.cc
diff --git a/webrtc/modules/video_render/linux/video_x11_render.cc b/webrtc/modules/video_render/linux/video_x11_render.cc
new file mode 100644
index 0000000000000000000000000000000000000000..5eb4f36f95f1b1ca53021bddfc758947b0a4e0f7
--- /dev/null
+++ b/webrtc/modules/video_render/linux/video_x11_render.cc
@@ -0,0 +1,153 @@
+/*
+ * Copyright (c) 2012 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.
+ */
+
+#include "webrtc/modules/video_render/linux/video_x11_channel.h"
+#include "webrtc/modules/video_render/linux/video_x11_render.h"
+
+#include "webrtc/system_wrappers/include/critical_section_wrapper.h"
+#include "webrtc/system_wrappers/include/trace.h"
+
+namespace webrtc {
+
+VideoX11Render::VideoX11Render(Window window) :
+ _window(window),
+ _critSect(*CriticalSectionWrapper::CreateCriticalSection())
+{
+}
+
+VideoX11Render::~VideoX11Render()
+{
+ delete &_critSect;
+}
+
+int32_t VideoX11Render::Init()
+{
+ CriticalSectionScoped cs(&_critSect);
+
+ _streamIdToX11ChannelMap.clear();
+
+ return 0;
+}
+
+int32_t VideoX11Render::ChangeWindow(Window window)
+{
+ CriticalSectionScoped cs(&_critSect);
+ VideoX11Channel* renderChannel = NULL;
+
+ std::map<int, VideoX11Channel*>::iterator iter =
+ _streamIdToX11ChannelMap.begin();
+
+ while (iter != _streamIdToX11ChannelMap.end())
+ {
+ renderChannel = iter->second;
+ if (renderChannel)
+ {
+ renderChannel->ChangeWindow(window);
+ }
+ iter++;
+ }
+
+ _window = window;
+
+ return 0;
+}
+
+VideoX11Channel* VideoX11Render::CreateX11RenderChannel(
+ int32_t streamId,
+ int32_t zOrder,
+ const float left,
+ const float top,
+ const float right,
+ const float bottom)
+{
+ CriticalSectionScoped cs(&_critSect);
+ VideoX11Channel* renderChannel = NULL;
+
+ std::map<int, VideoX11Channel*>::iterator iter =
+ _streamIdToX11ChannelMap.find(streamId);
+
+ if (iter == _streamIdToX11ChannelMap.end())
+ {
+ renderChannel = new VideoX11Channel(streamId);
+ if (!renderChannel)
+ {
+ WEBRTC_TRACE(
+ kTraceError,
+ kTraceVideoRenderer,
+ -1,
+ "Failed to create VideoX11Channel for streamId : %d",
+ streamId);
+ return NULL;
+ }
+ renderChannel->Init(_window, left, top, right, bottom);
+ _streamIdToX11ChannelMap[streamId] = renderChannel;
+ }
+ else
+ {
+ WEBRTC_TRACE(kTraceInfo, kTraceVideoRenderer, -1,
+ "Render Channel already exists for streamId: %d", streamId);
+ renderChannel = iter->second;
+ }
+
+ return renderChannel;
+}
+
+int32_t VideoX11Render::DeleteX11RenderChannel(int32_t streamId)
+{
+ CriticalSectionScoped cs(&_critSect);
+
+ std::map<int, VideoX11Channel*>::iterator iter =
+ _streamIdToX11ChannelMap.find(streamId);
+ if (iter != _streamIdToX11ChannelMap.end())
+ {
+ VideoX11Channel *renderChannel = iter->second;
+ if (renderChannel)
+ {
+ renderChannel->ReleaseWindow();
+ delete renderChannel;
+ renderChannel = NULL;
+ }
+ _streamIdToX11ChannelMap.erase(iter);
+ }
+
+ WEBRTC_TRACE(kTraceError, kTraceVideoRenderer, -1,
+ "No VideoX11Channel object exists for stream id: %d",
+ streamId);
+ return -1;
+}
+
+int32_t VideoX11Render::GetIncomingStreamProperties(
+ int32_t streamId,
+ uint32_t& zOrder,
+ float& left,
+ float& top,
+ float& right,
+ float& bottom)
+{
+ CriticalSectionScoped cs(&_critSect);
+
+ std::map<int, VideoX11Channel*>::iterator iter =
+ _streamIdToX11ChannelMap.find(streamId);
+ if (iter != _streamIdToX11ChannelMap.end())
+ {
+ VideoX11Channel *renderChannel = iter->second;
+ if (renderChannel)
+ {
+ renderChannel->GetStreamProperties(zOrder, left, top, right, bottom);
+ }
+ }
+
+ WEBRTC_TRACE(kTraceError, kTraceVideoRenderer, -1,
+ "No VideoX11Channel object exists for stream id: %d",
+ streamId);
+ return -1;
+}
+
+} // namespace webrtc
« no previous file with comments | « webrtc/modules/video_render/linux/video_x11_render.h ('k') | webrtc/modules/video_render/mac/cocoa_full_screen_window.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698