使用 openCVLibrary320 for Android,我在项目中出现错误:
W/dalvikvm: No implementation found for native Lorg/opencv/imgproc/Imgproc;.Canny_2:(JJDDIZ)V
W/dalvikvm: threadid=12: thread exiting with uncaught exception (group=0x9cd7fb20)
E/AndroidRuntime: FATAL EXCEPTION: Thread-68
Process: hantke.niklas.mnotes, PID: 2144
java.lang.UnsatisfiedLinkError: Native method not found: org.opencv.imgproc.Imgproc.Canny_2:(JJDDIZ)V
at org.opencv.imgproc.Imgproc.Canny_2(Native Method)
at org.opencv.imgproc.Imgproc.Canny(Imgproc.java:1029)
at hantke.niklas.mnotes.MainActivity.detectStaffLines(MainActivity.java:121)
at hantke.niklas.mnotes.MainActivity.onCameraFrame(MainActivity.java:173)
at org.opencv.android.CameraBridgeViewBase.deliverAndDrawFrame(CameraBridgeViewBase.java:392)
at org.opencv.android.JavaCameraView$CameraWorker.run(JavaCameraView.java:352)
at java.lang.Thread.run(Thread.java:841)
这是我第一次称该方法为canny,但在此之前,我调用cvtColor和equalizeHist没有任何错误。
在API 25模拟器上运行良好,但在API 19 emu和Android 5.1的Android手机上都不起作用。与 SDK 3.20 捆绑在一起的最新版本的 openCV 管理器安装在每个模拟器和手机上
我发现了我的错误。
问题出在 openCV 的初始化上:我不得不写:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_3_2_0, this, mLoaderCallback);
}
而不是
OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_2, this, mLoaderCallback);
因为我使用的是 3.2.0 版。奇怪的是,它适用于Android 6模拟器。