OpenCV+Imutils实现图像的旋转操作
作者:woshicver 发布时间:2021-07-25 20:39:42
前言
本文,将描述使用 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 函数的参数值应包含图像的路径。
输出:
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函数,该函数根据旋转矩阵中指定的值对图像应用旋转。该函数还将图像宽度和高度的元组作为参数。
输出:
图像围绕中心旋转 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)
输出:
让我们比较一下如果我们通过 90⁰(逆时针 90⁰ 旋转)作为旋转角度而不是 -90⁰ 的情况。
请注意,图像以逆时针方向旋转,还将图像比例缩小了一半(通过传递 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)
输出:
旋转如何切断图像的某些部分?我将在本文后面展示如何避免这种情况。
使用 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函数,通过将图像和旋转角度作为参数传递,将图像沿所需方向旋转。
输出:
就像在前面的图像中一样,旋转会切断图像的某些部分,虽然这可能在某些用例中是有意的,但我们可以编写代码,确保图像的所有部分仍然在视图中。
脚本:将图像旋转 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)
输出:
这次使用 cv2.rotate_bound 辅助函数而不是旋转函数来确保图像的所有部分都在旋转后的图像中。
来源:https://blog.csdn.net/woshicver/article/details/124777279


猜你喜欢
- 1.导入依赖包import ( "github.com/spf13/viper")2.编写ya
- 很多人看到PHP就以为是程序员,就以为钱很多(虽然是事实),但是也要考虑下自己是不是适合这一行,知道PHP是什么吗?PHP都有什么样的功能,
- 前端使用ajax进行数据交互时:$.ajax({ cache: false, type: "POST", url: {%
- **问题描述:**有如下程序输出日志,计算程序运行时间,显示花费623分钟?start time:2019-03-15 19:45:31.2
- 问题描述: echarts柱状堆叠图,是很常用的图表,官网的例子很简单 。图例(legend),x轴(xAxis)都是
- 1.var、let、const简介 ECMAS
- 这10个asp处理网页编码转换的函数,不知何时收藏在我的电脑中,今天刚好看到了,拿出来与大家分享,这里各种常见的网页编码问题已经
- 1.第一种就是直接调用 window.print()方法这种方法的坏处就是 默认打印整个页面,不能打印局部页面。2.第二种使用v-print
- 你同样可以使用cache标签来缓存模板片段。 在模板的顶端附近加入{% load cache %}以通知模板存取缓存标签。模板标签{% ca
- 每次在"万达影城"网上购票总会用到左上角选择城市的功能。如下:今天就在ASP.NET MVC中实现一下。我想最好的方式应
- throttle我们这里说的throttle就是函数节流的意思。再说的通俗一点就是函数调用的频度控制器,是连续执行时间间隔控制。主要应用的场
- 本文介绍了python selenium UI自动化解决验证码的4种方法,分享给大家,具体如下:测试环境windows7+firefox50
- * test11.pyimport timeprint "1"time.sleep(2)print "1&qu
- Django url pathDjango 路由在 urls.py 配置path('浏览器地址栏表示URL', '处
- Matplotlib可以无缝的处理LaTex字体,在图中加入数学公式from matplotlib.patches import Polyg
- 一.在express项目中操作数据库的步骤①安装操作 MySQL 数据库的第三方模块(mysql)②通过mysql模块连接到MySQL 数据
- Python 条件语句Python条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块。可以通过下图来简单了解
- PHP版: $o = array('x'=>1, 'y'=>2, 'z'=>
- 背景开工前我就觉得有什么不太对劲,感觉要背锅。这可不,上班第三天就捅锅了。我们有个了不起的后台程序,可以动态加载模块,并以线程方式运行,通过
- 一个封装好的JavaScript拖动类,使用方便:<div id="idDrag" style="bor