我目前正在开发一个 Play 2.1 项目,其中对网络服务的请求将处理下载用户提供的图像、重新调整大小和重新裁剪它们,以及过滤掉已知的坏照片(例如,我们不希望用户上传公司徽标)。我们正在尝试使用 OpenCV 来处理后端工作,但我似乎无法让 IntelliJ 以适用于 java 项目的方式添加 OpenCV jar。
我已经能够从源代码构建 OpenCV,没有问题。这给我留下了以下文件夹:/home/charles/opencv/release
在这个文件夹中,我有三个感兴趣的文件:
- bin/opencv-246.jar
- 库/cv2.so
- lib/libopencv_java246.so
如果我尝试将 jar 文件作为新的 Java 库添加到 IntelliJ,它似乎会找到所有类/方法,并且我可以使用自动完成功能编写代码。我还可以单击相应的类或方法,它会将我带到正确的文件。
但是,当我尝试运行 Play 项目时,出现此错误:
[info] Loading project definition from /home/charles/Github/ImageProject
[info] Set current project to ImageProject (in build file:/home/charles/Github/ImageProject/)
--- (Running the application from SBT, auto-reloading is enabled) ---
[info] play - Listening for HTTP on /0:0:0:0:0:0:0:0:9000
Server started, use Alt+D to stop
[info] Compiling 1 Java source to /home/charles/Github/ImageProject/target/scala-2.10/classes...
[error] /home/charles/Github/ImageProject/app/controllers/Application.java:7: error: package org.opencv.core does not exist
[error] import org.opencv.core.Core;
[error] ^
我还尝试将 jar 文件的副本直接添加到项目中(因此将 opencv-246.jar 放入 ImageProject/lib),然后从该位置添加 java 库。但这只会给我留下一个不同的错误:
java.lang.UnsatisfiedLinkError: no opencv_java246 in java.library.path
我怀疑部分问题可能与 Java OpenCV 包装器使用的本机库有关(上面的文件 2 或 3)。在 Eclipse 中,当您添加 jar 文件时,您可以显式设置本机库位置,这使得 OpenCV 可以正常工作。我已经阅读了使用它来解决问题的建议:
-Djava.library.path=/home/charles/opencv/release/lib
但这似乎不起作用(尽管也许我将其设置在错误的位置?我尝试在项目的运行配置和 IDE 设置中将其设置为 JVM 参数,但似乎都不是使用或尊重)。
注意:再次澄清一下,这是一个 Play2 项目,而不是 Android 项目。那里似乎有一些特定于 Android 的帮助,在这种情况下不相关。
这感觉应该是一件相当直截了当的事情,但我已经花了几天时间试图找到答案,但仍然一无所获。有任何想法吗?
其他详细信息: 我还尝试在此处遵循 OpenCV 文档的“运行 SBT 示例”:http: //docs.opencv.org/doc/tutorials/introduction/desktop_java/java_dev_intro.html
而且我也收到类似的错误:
charles@charles-VirtualBox:~/JavaSample$ sbt run
[info] Loading project definition from /home/charles/JavaSample/project
[info] Set current project to JavaSample (in build file:/home/charles/JavaSample/)
[info] Compiling 1 Java source to /home/charles/JavaSample/target/scala-2.10/classes...
[info] Running HelloOpenCV
Hello, OpenCV
[error] (run-main) java.lang.UnsatisfiedLinkError: no opencv_java246 in java.library.path
java.lang.UnsatisfiedLinkError: no opencv_java246 in java.library.path
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1856)
at java.lang.Runtime.loadLibrary0(Runtime.java:845)
at java.lang.System.loadLibrary(System.java:1084)
at HelloOpenCV.main(HelloOpenCV.java:47)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
[trace] Stack trace suppressed: run last compile:run for the full output.
java.lang.RuntimeException: Nonzero exit code: 1
at scala.sys.package$.error(package.scala:27)
[trace] Stack trace suppressed: run last compile:run for the full output.
[error] (compile:run) Nonzero exit code: 1
[error] Total time: 2 s, completed Jul 17, 2013 5:11:39 PM