关于使用Android开发Vitamio框架Android6.0会Crash

缘由

前段时间领导让我研究了一个公司的老项目,很简单,就是控制监控设备,进行远程查看监控的项目,我拿到手的时候,这个项目简直不能直视,完全无架构可言,没办法,再乱也要上啊,因为要更改上面的一个功能,项目本身有一个百度地图,将其更换为蜂鸟室内地图(其实我完全没有听说过),哈哈,用了一天时间算是集成好了,OK,交工!

问题

就在我高兴的喊着结束的时候,问题来了,项目无法播放视频,我调试了好几个小时,也是只要播放视频,就会crash,没办法,一步一步排查,经过初步排查,发现MediaPalyer无法初始化,直接报错,来来来,看看log:

11-03 09:51:24.806 4013-4013/com.example.nview E/JPush: [AndroidUtil] The permission should be defined - com.example.nview.permission.JPUSH_MESSAGE
11-03 09:51:27.869 4013-4013/com.example.nview E/linker: /data/data/com.example.nview/libs/libffmpeg.so: has text relocations
11-03 09:51:27.869 4013-4013/com.example.nview E/Vitamio[4.2.1][Player]: LOAD FFMPEG ERROR: dlopen failed: /data/data/com.example.nview/libs/libffmpeg.so: has text relocations
11-03 09:51:27.870 4013-4013/com.example.nview E/Vitamio[4.2.1][Player]: FIND_NAME_SYM vvo, render_yuv
11-03 09:51:27.965 4013-4085/com.example.nview E/CrashReport-Native: Failed to get java thread with thread name: main
11-03 09:51:28.021 4013-4013/com.example.nview A/libc: Fatal signal 11 (SIGSEGV), code 1, fault addr 0x0 in tid 4013 (m.example.nview)

                                                       [ 11-03 09:51:28.022   462:  462 W/         ]
                                                       debuggerd: handling request: pid=4013 uid=10243 gid=10243 tid=4013

(忘记截图了,将就看看吧)看到log提示中有libffmpeg.so的字眼,视频加载不了?那我就加一个so文件,下载,加上去,运行,报错,无奈,重新另找原因;后来发现是调用jni的问题,但毕竟是第三方的,我们也不好去更改底层代码,所以就慢慢找别的原因。
就在这个时候,我发现一个问题,我在Android6.0以下的设备运行就可以正常播放视频啊,为什么就在6.0以上就不行呢?(包括6.0),然后我就去githhub上面看了一下:
关于使用Android开发Vitamio框架Android6.0会Crash_第1张图片
项目貌似很久没维护了,没关系,虽然也没找到原因,但是我们不能气馁。

解决方法

最后,我抱着试一试的态度,修改了android的运行版本:

minSdkVersion 14
targetSdkVersion 22

我们把targetSdkVersion的值改为22,没错,<=23就可以,问题解决了,由于这个项目在GitHub上,有很久没有更新了,所以大家在集成Vitamio的时候,出现类似错误,就把版本改低一点,就能解决问题了。

这篇博客不是讲解学习类博客,只是给大家总结一下Vitamio在使用过程中遇到的问题,欢迎大家留言讨论

你可能感兴趣的:(Bug修复)