OpenCV+Imutils实现图像的旋转操作

作者:woshicver 时间:2021-07-25 20:39:42 

前言 

OpenCV+Imutils实现图像的旋转操作

本文,将描述使用 OpenCV 和 Imutils 围绕任意点旋转指定角度的图像所需的步骤。

使用 OpenCV 旋转图像

使用 OpenCV 旋转图像:

1.使用 OpenCV 的 imread 函数加载所需的图像。

脚本:加载并显示原始图像

# import required library
import cv2

# load image from disk
image = cv2.imread('eiffel_tower.jpg')

# display image
cv2.imshow('Original image', image)
cv2.waitKey(0)

导入了 OpenCV 库并使用 imread 函数从工作目录加载了埃菲尔铁塔的图像,然后使用 imshow 函数显示图像。

请注意,如果图像不在工作目录中,则提供给 imread 函数的参数值应包含图像的路径。

输出:

OpenCV+Imutils实现图像的旋转操作

2.获取图像的空间维度(高度、宽度、中心坐标)。

脚本:获取图像的高度、宽度和中心坐标。

# get the dimensions of the image and calculate the center of the
# image
height, width = image.shape[:2]
centerX, centerY = (width // 2, height // 2)

image.shape属性的前两个值分别返回图像的高度和宽度。整数除法用于获取中心位置的值,因为旋转图像的函数只接受整数值。中心位置值对于围绕中心旋转图像很有用。

3.定义一个旋转矩阵以围绕所需的点和旋转角度旋转图像。

脚本:定义一个旋转矩阵以将图像围绕中心旋转 45⁰。

# # rotate our image by 45 degrees around the center of the image

# get rotation matrix
M = cv2.getRotationMatrix2D((centerX, centerY), 45, 1.0)

cv2.getRotationMatrix2D函数(顾名思义)定义了一个二维矩阵,用于根据传递的参数值旋转图像。

该函数采用旋转点参数(在此示例中,图像的中心由坐标(centerX , centerY)表示)、以度为单位的旋转角度(在本例中为45度)和浮点值(在本例中为1.0 )指定旋转图像相对于原始图像的比例。

我们示例中的1.0比例值将旋转后的图像缩放为与原始图像相同的尺寸。较高的比例值会扩大图像,而较低的值会缩小图像。

4.根据旋转矩阵对图像进行旋转,并显示旋转后的图像。

脚本:将图像围绕中心旋转 45⁰。

# rotate image
rotated = cv2.warpAffine(image, M, (width, height))

# display image
cv2.imshow("Rotated by 45 Degrees", rotated)
cv2.waitKey(0)

旋转矩阵 (M) 被传递给cv2.warpAffine函数,该函数根据旋转矩阵中指定的值对图像应用旋转。该函数还将图像宽度和高度的元组作为参数。

输出:

OpenCV+Imutils实现图像的旋转操作

图像围绕中心旋转 450。注意图像是逆时针方向旋转的吗?我们还可以通过在旋转矩阵中传递旋转角度的负值来顺时针旋转图像。

使用 OpenCV 顺时针旋转图像

脚本:

# rotate the image by 90 degrees in clockwise direction
M = cv2.getRotationMatrix2D((centerX, centerY), -90, 0.5)
rotated = cv2.warpAffine(image, M, (width, height))
cv2.imshow("Rotated by -90 Degrees", rotated)
cv2.waitKey(0)

输出:

OpenCV+Imutils实现图像的旋转操作

让我们比较一下如果我们通过 90⁰(逆时针 90⁰ 旋转)作为旋转角度而不是 -90⁰ 的情况。

OpenCV+Imutils实现图像的旋转操作

请注意,图像以逆时针方向旋转,还将图像比例缩小了一半(通过传递 0.5 作为比例值)。

虽然之前已经沿中心(centerX, centerY)旋转了图像,但可以使用前面提到的类似步骤围绕图像中的任意点旋转图像。

围绕任意点旋转图像

脚本:将图像围绕点 (15, 10) 旋转 30 度。

# rotate our image around an arbitrary point
M = cv2.getRotationMatrix2D((15, 10), 30, 1.0)
rotated = cv2.warpAffine(image, M, (width, height))
cv2.imshow("Rotated around an  Arbitrary Point", rotated)
cv2.waitKey(0)

输出:

OpenCV+Imutils实现图像的旋转操作

旋转如何切断图像的某些部分?我将在本文后面展示如何避免这种情况。

使用 Imutils 旋转图像

就像移动图像一样,Imutils 包提供了使用简单易用的旋转辅助函数沿任意点和任意角度旋转图像的简单步骤。

脚本:使用 Imutils 将图像顺时针旋转 30⁰。

# rotate our image around an arbitrary point
M = cv2.getRotationMatrix2D((15, 10), 30, 1.0)
rotated = cv2.warpAffine(image, M, (width, height))
cv2.imshow("Rotated around an  Arbitrary Point", rotated)
cv2.waitKey(0)

调用 imutils.rotate函数,通过将图像和旋转角度作为参数传递,将图像沿所需方向旋转。

输出:

OpenCV+Imutils实现图像的旋转操作

就像在前面的图像中一样,旋转会切断图像的某些部分,虽然这可能在某些用例中是有意的,但我们可以编写代码,确保图像的所有部分仍然在视图中。

脚本:将图像旋转 30⁰,同时确保整个图像都在视图中。

# rotate the image by 30 degrees, ensuring the
# entire rotated image still views in the viewing area
rotated = imutils.rotate_bound(image, -30)
cv2.imshow("Rotated Without Cropping", rotated)
cv2.waitKey(0)

输出:

OpenCV+Imutils实现图像的旋转操作

这次使用 cv2.rotate_bound 辅助函数而不是旋转函数来确保图像的所有部分都在旋转后的图像中。

来源:https://blog.csdn.net/woshicver/article/details/124777279

标签:OpenCV,Imutils,图像,旋转
0
投稿

猜你喜欢

  • 使用SQL Server判断文件是否存在后再删除(详解)

    2024-01-19 13:03:33
  • jupyter notebook读取/导出文件/图片实例

    2022-01-05 00:28:45
  • Python Flask 实现 HTML 文件压缩案例代码(9 级压缩)

    2021-05-22 15:22:13
  • 在CentOS上MySQL数据库服务器配置方法

    2024-01-19 07:01:21
  • 深入解析Python中的变量和赋值运算符

    2023-10-13 20:58:53
  • 用Python遍历C盘dll文件的方法

    2023-04-27 20:15:27
  • Python从csv文件中读取数据及提取数据的方法

    2021-01-26 07:12:44
  • Jupyter Notebook 文件默认目录的查看以及更改步骤

    2022-03-22 15:01:19
  • SQL Server异常代码处理的深入讲解

    2024-01-22 11:42:58
  • Mysql中的Btree与Hash索引比较

    2024-01-16 12:56:49
  • Mysql中mvcc各场景理解应用

    2024-01-24 19:29:07
  • Python实现随机取一个矩阵数组的某几行

    2021-10-04 16:45:52
  • python+pygame实现简易五子棋小游戏的三种方式

    2023-09-26 06:01:43
  • python 使用第三方库requests-toolbelt 上传文件流的示例

    2021-05-13 05:48:31
  • Mysql技术内幕之InnoDB锁的深入讲解

    2024-01-19 12:16:21
  • Python利用 SVM 算法实现识别手写数字

    2023-04-17 10:33:58
  • Python tkinter模块中类继承的三种方式分析

    2023-07-19 22:00:48
  • Django nginx配置实现过程详解

    2022-11-09 11:42:58
  • Python编程快速上手——strip()函数的正则表达式实现方法分析

    2022-07-24 07:08:59
  • Python多个MP4合成视频的实现方法

    2021-02-21 13:50:44
  • asp之家 网络编程 m.aspxhome.com