opencv remap() python 的实现 以及遇到的疑问。

opencv中重映射函数 remap() 的python实现

dst=cv.remap(src, map1, map2, interpolation[, dst[, borderMode[, borderValue]]])

Parameters

srcSource image.
map1类型为CV_16SC2、CV_32FC1或CV_32FC2的(x,y)点或x值的第一个映射。有关将浮点表示转换为定点的详细信息,请参阅convertMaps。
map2第二个y值的映射分别具有CV_16UC1、CV_32FC1或none类型(如果map1是(x,y)点,则为空映射)。

那么在python 中 map1  和 map2 该如何生成呢。

    srcImage=cv2.imread("sunnys.jpg") #读取源图片
    cv2.imshow("原始图",srcImage)      #显示原始图
    sp = srcImage.shape[:2]
    map_x = np.zeros((sp[0],sp[1]),np.float32)
    map_y = np.zeros((sp[0],sp[1]),np.float32)

使用 shape 获取图像大小 使用np.zeros生成图像数组

源码:

def remapDemo():
    """remap python实现"""
    srcImage=cv2.imread("sunnys.jpg") #读取源图片
    cv2.imshow("原始图",srcImage)      #显示原始图
    sp = srcImage.shape[:2]
    map_x = np.zeros((sp[0],sp[1]),np.float32)
    map_y = np.zeros((sp[0],sp[1]),np.float32)
    for y in range(0,int(sp[0]-1)):
        for x in range(0,int(sp[1]-1)):
            xS = y
            yS = len(srcImage[y])-x
            map_x[y,x]=xS
            map_y[y,x]=yS
    dstImg=cv2.remap(srcImage, map_x, map_y, cv2.INTER_LINEAR)
    while(True):
        cv2.imshow('dstImg',dstImg)
        c=cv2.waitKey(1)
        if c==27:
            break

效果图:

 

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值