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

Unified Diff: content/renderer/media/rtc_video_decoder_bridge_tv.h

Issue 14247018: Implement WebRTC in Chrome for TV (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed Dongwon and Yuncheol's comments Created 7 years, 7 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: content/renderer/media/rtc_video_decoder_bridge_tv.h
diff --git a/content/renderer/media/rtc_video_decoder_bridge_tv.h b/content/renderer/media/rtc_video_decoder_bridge_tv.h
new file mode 100644
index 0000000000000000000000000000000000000000..09d0d7ff76d09aa4c209782cb449b3fc05617db0
--- /dev/null
+++ b/content/renderer/media/rtc_video_decoder_bridge_tv.h
@@ -0,0 +1,59 @@
+// Copyright (c) 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CONTENT_RENDERER_MEDIA_RTC_VIDEO_DECODER_BRIDGE_TV_H_
+#define CONTENT_RENDERER_MEDIA_RTC_VIDEO_DECODER_BRIDGE_TV_H_
+
+#include "base/basictypes.h"
+#include "base/compiler_specific.h"
+#include "content/common/content_export.h"
+#include "third_party/webrtc/modules/video_coding/codecs/interface/video_codec_interface.h"
+#include "ui/gfx/size.h"
+
+namespace content {
+
+class MediaStreamDependencyFactory;
+class RTCVideoDecoderFactoryTv;
+
+// An object shared between WebMediaPlayerAndroid and WebRTC Video Engine.
+// Note that this class provides the first remote stream.
+class CONTENT_EXPORT RTCVideoDecoderBridgeTv
+ : NON_EXPORTED_BASE(public webrtc::VideoDecoder) {
+ public:
+ RTCVideoDecoderBridgeTv(RTCVideoDecoderFactoryTv* factory);
+ virtual ~RTCVideoDecoderBridgeTv();
+
+ // webrtc::VideoDecoder implementation.
+ virtual int32_t InitDecode(const webrtc::VideoCodec* codecSettings,
acolwell GONE FROM CHROMIUM 2013/05/14 18:17:47 nit: change to unix_hacker_style here and below. s
wonsik 2013/05/20 14:02:24 Done.
+ int32_t numberOfCores) OVERRIDE;
+ virtual int32_t Decode(
+ const webrtc::EncodedImage& inputImage,
+ bool missingFrames,
+ const webrtc::RTPFragmentationHeader* fragmentation,
+ const webrtc::CodecSpecificInfo* codecSpecificInfo = NULL,
+ int64_t renderTimeMs = -1) OVERRIDE;
+ virtual int32_t RegisterDecodeCompleteCallback(
+ webrtc::DecodedImageCallback* callback) OVERRIDE;
+ virtual int32_t Release() OVERRIDE;
+ virtual int32_t Reset() OVERRIDE;
+
+ private:
+ static void RunDecodeCompleteCallback(webrtc::DecodedImageCallback* callback,
+ int64_t timestamp);
+
+ // The factory outlives this object, so weak pointer is fine.
+ RTCVideoDecoderFactoryTv* factory_;
+
+ gfx::Size size_;
+ bool is_initialized_;
+ bool first_frame_;
+ webrtc::DecodedImageCallback* decode_complete_callback_;
+ int64_t timestamp_offset_millis_;
+
+ DISALLOW_COPY_AND_ASSIGN(RTCVideoDecoderBridgeTv);
+};
+
+} // namespace content
+
+#endif // CONTENT_RENDERER_MEDIA_RTC_VIDEO_DECODER_BRIDGE_TV_H_

Powered by Google App Engine
This is Rietveld 408576698