前言
由于opencv_contrib模块的安装依赖于opencv基础模块,所以看该教程前请先看一遍OpenCV基础模块安装教程
下载
下载 opencv_contrib模块(需要与opencv基础模块版本号4.6.0相同,国内可以在gitcode下载)
配置、编译、安装
打开cmake-gui,选择【OpenCV基础模块】的源码路径(不是contrib模块),再选择新的编译输出路径build/contrib,然后点击configure,等待结束。
 
完成后,【在基础模块的配置上】继续设置下面几个配置:
-  
设置contrib模块路径
xxxx/opencv_contrib-4.6.0/modules(注意要包含modules)

 -  
勾选 nonfree(允许使用带专栏的算法)

 
重新点击configure,然后等待,这又会下载很多东西,不出意外又会报红,因此接下来又需要手动下载了。【下载方式见文章最后-configure报红解决办法】
下载完毕、重命名且放到对应文件夹后,依次执行下面步骤:
- 点击configure,然后generate
 - 关闭cmake-gui,在 
build/contrib目录下打开cmd - 在cmd输入命令 
mingw32-make -j7开始编译(通常需要30分钟以上) 
编译完成即可使用命令 mingw32-make install 进行安装, 然后添加环境变量(注意是把含有.dll的bin目录添加到环境变量)
configure报红解决办法
方法一、手动下载
进入 build/contrib 目录,打开【CMakeDownloadLog.txt】文件,找到所有含有 “cmake_download” 的行, 单独复制到一个文件中,方便后面对照下载。
如:
#cmake_download "D:/xxxx/opencv460/opencv/sources/.cache/xfeatures2d/vgg/7cd47228edec52b6d82f46511af325c5-vgg_generated_80.i" "https://raw.githubusercontent.com/opencv/opencv_3rdparty/fccf7cd6a4b12079f73bbfb21745f9babcd4eb1d/vgg_generated_80.i"
# 第2个链接是文件下载位置,第1个链接则是下载文件并重命名后保存的位置
 
对着每一条下载链接,把所有 raw.githubusercontent.com 都改为 raw.staticdn.net 后再去下载。
下载完成按照第1个链接描述那样,重命名并保存到指定位置。
方法二、写个Python脚本自动下载
【附】:写了个python脚本自动下载缺少的文件,安装了python以及requests库的可以用该脚本进行下载(注意,有个 .dat文件较大,请自行下载)
import requests
import os
def getItemUrls(fpath):
    items = []
    with open(fpath, 'r') as f:
        lines = f.readlines()
        for line in lines:
            if('cmake_download' in line):
                line = line.strip().replace('"', '')
                linfo = line.split()
                fileSavePath = linfo[1]
                url = linfo[2].replace(
                    'raw.githubusercontent.com', 'raw.staticdn.net')
                item = dict(file=fileSavePath, url=url)
                items.append(item)
    return items
def save(savepath, content):
    with open(savepath, 'wb') as f:
        f.write(content)
print('请输入 CMakeDownloadLog.txt 的文件路径',
      r'比如D:\opencv\sources\build\release\CMakeDownloadLog.txt', sep='\n')
fp = input(': ')
items = getItemUrls(fp)
for i in range(len(items)):
    item = items[i]
    if(item["url"][-3:] == "dat"):
        print(f"i={i} --> 文件过大,请自行前往{item['url']}\n并保存为 {item['file']}")
        continue
    os.makedirs('/'.join(item['file'].split('/')[:-1]), exist_ok=True)
    try:
        r = requests.get(item['url'], timeout=20)
    except:
        print(f"i={i} --> 下载失败,请自行前往{item['url']}\n并保存为 {item['file']}")
        continue
    save(item['file'], r.content)
    print(f'i={i} --> 已下载')
    
print("【下载结束】")
                


















