Android15 Media框架JNI Interface调试

Android15 Media框架有两个使用场景,即媒体播放和录制。媒体播放实现中一个重要的类是MediaPlayerService,录制实现中一个重要的类是MediaRecorder。这里以MediaRecorder这种使用场景为例子说明调试时如何操作。

MediaRecorder使用场景,从技术栈实现来说是通过JNI interface提供接口给APK调用的。

MediaRecorderJNI这层的日志是通过ALOGV/E日志接口输出的,如代码中有:

cpp 复制代码
//frameworks/base/media/jni/android_media_MediaRecorder.cpp
static void android_media_MediaRecorder_setVideoSource(JNIEnv *env, jobject thiz, jint vs)
{
    ALOGV("setVideoSource(%d)", vs);
    if (vs < VIDEO_SOURCE_DEFAULT || vs >= VIDEO_SOURCE_LIST_END) {
        jniThrowException(env, "java/lang/IllegalArgumentException",
            "Invalid video source");
        return;
    }
    sp<MediaRecorder> mr = getMediaRecorder(env, thiz);
    if (mr == NULL) {
        jniThrowException(env, "java/lang/IllegalStateException", NULL);
        return;
    }
    process_media_recorder_call(env, mr->setVideoSource(vs), "java/lang/RuntimeException",
        "setVideoSource failed.");
}

默认上述JNI Interface中的ALOGV打印的内容是不输出的,如果开发调试时想打开需要做两个内容:

  1. 模块中定义LOG_NDEBUG 0
  2. 系统启动后设置调试级别为V

下面以打开MediaRecorder JNI Interface ALOGV级别日志输出为例子,

1. android_media_MediaRecorder.cpp中定义LOG_NDEBUG 0

cpp 复制代码
--- a/media/jni/android_media_MediaRecorder.cpp
+++ b/media/jni/android_media_MediaRecorder.cpp
@@ -22,7 +22,7 @@
 #include <unistd.h>
 #include <vector>

-//#define LOG_NDEBUG 0
+#define LOG_NDEBUG 0
 #define LOG_TAG "MediaRecorderJNI"
 #include <utils/Log.h>

@@ -47,10 +47,13 @@
 #include <android/content/AttributionSourceState.h>
 #include <android_os_Parcel.h>

然后,编译super.img替换到设备.

2.启动系统后,adb设置MediaRecorder logLevel为V级别

adb shell setprop persist.log.tag.MediaRecorderJNI V

该属性设置即生效,且永久生效.

3.过滤日志确认

相关推荐
spencer_tseng2 小时前
anti-screenshot (Android + iOS)
android·ios
程序员Android2 小时前
Android 相机MFNR 拍照trace 分析
android·数码相机
2501_915918412 小时前
基于Mach-O文件的动态库与静态库归属方案及API扫描实践
android·ios·小程序·https·uni-app·iphone·webview
踏雪羽翼2 小时前
android 实现google 订阅支付
android·支付·订阅·google订阅·谷歌支付
2501_915106322 小时前
iOS 证书无法跨电脑使用?签名迁移方法一文讲透
android·ios·小程序·https·uni-app·iphone·webview
Kapaseker2 小时前
Window 内外藏机巧 旧岗新页见真章
android·kotlin
谪星·阿凯2 小时前
从XXE遗留疑问到Upload-Labs全通关:文件上传漏洞的溯源与实战突破
android·计算机网络
星轨初途2 小时前
C++ 类和对象(下):初始化列表、static 成员与编译器优化深度剖析
android·开发语言·c++·经验分享·笔记
恋猫de小郭2 小时前
Flutter 的 build_runner 已经今非昔比,看看 build_runner 2.13 有什么特别?
android·前端·flutter