先填充在缩放和先缩放后填充的区别

本文探讨了图像处理中两种不同缩放填充方法——先填充后缩放与先缩放后填充——对图像像素值的影响。通过具体示例,展示了尽管视觉效果相近,但像素差异可达近一半,主要归因于坐标位置变化及双线性插值法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

将同样的一张图(101*156),采用两种不同的方式进行缩放填充,带来的像素差异:

1.先填充后缩放

def resize_1(img):
    height, width, channel = img.shape
    temp = np.zeros((height,height,3),np.uint8)
    start = (height -width) / 2
    temp[:,start:width+start,:] = img
    img1 = cv2.resize(temp,(300,300))
    cv2.imwrite('test_1.jpg',img1)
    return img1

2.先缩放后填充

def resize_1(img):
    height, width, channel = img.shape
    temp = np.zeros((height,height,3),np.uint8)
    start = (height -width) / 2
    temp[:,start:width+start,:] = img
    img1 = cv2.resize(temp,(300,300))
    cv2.imwrite('test_1.jpg',img1)
    return img1

opencv2默认采用的是INTER_LINEAR(双线性插值法)

3.对比两张图片的不同并且可视化

def compare(img1,img2,img3):
    count = 0
    height,width,channel = img1.shape
    for h in xrange(height):
        for w in xrange(width):
            if sum(img1[h][w]) != sum(img2[h][w]):
                print(img1[h][w])
                print(img2[h][w])
                count += 1
                img3[h][w] = [0,0,255]
                # pass
    print(count)
    cv2.imwrite('test.jpg',img3)

结果将会显示近一半的像素值不同.

为什么会产生这种原因呢?

主要是坐标的位置发生了变化,因为我们采用的opencv默认的是双线性插值:

  SrcX=(dstX+0.5)* (srcWidth/dstWidth) -0.5
  SrcY=(dstY+0.5) * (srcHeight/dstHeight)-0.5

则假设我们src图像为100*150,缩放到200*300,然后最终填充到300*300,

所以要找dst(0,30)对应的src坐标,(四舍五入)

  srcx = 0.5 * 0.5 - 0.5 = 0

  srcy = 30.5*0.5 -0.5 = 15
但是第一种扩大的方式找到的(0,15)是基于前面带有黑边的坐标,而第二种方式是没有带黑边的坐标,

由于坐标的偏移,最终导致了缩放最后肉眼看着没有什么区别,但是对于图像的像素来说已经有近一半的不同。

 

转载于:https://www.cnblogs.com/magicpig666/p/9766521.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值