重映射互换、缩放

2021-10-11  本文已影响0人  大龙10

《OpenCV轻松入门:面向Python》读书笔记
作者:李立宗
出版社:电子工业出版社
出版时间:2019-05

第5章 几何变换

5.5 重映射

5.5.5 绕x轴、y轴翻转

如果想让图像绕着x轴、y轴翻转,意味着在映射过程中:

反映在map1和map2上:

5.5.6 x轴、y轴互换

如果想让图像的x轴、y轴互换,意味着在映射过程中,对于任意一点,都需要将其x轴、y轴坐标互换。
反映在mapx和mapy上:

需要注意的是,如果行数和列数不一致,上述运算可能存在值无法映射的情况。默认情况下,无法完成映射的值会被处理为0。

5.5.7 图像缩放

上述介绍的映射都是直接完成的整数映射,处理起来比较方便。在处理更复杂的问题时,就需要对行、列值进行比较复杂的运算来实现。
缩小图像后,可以将图像固定在围绕其中心的某个区域。
例如,将其x轴、y轴设置为:

3)程序

import cv2
import numpy as np
img=cv2.imread("lena.bmp")
rows,cols=img.shape[:2]
mapx = np.zeros(img.shape[:2],np.float32)
mapy = np.zeros(img.shape[:2],np.float32)
for i in range(rows):
    for j in range(cols):
            mapx.itemset((i,j),cols-1-j)
            mapy.itemset((i,j),rows-1-i)
rst1=cv2.remap(img,mapx,mapy,cv2.INTER_LINEAR)

mapx = np.zeros(img.shape[:2],np.float32)
mapy = np.zeros(img.shape[:2],np.float32)
for i in range(rows):
    for j in range(cols):
            mapx.itemset((i,j),i)
            mapy.itemset((i,j),j)
rst2=cv2.remap(img,mapx,mapy,cv2.INTER_LINEAR)

mapx = np.zeros(img.shape[:2],np.float32)
mapy = np.zeros(img.shape[:2],np.float32)
for i in range(rows):
    for j in range(cols):
        if 0.25*cols< i <0.75*cols and 0.25*rows< j <0.75*rows:
                mapx.itemset((i,j),2*( j - cols*0.25 ) + 0.5)
                mapy.itemset((i,j),2*( i - rows*0.25 ) + 0.5)
        else:     
                mapx.itemset((i,j),0)
                mapy.itemset((i,j),0)

rst3=cv2.remap(img,mapx,mapy,cv2.INTER_LINEAR)

cv2.imshow("original",img)
cv2.imshow("result1",rst1)
cv2.imshow("result2",rst2)
cv2.imshow("result3",rst3)

cv2.waitKey()
cv2.destroyAllWindows()

4)结果

上一篇 下一篇

猜你喜欢

热点阅读