首页 > 解决方案 > 我想用原始位深度保存我的调整大小/缩放opencv图像?

问题描述

import cv2
import numpy as np

# load input image:
input = cv2.imread("image.png")  #image.png size has 1.48MB & bit depth: 8

# scaling:
scaled_img = cv2.resize(input,None,fx=0.5,fy=0.5,)
cv2.imshow("Scaling-Linear Interpolation", scaled_img)

#saving the img:
cv2.imwrite("image_resize.png", scaled_img)  # 1.66 MB & bit depth: 24

我想知道为什么位深度会从原始图像发生变化。并且还知道如何根据用户进行更改。

标签: pythonimageopencvresize

解决方案


opencv imread 始终读取为 3 通道输入,因此它为加载的灰度图像添加了 2 个相同的通道。

您可以使用 grayscale 或未更改标志加载为灰度,或使用 cv2.cvtColor 转换为灰度。

有关标志,请参见https://docs.opencv.org/3.4/d4/da8/group__imgcodecs.html#gga61d9b0126a3e57d9277ac48327799c80af660544735200cbe942eea09232eb822

所以目前您正在将单通道 8 位图像文件加载为 3x8=24 位图像。保存为 png 后,它是一个 24 位图像文件。


推荐阅读