java - 重命名包破坏了 JNI 函数 Android Studio

标签 java android-studio opencv java-native-interface

我正在使用 openCV,它工作正常,直到我更改了包名称。我搜索了 google 和 stackoverflow,但没有任何结果。 已经一天了,我很沮丧。 这是原木猫。 任何帮助将不胜感激。

12-18 08:37:24.328 12081-12144/in.indilabz.in.cbxprint E/art: No implementation found for void in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.nativeApplyFilter(int, int, long, long) (tried Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter and Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter__IIJJ)
12-18 08:37:24.333 12081-12144/in.indilabz.in.cbxprint E/UncaughtException: java.lang.RuntimeException: An error occured while executing doInBackground()
                                    at android.os.AsyncTask$3.done(AsyncTask.java:304)
                                    at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
                                    at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
                                    at java.util.concurrent.FutureTask.run(FutureTask.java:242)
                                    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
                                    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                    at java.lang.Thread.run(Thread.java:818)
                                Caused by: java.lang.UnsatisfiedLinkError: No implementation found for void in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.nativeApplyFilter(int, int, long, long) (tried Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter and Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter__IIJJ)
                                    at in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.nativeApplyFilter(Native Method)
                                    at in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.processImage(PhotoProcessing.java:26)
                                    at in.indilabz.in.cbxprint.editor.fragment.RecyclerMenuFragment$GetFilterThumbsTask.doInBackground(RecyclerMenuFragment.java:144)
                                    at in.indilabz.in.cbxprint.editor.fragment.RecyclerMenuFragment$GetFilterThumbsTask.doInBackground(RecyclerMenuFragment.java:134)
                                    at android.os.AsyncTask$2.call(AsyncTask.java:292)
                                    at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
                                    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                                    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                                    at java.lang.Thread.run(Thread.java:818) 
12-18 08:37:24.459 696-714/? E/SensorService: activeConnections...
12-18 08:37:24.459 696-714/? E/SensorService: activeConnections...
12-18 08:37:24.625 12081-12144/in.indilabz.in.cbxprint E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #3
                                Process: in.indilabz.in.cbxprint, PID: 12081
                                java.lang.RuntimeException: An error occured while executing doInBackground()
                                    at android.os.AsyncTask$3.done(AsyncTask.java:304)
                                    at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
                                    at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
                                    at java.util.concurrent.FutureTask.run(FutureTask.java:242)
                                    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
                                    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                    at java.lang.Thread.run(Thread.java:818)
                                Caused by: java.lang.UnsatisfiedLinkError: No implementation found for void in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.nativeApplyFilter(int, int, long, long) (tried Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter and Java_in_indilabz_in_cbxprint_editor_filter_PhotoProcessing_nativeApplyFilter__IIJJ)
                                    at in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.nativeApplyFilter(Native Method)
                                    at in.indilabz.in.cbxprint.editor.filter.PhotoProcessing.processImage(PhotoProcessing.java:26)
                                    at in.indilabz.in.cbxprint.editor.fragment.RecyclerMenuFragment$GetFilterThumbsTask.doInBackground(RecyclerMenuFragment.java:144)
                                    at in.indilabz.in.cbxprint.editor.fragment.RecyclerMenuFragment$GetFilterThumbsTask.doInBackground(RecyclerMenuFragment.java:134)
                                    at android.os.AsyncTask$2.call(AsyncTask.java:292)
                                    at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
                                    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                                    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                                    at java.lang.Thread.run(Thread.java:818) 

最佳答案

根据@lockcmpxchg8b 的评论,我去寻找关于 javah 的引用资料并找到了 this article我在那里找到了答案。

要解决这个问题,您需要检查 make 文件(可能位于 app/src/main/jni/Android.mk 之类的地方)。它应该包含 LOCAL_MODULELOCAL_CFLAGSLOCAL_SRC_FILES 等值。

LOCAL_SRC_FILES 会列出一些 .cpp 文件。在名称类似于 Java_old_package_name_editor_filter_PhotoProcessing_nativeApplyFilter 的文件之一中找到函数,并将 old_package_name 更改为您的新包。

关于java - 重命名包破坏了 JNI 函数 Android Studio,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47861660/

相关文章:

android - 添加原始资源文件夹时,'"aapt.exe'“以非零退出值完成”崩溃

android - Robolectric NullPointerException 与 BugSense

opencv - 在这种情况下如何分割连接的字符?

linux - 错误 : Could not find or load main class

java - lambda 表达式中使用的变量应该是最终变量或有效最终变量

JavaCV透视校正

android-studio - Android Studio更新(1.5至2.2.3)中断了项目

opencv - 从对象/掩码 opencv 获取矩形 ROI

java - 如何使用 opencv 和 eclipse 将图片转换为 mat

java - TimeZone.getTimeZone().getRawOffset() 取决于什么?