- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章
数字图像的几何运算;目录;图像平移;dst = cv2.warpAffine(src,M,dsize[,flags[,borderMode[,borderValue]]]);;;在原图像的大小不变的情况下,只是将图像平移到另一个位置,这时显示窗口尺寸变大。;在显示窗口不变的情况下,对图像进行平移,这样原图像中会有一部分不在显示窗口中,将会有部分图像丢失。; 在仿射变换的实际应用中,原始图像中的所有平行线在输出图像中希望继续保持平行,我们就需要输入图像中的三个点及其在输出图像中的对应位置,然后通过cv2.getAffineTransform()函数将创建一个2×3变换矩阵,并将该矩阵传递给cv2.warpAffine()函数,实现图像中的平行线在仿射变换前后一直保持平行。
函数cv2.getAffineTransform()语法格式为:;3.1.3 仿射变换应用实例;图像缩放;dst = cv2.resize(src,dsize[,fx[,fy[,interpolation]]]);【例3.4】分别通过设置缩放比例的方法和直接设置图像的大小方法,利用仿射变换函数cv2.warpAffine()实现对图像的缩放。程序代码如下:;图像旋转;M = cv2.getRotationMatrix2D(center, angle, scale);【例3.5】使用cv2.getRotationMatrix2D函数实现图像的顺时针、逆时针旋转。程序代码如下:;若将scale改为-1,即可进行顺时针旋转:M = cv2.getRotationMatrix2D((cols/2, rows/2), 45, -1),顺时针旋转后程序运行结果如下图所示。;【例3.6】通过上述M变换矩阵实现图像边缘无剪切的旋转。程序代码如下:;图像剪切;;【例3.7】规则剪切:对图像进行规则裁剪。程序代码如下:;【例3.8】不规则剪切:首先通过鼠标左键在图像上选取多个任意点,连接成不规则的形状;然后双击鼠标左键,剪切出图像的掩模区域和图像区域;最后点击鼠标右键将图像上的连线清除掉。程序代码如下:; # ----双击鼠标,结束选取,绘制感兴趣区域------
if event == cv2.EVENT_LBUTTONDBLCLK:
ROI_byMouse()
ROI_bymouse_flag = 1
lsPointsChoose = []
def ROI_byMouse():
global src, ROI, ROI_flag, mask2
mask = np.zeros(img.shape, np.uint8)
pts = np.array([lsPointsChoose], np.int32) # pts是多边形的顶点列表
pts = pts.reshape((-1, 1, 2))
# OpenCV中需要先将多边形的顶点坐标变成顶点数×1×2维的矩阵,再来绘制
mask = cv2.polylines(mask, [pts], True, (255, 255, 255)) # 画多边形
mask2 = cv2.fillPoly(mask, [pts], (255, 255, 255)) #填充多边形
cv2.imshow(mask, mask2)
#掩模图像与原图像进行“位与”操作
ROI = cv2.bitwise_and(mask2, img)
cv2.imshow(ROI, ROI)
if __name__ == __main__:
# 选择点设置
lsPointsChoose = []
tpPointsChoose = []
pointsCount = 0
count = 0
pointsMax = 6
img = cv2.imread(d:/pics/lena.jpg)
ROI = img.copy()
cv2.namedWindow(src)
cv2.setMouseCallback(src, On_Mouse)
cv2.imshow(src, img)
cv2.waitKey(0)
cv2.destroyAllWindows();图像镜像变换;dst = cv2.flip(src, flipCode);【例3.9】使用cv2.flip函数实现图像的水平、垂直以及对角镜像变换。程序代码如下:;图像透视变换;M = cv2.getPerspecti
您可能关注的文档
- 工程管理学 01工程概述.pptx
- 工程管理学 02工程管理概述.pptx
- 工程管理学 03工程决策.pptx
- 工程管理学 04工程设计.pptx
- 工程管理学 05工程施工.ppt
- 工程管理学 06工程验收.ppt
- 工程管理学 07工程招投标.ppt
- 工程管理学 08工程投资.ppt
- 工程管理学 09工程融资.ppt
- 工程管理学 10工程经济评估.pptx
- 智能图像处理:Python和OpenCV实现第十二章 图像特征的提取与分析.pptx
- 智能图像处理:Python和OpenCV实现第十二章 图像特征的提取与分析1.pptx
- 智能图像处理:Python和OpenCV实现第十一章 彩色图像处理.pptx
- 智能图像处理:Python和OpenCV实现第十章 图像分割.pptx
- 智能图像处理:Python和OpenCV实现第四章 图像空域增强.pptx
- 智能图像处理:Python和OpenCV实现第五章 图像空域滤波.pptx
- 智能图像处理:Python和OpenCV实现第一章 python入门基础.pptx
- 智能图像处理:Python和OpenCV实现第一章 数字图像处理课件-opencv简介.pptx
最近下载
- 2025届高考英语长难句分析课件.pptx
- 2023部编新人教版五年级(上册)道德与法治全册教案.doc VIP
- 水土保持单元工程施工质量检验表与验收表(样表:2混凝土工程)(SLT 336—2025)水土保持工程质量验收与评价规范.docx VIP
- 玻璃板液位计介绍.pptx VIP
- 国家计委“计价格[2002]1980号文”.doc VIP
- 特种工程塑料——PEEK .ppt VIP
- 三国志曹操传宝物全拿攻略.doc VIP
- 卫星气象学课件:第3章 卫星遥感辐射基础.ppt VIP
- 2025年部编新人教版五年级上册道德与法治全册教案资料.doc VIP
- 1正确认识广告教学设计.docx VIP
文档评论(0)