使用Vitamio的时候发现在Android的高版本会提示加载不到so
2019-02-27 15:52:27.050 14535-14535/? E/zygote: No implementation found for boolean io.vov.vitamio.MediaPlayer.loadFFmpeg_native(java.lang.String) (tried Java_io_vov_vitamio_MediaPlayer_loadFFmpeg_1native and Java_io_vov_vitamio_MediaPlayer_loadFFmpeg_1native__Ljava_lang_String_2)
2019-02-27 15:52:27.056 14535-14535/? E/Vitamio[Player]: Error loading libs
java.lang.UnsatisfiedLinkError: No implementation found for boolean io.vov.vitamio.MediaPlayer.loadFFmpeg_native(java.lang.String) (tried Java_io_vov_vitamio_MediaPlayer_loadFFmpeg_1native and Java_io_vov_vitamio_MediaPlayer_loadFFmpeg_1native__Ljava_lang_String_2)
at io.vov.vitamio.MediaPlayer.loadFFmpeg_native(Native Method)
at io.vov.vitamio.MediaPlayer.loadFFmpeg_native_lib(MediaPlayer.java:255)
at io.vov.vitamio.MediaPlayer.<clinit>(MediaPlayer.java:328)
at io.vov.vitamio.widget.VideoView.openVideo(VideoView.java:427)
at io.vov.vitamio.widget.VideoView.access$1400(VideoView.java:70)
at io.vov.vitamio.widget.VideoView$3.surfaceCreated(VideoView.java:158)
at android.view.SurfaceView.updateSurface(SurfaceView.java:669)
at android.view.SurfaceView$2.onPreDraw(SurfaceView.java:145)
at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:977)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2369)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1411)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6784)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:911)
at android.view.Choreographer.doCallbacks(Choreographer.java:723)
at android.view.Choreographer.doFrame(Choreographer.java:658)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:897)
at android.os.Handler.handleCallback(Handler.java:790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6719)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:449)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
大家都知道,在新版本中,已经将LibsChecker.checkVitamioLibs(this)修改为Vitamio.isInitialized(this),那他真正的load代码会发生什么变化呢?实际上在vitamio中有一个MideaPlay有一个静态方法load_lib就是加载so的,我们才错误就是没有加载到正确的so导致的,那这里就需要修改了:
private static boolean load_lib(String path, String name) {
//if (path == "") {
//System.load(name);
//} else {
//System.load(path + name);
//}
String libraries[] = {name,Vitamio.getLibraryPath() + name};
boolean success = false;
for(String library : libraries) {
try{
System.load(library);
success = true;
break;
} catch(UnsatisfiedLinkError e) {
Log.i(Log.TAG,e.toString());
}
}
return success;
}
至此,就可以播放视频了