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

Unified Diff: webrtc/api/android/jni/androidvideotracksource_jni.cc

Issue 2127893002: AndroidVideoTrackSource implementation (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@magjed-init
Patch Set: Changes according to magjed's comments. Created 4 years, 5 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/api/android/jni/androidvideotracksource_jni.cc
diff --git a/webrtc/api/android/jni/androidvideotracksource_jni.cc b/webrtc/api/android/jni/androidvideotracksource_jni.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f69274f8cfef1f6d01cfaa3598b43acccd6375cb
--- /dev/null
+++ b/webrtc/api/android/jni/androidvideotracksource_jni.cc
@@ -0,0 +1,83 @@
+/*
+ * Copyright (c) 2016 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/api/android/jni/classreferenceholder.h"
+#include "webrtc/api/androidvideotracksource.h"
+#include "webrtc/api/videosourceproxy.h"
+
+namespace webrtc_jni {
+
+static webrtc::AndroidVideoTrackSource* AndroidVideoTrackSourceFromJavaProxy(
+ jlong j_proxy) {
+ auto proxy_source = reinterpret_cast<webrtc::VideoTrackSourceProxy*>(j_proxy);
+ return reinterpret_cast<webrtc::AndroidVideoTrackSource*>(
+ proxy_source->internal());
+}
+
+JOW(void,
+ VideoCapturer_00024AndroidVideoTrackSourceObserver_nativeOnByteBufferFrameCaptured)
+(JNIEnv* jni,
+ jclass,
+ jlong j_source,
+ jbyteArray j_frame,
+ jint length,
+ jint width,
+ jint height,
+ jint rotation,
+ jlong timestamp) {
+ auto source = AndroidVideoTrackSourceFromJavaProxy(j_source);
magjed_webrtc 2016/07/19 14:42:28 I prefer 'webrtc::AndroidVideoTrackSource*' over a
sakal 2016/07/20 08:06:28 Done.
+ jbyte* bytes = jni->GetByteArrayElements(j_frame, nullptr);
+ source->OnByteBufferFrameCaptured(bytes, length, width, height, rotation,
+ timestamp);
+ jni->ReleaseByteArrayElements(j_frame, bytes, JNI_ABORT);
+}
+
+JOW(void,
+ VideoCapturer_00024AndroidVideoTrackSourceObserver_nativeOnTextureFrameCaptured)
+(JNIEnv* jni,
+ jclass,
+ jlong j_source,
+ jint j_width,
+ jint j_height,
+ jint j_oes_texture_id,
+ jfloatArray j_transform_matrix,
+ jint j_rotation,
+ jlong j_timestamp) {
+ auto source = AndroidVideoTrackSourceFromJavaProxy(j_source);
+ source->OnTextureFrameCaptured(
+ j_width, j_height, j_rotation, j_timestamp,
+ NativeHandleImpl(jni, j_oes_texture_id, j_transform_matrix));
+}
+
+JOW(void,
+ VideoCapturer_00024AndroidVideoTrackSourceObserver_nativeCapturerStarted)
+(JNIEnv* jni, jclass, jlong j_source, jboolean j_success) {
+ LOG(LS_INFO) << "AndroidVideoTrackSourceObserve_nativeCapturerStarted";
+ auto source = AndroidVideoTrackSourceFromJavaProxy(j_source);
+ source->SetState(webrtc::AndroidVideoTrackSource::SourceState::kLive);
+}
+
+JOW(void,
+ VideoCapturer_00024AndroidVideoTrackSourceObserver_nativeCapturerStopped)
+(JNIEnv* jni, jclass, jlong j_source) {
+ LOG(LS_INFO) << "AndroidVideoTrackSourceObserve_nativeCapturerStopped";
+ auto source = AndroidVideoTrackSourceFromJavaProxy(j_source);
+ source->SetState(webrtc::AndroidVideoTrackSource::SourceState::kEnded);
+}
+
+JOW(void,
+ VideoCapturer_00024AndroidVideoTrackSourceObserver_nativeOnOutputFormatRequest)
+(JNIEnv* jni, jclass, jlong j_source, jint j_width, jint j_height, jint j_fps) {
+ LOG(LS_INFO) << "AndroidVideoTrackSourceObserve_nativeOnOutputFormatRequest";
+ auto source = AndroidVideoTrackSourceFromJavaProxy(j_source);
+ source->OnOutputFormatRequest(j_width, j_height, j_fps);
+}
+
+} // namespace webrtc_jni

Powered by Google App Engine
This is Rietveld 408576698