FFmpeg 中的 log 输出到 Android 的 logcat 中

本文主要讲述将 FFmpeg 中的 log 打印到 Android 的 logcat 中,其他底层库同样可以参考

FFmpeg 的 log 重定向到 Android 的 logcat

  1. FFmpeg 打印日志的函数

    首先,来了解下 FFmpeg 自己的日志系统 -- 使用 av_log() 函数打印日志,其声明位于:<libutil/log.h>

    /**
     * avcl: 该 log 所属的结构体
     * level: log级别
     * fmt: 打印内容
     */
    void av_log(void *avcl, int level, const char *fmt, ...) av_printf_format(3, 4);
    

    使用示例:

    av_log(NULL, AV_LOG_DEBUG, "hello");
    av_log(NULL, AV_LOG_ERROR, "eror");
    
  2. Android 中打印 FFmpeg 的日志

    FFmpeg 默认使用的事 printf 来打印日志,而 Android 系统有着自己的日志系统,所以,需要将 FFmpeg 的日志重定向使用 Android 的日志系统

    • 引入 Android 的 log 方法

      #include <android/log.h>
      
      #define LOGI(...) __android_log_print(ANDROID_LOG_INFO,  LOG_TAG, __VA_ARGS__)
      #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
      #define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
      
    • 实现使用 Android log 函数的方法

      static void log_callback_test2(void *ptr, int level, const char *fmt, va_list vl) 
      {
          va_list vl2;
          char *line = malloc(128 * sizeof(char));
          static int print_prefix = 1;
          va_copy(vl2, vl);
          av_log_format_line(ptr, level, fmt, vl2, line, 128, &print_prefix);
          va_end(vl2);
          line[127] = '\0';
          LOGE("%s", line);
          free(line);
      }
      
    • 注册 FFmpeg 的 LOG callback fuunction

      av_log_set_callback(log_callback_test2);
      

    在 FFmpeg 代码初始调用的地方,调用 av_log_set_callback,FFmpeg 中使用 av_log() 打印的日志就输出到 logcat 中了

FFmpeg 中使用直接 __android_log_print 打印log

  1. 底层库使用 NDK 编译

    • 在要打印的源文件引入 Android 的 log 头文件,以及宏定义

      #include <android/log.h>
      
      #define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE,"yourTAGStr", __VA_ARGS__)
      #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,"yourTAGStr", __VA_ARGS__)
      #define LOGI(...) __android_log_print(ANDROID_LOG_INFO, "yourTAGStr", __VA_ARGS__)
      #define LOGW(...) __android_log_print(ANDROID_LOG_WARN, "yourTAGStr", __VA_ARGS__)
      #define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,"yourTAGStr", __VA_ARGS__)
      
    • 底层库的 Android.mk 中加入 LOCAL_LDLIBS+= -llog

    • 在需要打印的地方加入

      LOGD("log test");
      
  2. Android 程序中使用的底层库中链接第三方库,打印第三方库中的 log

    如果底层库需要链接第三方库,需要在第三方库源码中加log,先看下第三方库是使用 NDK 编译还是 ./configure、make 编译。如果使用 NDK 编译,可以直接使用上面那种方式加入log。

    我们的 veffwrapper.so 使用 NDK 编译,需要加入 FFmpeg 库,FFmpeg 使用 ./configure、make 方式编译。与上面一种方式原理相同,都是利用 Android 提供的 log 机制,即需要将 Android 的 liblog.so 链接到底层库中。

    • 在 build_ffmpe.sh 同级目录下创建 jni_log文件夹,将 ndk-dundle/platforms/android-24/arch-arm/usr/ 下的 log.h 和 liblog.so 文件放入新建的文件夹中
    • 将 liblog 链接到 FFmpeg 中
    // 在 ./configure 后加入 liblog.so 的路径,并指定链接该库
    ./configure $FFMPEG_FLAGS --extra-cflags="xxx -Ijni_log/include" --extra-ldflags="-Lxxx -Ljni_log/lib -llog" 
    
    • 在 FFmpeg 源码中引入 Android 关于 log 的头文件,以及宏定义(可以新建文件或在需要打印log的源文件中添加)

      #include "../jni_log/include/log.h"
      
      #define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE, "yourTAGStr", __VA_ARGS__)
      #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG  , "yourTAGStr", __VA_ARGS__)
      #define LOGI(...) __android_log_print(ANDROID_LOG_INFO   , "yourTAGStr", __VA_ARGS__)
      #define LOGW(...) __android_log_print(ANDROID_LOG_WARN   , "yourTAGStr", __VA_ARGS__)
      #define LOGE(...) __android_log_print(ANDROID_LOG_ERROR  , "yourTAGStr", __VA_ARGS__)
      

      在需要打印的地方加入:

      LOGE("ffmpeg log test");

    • veffwrapper 库生成加载时链接到 /system/lib/liblog.so 的模块

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • mean to add the formatted="false" attribute?.[ 46% 47325/...
    ProZoom阅读 2,695评论 0 3
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,710评论 2 59
  • 下面分别做介绍: cmake_minimum_required(VERSION 3.4.1)用来设置在编译本地库时...
    123yuan123阅读 1,202评论 1 1
  • 知识要点: 1、对求助者形成初步印象、对一般心理健康水平进行分析时的注意事项。 2、判断正常与异常的心理活动的三项...
    PYC1618阅读 103评论 0 0