给视觉开发新手的保姆级教程:在Ubuntu上从下载源码到成功运行Demo,搞定OpenCV 3环境搭建
给视觉开发新手的保姆级教程在Ubuntu上从下载源码到成功运行Demo搞定OpenCV 3环境搭建第一次在Ubuntu上搭建OpenCV开发环境对很多视觉开发新手来说可能是个令人望而生畏的任务。命令行操作、编译工具链、环境配置……这些术语听起来就让人头疼。但别担心本文将手把手带你完成从源码下载到成功运行Demo的全过程即使你对Linux命令行和CMake完全陌生也能轻松跟上。我们将使用OpenCV 3.4.10版本这是目前3.x系列中最稳定且功能完善的版本之一。整个过程会特别关注那些容易让新手困惑的环节比如CMake-GUI的配置含义、编译错误的解决方法以及如何验证安装是否成功。最终你不仅能拥有一个可用的OpenCV开发环境还会理解整个工作流程背后的原理。1. 环境准备与源码获取在开始之前请确保你的Ubuntu 18.04系统已经更新到最新状态。打开终端快捷键CtrlAltT执行以下命令更新软件包列表和已安装的软件sudo apt update sudo apt upgrade -y接下来我们需要安装一些必要的依赖项。这些工具和库是编译OpenCV的基础sudo apt install -y build-essential cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev对于Python用户还可以安装Python开发环境和相关包sudo apt install -y python3-dev python3-numpy现在让我们获取OpenCV 3.4.10及其contrib模块的源码。有两种方式可以下载使用wget命令行下载推荐wget -O opencv.zip https://codeload.github.com/opencv/opencv/zip/3.4.10 wget -O opencv_contrib.zip https://codeload.github.com/opencv/opencv_contrib/zip/3.4.10浏览器下载 直接在浏览器中打开以下链接下载zip包OpenCV主仓库https://github.com/opencv/opencv/archive/3.4.10.zipContrib模块https://github.com/opencv/opencv_contrib/archive/3.4.10.zip下载完成后解压文件并整理目录结构unzip opencv.zip unzip opencv_contrib.zip mv opencv-3.4.10 opencv mv opencv_contrib-3.4.10 opencv_contrib提示建议将这两个文件夹放在同一目录下比如你的主目录下的opencv_build文件夹中这样后续操作会更方便。2. 使用CMake-GUI配置OpenCVCMake是一个跨平台的构建系统生成器而CMake-GUI则提供了图形化界面让配置过程更加直观。如果你还没有安装CMake-GUI可以通过以下命令安装sudo apt install -y cmake-qt-gui现在创建一个构建目录并启动CMake-GUImkdir opencv/build cd opencv/build cmake-gui ..CMake-GUI界面打开后你会看到以下主要区域Where is the source code自动指向你解压的OpenCV源码目录Where to build the binaries自动指向你创建的build目录点击左下角的Configure按钮在弹出的对话框中选择Unix Makefiles然后点击Finish。CMake会开始检查系统环境和依赖项。配置过程中有几个关键选项需要特别注意BUILD_opencv_world勾选此选项会将所有OpenCV模块编译成一个单独的库文件简化链接过程。CMAKE_BUILD_TYPE设置为RELEASE以获得优化性能。OPENCV_EXTRA_MODULES_PATH指向contrib模块的路径通常是path/to/opencv_contrib/modules。完成这些设置后再次点击Configure按钮。如果没有错误点击Generate按钮生成Makefile。注意如果在配置过程中遇到与Anaconda相关的库冲突问题可以临时注释掉.bashrc文件中Anaconda的路径然后重新启动终端再试。3. 编译与安装OpenCV配置完成后就可以开始编译了。首先确定你的系统有多少个CPU核心以便并行编译加快速度nproc假设输出是8那么可以使用以下命令开始编译make -j8编译过程可能需要较长时间取决于你的硬件配置请耐心等待。如果一切顺利你会看到类似以下的输出[100%] Built target opencv_world [100%] Built target opencv_test_core编译完成后安装OpenCV到系统目录sudo make install为了让系统能够找到新安装的OpenCV库还需要配置动态链接器的路径sudo sh -c echo /usr/local/lib /etc/ld.so.conf.d/opencv.conf sudo ldconfig最后设置pkg-config环境变量这将帮助你在编译自己的程序时自动找到OpenCV的库和头文件echo export PKG_CONFIG_PATH$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig ~/.bashrc source ~/.bashrc4. 验证安装与编写第一个OpenCV程序安装完成后我们可以通过多种方式验证OpenCV是否正常工作。运行官方示例OpenCV自带了许多示例程序我们可以编译并运行其中一个cd ~/opencv/samples/cpp/example_cmake make ./opencv_example如果看到一个窗口显示OpenCV的logo说明安装成功。编写自己的测试程序让我们创建一个简单的程序来读取并显示一张图片。首先创建一个新目录并编写代码mkdir ~/opencv_test cd ~/opencv_test gedit display_image.cpp将以下代码粘贴到编辑器中#include opencv2/opencv.hpp #include iostream using namespace cv; using namespace std; int main(int argc, char** argv) { if (argc ! 2) { cout Usage: display_image Image_Path\n; return -1; } Mat image imread(argv[1], IMREAD_COLOR); if (image.empty()) { cout Could not open or find the image\n; return -1; } namedWindow(Display window, WINDOW_AUTOSIZE); imshow(Display window, image); waitKey(0); return 0; }保存后使用以下命令编译g display_image.cpp -o display_image pkg-config --cflags --libs opencv编译成功后找一张测试图片比如test.jpg运行程序./display_image test.jpg如果能看到图片正常显示恭喜你你已经成功搭建了OpenCV开发环境并运行了第一个程序。5. 常见问题与解决方案在OpenCV环境搭建过程中可能会遇到各种问题。以下是几个常见问题及其解决方法CMake找不到依赖项确保安装了所有必要的开发包使用apt search查找缺失的库有时需要手动指定库路径编译过程中内存不足减少并行编译线程数如使用make -j4代替make -j8增加系统交换空间运行时找不到库确认执行了sudo ldconfig检查/etc/ld.so.conf.d/中的配置文件确保.bashrc中的环境变量设置正确Python绑定问题确保Python开发包已安装检查CMake配置中的Python相关选项可能需要重新编译并指定Python版本提示遇到问题时可以尝试清理build目录并从头开始配置和编译。很多问题都能通过这种方式解决。6. 进阶配置与优化建议现在你已经有了一个可用的OpenCV环境下面是一些进阶建议可以帮助你更好地使用OpenCV进行开发使用CMake管理你的OpenCV项目对于你自己的项目建议使用CMake来管理构建过程。下面是一个简单的CMakeLists.txt示例cmake_minimum_required(VERSION 3.5) project(MyOpenCVProject) find_package(OpenCV REQUIRED) add_executable(display_image display_image.cpp) target_link_libraries(display_image ${OpenCV_LIBS})性能优化选项在编译OpenCV时可以通过以下选项优化性能ENABLE_AVX/ENABLE_AVX2启用CPU的AVX指令集加速WITH_OPENMP启用多线程支持WITH_TBB使用Intel TBB进行并行化文档与帮助OpenCV提供了完善的文档和社区支持官方文档https://docs.opencv.org/3.4.10/示例代码opencv/samples目录社区论坛https://answers.opencv.org/在实际项目中我发现使用pkg-config可以大大简化编译命令。例如当你需要同时链接多个库时pkg-config会自动处理依赖关系。另外建议定期查看OpenCV的更新日志了解新特性和性能改进。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2609964.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!