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.过滤日志确认

相关推荐
2301_771717211 天前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
dvjr cloi1 天前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
随遇丿而安1 天前
第2周:`EditText` 不只是输入框,它是 Android 输入体验的第一道门
android
我命由我123451 天前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
一起搞IT吧1 天前
Android性能系列专题理论之十:systrace/perfetto相关指标知识点细节含义总结
android·嵌入式硬件·智能手机·性能优化
小书房1 天前
Kotlin的by
android·开发语言·kotlin·委托·by
jinanwuhuaguo1 天前
(第二十八篇)OpenClaw成本与感知的奇点——从“Token封建制”到“全民养虾”的本体论地基
android·人工智能·kotlin·拓扑学·openclaw
xxjj998a1 天前
Laravel4.x核心特性全解析
android·mysql·laravel
JoshRen1 天前
2026教程:在Android Termux中集成Gemini 3镜像站实现移动端文档自动处理与摘要生成(附国内免费方案)
android
诸神黄昏EX1 天前
Android Google KEY
android