Hide AndroidVideoBuffer class and use factory function
This is a step to ensure that the Java to C++ Video Frame Buffer conversion respects its types. Bug: webrtc:12602 Change-Id: I1b688b1f421f44474e022b433f9075e75744d86f Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/223082 Reviewed-by: Xavier Lepaul <xalep@webrtc.org> Commit-Queue: Xavier Lepaul <xalep@webrtc.org> Cr-Commit-Position: refs/heads/master@{#34487}
This commit is contained in:
committed by
WebRTC LUCI CQ
parent
84b583f577
commit
d33d0e8765
@ -10,11 +10,11 @@
|
|||||||
|
|
||||||
#include "sdk/android/src/jni/android_video_track_source.h"
|
#include "sdk/android/src/jni/android_video_track_source.h"
|
||||||
|
|
||||||
#include "sdk/android/generated_video_jni/NativeAndroidVideoTrackSource_jni.h"
|
|
||||||
|
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
#include "rtc_base/logging.h"
|
#include "rtc_base/logging.h"
|
||||||
|
#include "sdk/android/generated_video_jni/NativeAndroidVideoTrackSource_jni.h"
|
||||||
|
#include "sdk/android/src/jni/video_frame.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
@ -132,7 +132,7 @@ void AndroidVideoTrackSource::OnFrameCaptured(
|
|||||||
jlong j_timestamp_ns,
|
jlong j_timestamp_ns,
|
||||||
const JavaRef<jobject>& j_video_frame_buffer) {
|
const JavaRef<jobject>& j_video_frame_buffer) {
|
||||||
rtc::scoped_refptr<VideoFrameBuffer> buffer =
|
rtc::scoped_refptr<VideoFrameBuffer> buffer =
|
||||||
AndroidVideoBuffer::Create(env, j_video_frame_buffer);
|
JavaToNativeFrameBuffer(env, j_video_frame_buffer);
|
||||||
const VideoRotation rotation = jintToVideoRotation(j_rotation);
|
const VideoRotation rotation = jintToVideoRotation(j_rotation);
|
||||||
|
|
||||||
// AdaptedVideoTrackSource handles applying rotation for I420 frames.
|
// AdaptedVideoTrackSource handles applying rotation for I420 frames.
|
||||||
|
|||||||
@ -18,7 +18,7 @@
|
|||||||
#include "rtc_base/checks.h"
|
#include "rtc_base/checks.h"
|
||||||
#include "rtc_base/thread.h"
|
#include "rtc_base/thread.h"
|
||||||
#include "rtc_base/timestamp_aligner.h"
|
#include "rtc_base/timestamp_aligner.h"
|
||||||
#include "sdk/android/src/jni/video_frame.h"
|
#include "sdk/android/src/jni/jni_helpers.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
|
|||||||
@ -27,6 +27,7 @@
|
|||||||
#include "sdk/android/native_api/jni/java_types.h"
|
#include "sdk/android/native_api/jni/java_types.h"
|
||||||
#include "sdk/android/src/jni/encoded_image.h"
|
#include "sdk/android/src/jni/encoded_image.h"
|
||||||
#include "sdk/android/src/jni/video_codec_status.h"
|
#include "sdk/android/src/jni/video_codec_status.h"
|
||||||
|
#include "sdk/android/src/jni/video_frame.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
|
|||||||
@ -25,7 +25,6 @@
|
|||||||
#include "modules/video_coding/svc/scalable_video_controller_no_layering.h"
|
#include "modules/video_coding/svc/scalable_video_controller_no_layering.h"
|
||||||
#include "rtc_base/synchronization/mutex.h"
|
#include "rtc_base/synchronization/mutex.h"
|
||||||
#include "sdk/android/src/jni/jni_helpers.h"
|
#include "sdk/android/src/jni/jni_helpers.h"
|
||||||
#include "sdk/android/src/jni/video_frame.h"
|
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
|
|||||||
@ -10,12 +10,8 @@
|
|||||||
|
|
||||||
#include "sdk/android/src/jni/video_frame.h"
|
#include "sdk/android/src/jni/video_frame.h"
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
#include "api/scoped_refptr.h"
|
#include "api/scoped_refptr.h"
|
||||||
#include "common_video/include/video_frame_buffer.h"
|
#include "common_video/include/video_frame_buffer.h"
|
||||||
#include "rtc_base/checks.h"
|
|
||||||
#include "rtc_base/logging.h"
|
|
||||||
#include "rtc_base/ref_counted_object.h"
|
#include "rtc_base/ref_counted_object.h"
|
||||||
#include "rtc_base/time_utils.h"
|
#include "rtc_base/time_utils.h"
|
||||||
#include "sdk/android/generated_video_jni/VideoFrame_jni.h"
|
#include "sdk/android/generated_video_jni/VideoFrame_jni.h"
|
||||||
@ -27,6 +23,51 @@ namespace jni {
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
class AndroidVideoBuffer : public VideoFrameBuffer {
|
||||||
|
public:
|
||||||
|
// Creates a native VideoFrameBuffer from a Java VideoFrame.Buffer.
|
||||||
|
static rtc::scoped_refptr<AndroidVideoBuffer> Create(
|
||||||
|
JNIEnv* jni,
|
||||||
|
const JavaRef<jobject>& j_video_frame_buffer);
|
||||||
|
|
||||||
|
// Similar to the Create() above, but adopts and takes ownership of the Java
|
||||||
|
// VideoFrame.Buffer. I.e. retain() will not be called, but release() will be
|
||||||
|
// called when the returned AndroidVideoBuffer is destroyed.
|
||||||
|
static rtc::scoped_refptr<AndroidVideoBuffer> Adopt(
|
||||||
|
JNIEnv* jni,
|
||||||
|
const JavaRef<jobject>& j_video_frame_buffer);
|
||||||
|
|
||||||
|
~AndroidVideoBuffer() override;
|
||||||
|
|
||||||
|
const ScopedJavaGlobalRef<jobject>& video_frame_buffer() const;
|
||||||
|
|
||||||
|
// Crops a region defined by |crop_x|, |crop_y|, |crop_width| and
|
||||||
|
// |crop_height|. Scales it to size |scale_width| x |scale_height|.
|
||||||
|
rtc::scoped_refptr<VideoFrameBuffer> CropAndScale(int crop_x,
|
||||||
|
int crop_y,
|
||||||
|
int crop_width,
|
||||||
|
int crop_height,
|
||||||
|
int scale_width,
|
||||||
|
int scale_height) override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
// Should not be called directly. Adopts the Java VideoFrame.Buffer. Use
|
||||||
|
// Create() or Adopt() instead for clarity.
|
||||||
|
AndroidVideoBuffer(JNIEnv* jni, const JavaRef<jobject>& j_video_frame_buffer);
|
||||||
|
|
||||||
|
private:
|
||||||
|
Type type() const override;
|
||||||
|
int width() const override;
|
||||||
|
int height() const override;
|
||||||
|
|
||||||
|
rtc::scoped_refptr<I420BufferInterface> ToI420() override;
|
||||||
|
|
||||||
|
const int width_;
|
||||||
|
const int height_;
|
||||||
|
// Holds a VideoFrame.Buffer.
|
||||||
|
const ScopedJavaGlobalRef<jobject> j_video_frame_buffer_;
|
||||||
|
};
|
||||||
|
|
||||||
class AndroidVideoI420Buffer : public I420BufferInterface {
|
class AndroidVideoI420Buffer : public I420BufferInterface {
|
||||||
public:
|
public:
|
||||||
// Adopts and takes ownership of the Java VideoFrame.Buffer. I.e. retain()
|
// Adopts and takes ownership of the Java VideoFrame.Buffer. I.e. retain()
|
||||||
@ -189,6 +230,12 @@ rtc::scoped_refptr<I420BufferInterface> AndroidVideoBuffer::ToI420() {
|
|||||||
return AndroidVideoI420Buffer::Adopt(jni, width_, height_, j_i420_buffer);
|
return AndroidVideoI420Buffer::Adopt(jni, width_, height_, j_i420_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rtc::scoped_refptr<VideoFrameBuffer> JavaToNativeFrameBuffer(
|
||||||
|
JNIEnv* jni,
|
||||||
|
const JavaRef<jobject>& j_video_frame_buffer) {
|
||||||
|
return AndroidVideoBuffer::Create(jni, j_video_frame_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
VideoFrame JavaToNativeFrame(JNIEnv* jni,
|
VideoFrame JavaToNativeFrame(JNIEnv* jni,
|
||||||
const JavaRef<jobject>& j_video_frame,
|
const JavaRef<jobject>& j_video_frame,
|
||||||
uint32_t timestamp_rtp) {
|
uint32_t timestamp_rtp) {
|
||||||
|
|||||||
@ -15,57 +15,15 @@
|
|||||||
|
|
||||||
#include "api/video/video_frame.h"
|
#include "api/video/video_frame.h"
|
||||||
#include "api/video/video_frame_buffer.h"
|
#include "api/video/video_frame_buffer.h"
|
||||||
#include "api/video/video_rotation.h"
|
|
||||||
#include "sdk/android/src/jni/jni_helpers.h"
|
#include "sdk/android/src/jni/jni_helpers.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
|
|
||||||
class AndroidVideoBuffer : public VideoFrameBuffer {
|
rtc::scoped_refptr<VideoFrameBuffer> JavaToNativeFrameBuffer(
|
||||||
public:
|
|
||||||
// Creates a native VideoFrameBuffer from a Java VideoFrame.Buffer.
|
|
||||||
static rtc::scoped_refptr<AndroidVideoBuffer> Create(
|
|
||||||
JNIEnv* jni,
|
JNIEnv* jni,
|
||||||
const JavaRef<jobject>& j_video_frame_buffer);
|
const JavaRef<jobject>& j_video_frame_buffer);
|
||||||
|
|
||||||
// Similar to the Create() above, but adopts and takes ownership of the Java
|
|
||||||
// VideoFrame.Buffer. I.e. retain() will not be called, but release() will be
|
|
||||||
// called when the returned AndroidVideoBuffer is destroyed.
|
|
||||||
static rtc::scoped_refptr<AndroidVideoBuffer> Adopt(
|
|
||||||
JNIEnv* jni,
|
|
||||||
const JavaRef<jobject>& j_video_frame_buffer);
|
|
||||||
|
|
||||||
~AndroidVideoBuffer() override;
|
|
||||||
|
|
||||||
const ScopedJavaGlobalRef<jobject>& video_frame_buffer() const;
|
|
||||||
|
|
||||||
// Crops a region defined by |crop_x|, |crop_y|, |crop_width| and
|
|
||||||
// |crop_height|. Scales it to size |scale_width| x |scale_height|.
|
|
||||||
rtc::scoped_refptr<VideoFrameBuffer> CropAndScale(int crop_x,
|
|
||||||
int crop_y,
|
|
||||||
int crop_width,
|
|
||||||
int crop_height,
|
|
||||||
int scale_width,
|
|
||||||
int scale_height) override;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// Should not be called directly. Adopts the Java VideoFrame.Buffer. Use
|
|
||||||
// Create() or Adopt() instead for clarity.
|
|
||||||
AndroidVideoBuffer(JNIEnv* jni, const JavaRef<jobject>& j_video_frame_buffer);
|
|
||||||
|
|
||||||
private:
|
|
||||||
Type type() const override;
|
|
||||||
int width() const override;
|
|
||||||
int height() const override;
|
|
||||||
|
|
||||||
rtc::scoped_refptr<I420BufferInterface> ToI420() override;
|
|
||||||
|
|
||||||
const int width_;
|
|
||||||
const int height_;
|
|
||||||
// Holds a VideoFrame.Buffer.
|
|
||||||
const ScopedJavaGlobalRef<jobject> j_video_frame_buffer_;
|
|
||||||
};
|
|
||||||
|
|
||||||
VideoFrame JavaToNativeFrame(JNIEnv* jni,
|
VideoFrame JavaToNativeFrame(JNIEnv* jni,
|
||||||
const JavaRef<jobject>& j_video_frame,
|
const JavaRef<jobject>& j_video_frame,
|
||||||
uint32_t timestamp_rtp);
|
uint32_t timestamp_rtp);
|
||||||
|
|||||||
Reference in New Issue
Block a user