opencv基础

2023-07-29,

Python 和 OpenCV 的结合是计算机视觉领域中应用最为广泛的一种方式,它们的结合使得开发者可以快速、高效地完成各种视觉任务。本文将介绍 Python 和 OpenCV 的基础使用,包括安装、图像读取、基本操作、特征提取等内容。

安装

在使用 Python 和 OpenCV 前,我们需要先安装它们。推荐使用 Anaconda 或者 Miniconda 来管理 Python 环境,这样可以有效地避免 Python 包冲突的问题。安装命令如下:

conda create -n opencv python=3.8
conda activate opencv
conda install -c conda-forge opencv

图像读取和显示

读取和显示图像是计算机视觉处理的基础,OpenCV 提供了方便的 API 来完成这一任务。

import cv2

# 读取图像
img = cv2.imread('test.jpg') # 显示图像
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

上述代码中,cv2.imread 用于读取图像,cv2.imshow 用于显示图像。需要注意的是,cv2.imshow 后面需要加上 cv2.waitKey(0),这是因为 OpenCV 的 GUI 窗口需要等待用户的输入才能关闭。如果不加这行代码,GUI 窗口会一闪而过。

图像操作

在 OpenCV 中,我们可以对图像进行各种各样的操作,比如缩放、旋转、裁剪等。下面是一些常用的图像操作:

import cv2

# 缩放
img = cv2.imread('test.jpg')
resized_img = cv2.resize(img, (640, 480)) # 旋转
img = cv2.imread('test.jpg')
(h, w) = img.shape[:2]
center = (w // 2, h // 2)
M = cv2.getRotationMatrix2D(center, 45, 1.0)
rotated_img = cv2.warpAffine(img, M, (w, h)) # 裁剪
img = cv2.imread('test.jpg')
cropped_img = img[100:200, 100:200]

上述代码中,cv2.resize 用于缩放图像,cv2.getRotationMatrix2D 和 cv2.warpAffine 用于旋转图像,img[100:200, 100:200] 用于裁剪图像。

特征提取

在计算机视觉领域中,特征提取是非常重要的一部分。OpenCV 提供了各种各样的特征提取算法,比如 SIFT、SURF、ORB 等。下面是一个使用 SIFT 算法提取图像特征的示例:

import cv2

# 提取特征
img = cv2.imread('test.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
sift = cv2.xfeatures2d.SIFT_create()
(kps, descs) = sift.detectAndCompute(gray, None)

可视化特征点

cv2.drawKeypoints(img, kps, img, color=(0, 255, 0), flags=cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

上述代码中,`cv2.xfeatures2d.SIFT_create` 用于创建一个 SIFT 对象,`sift.detectAndCompute` 用于提取图像的特征点和描述符,`cv2.drawKeypoints` 用于可视化特征点。需要注意的是,`cv2.drawKeypoints` 的第三个参数是输入图像,第四个参数是输出图像,所以我们在可视化特征点时需要将输入图像和输出图像设置为同一个变量。

结语

本文介绍了 Python 和 OpenCV 的基础使用,包括安装、图像读取、基本操作、特征提取等内容。当然,这只是一个入门级别的介绍,如果想深入了解 Python 和 OpenCV,还需要更多的学习和实践。

opencv基础的相关教程结束。

《opencv基础.doc》

下载本文的Word格式文档,以方便收藏与打印。