OpenCV 影象處理 01 圖片的縮放
阿新 • • 發佈:2019-01-14
方法1:
#最近臨域插值 雙線性插值 原理
# src 10*20 dst 5*10
#dst<-src
#(1,2)<-(2,4)
#dst x 1 -> src x 2 newX
#newX = x*(src 行/目標 行) newX = 1*(10/5) = 2
#newY = y*(src 列/目標 列) newX = 2*(20/10) = 4
#12.3 = 12
# 1、圖片的載入load 2、獲取圖片資訊inof 3、resize方法 4、check import cv2 img = cv2.imread('image0.jpg',1) cv2.imshow('img',img) imgInfo = img.shape print(imgInfo) height = imgInfo[0] width = imgInfo[1] mode = imgInfo[2] # 1放大 縮小 2、等比例 非 2:3 dstHeight = int(height*0.5) dstWidth = int(width*0.5) #最近臨域插值 雙線性插值 畫素關係重取樣 立方插值 dst = cv2.resize(img,(dstWidth,dstHeight)) cv2.imshow('image',dst) cv2.waitKey(0)
效果:
方法2:
#雙線性插值法
#A1 = 20% 上 + 80% 下
#B1 = 30% 左 + 70% 右
#1 最終點 = A1* 30% + A2* 70%
#2 最終點 = B1* 20% + B2* 80%
#info 2 空白模板 3 需要重新計算xy import cv2 import numpy as np img = cv2.imread('image0.jpg',0) imgInfo =img.shape height = imgInfo[0] width = imgInfo[1] dstHeight = int(height/2) dstWidth = int(width/2) dstImage = np.zeros((dstHeight,dstWidth,3),np.uint8) print(height*1.0/dstHeight) for i in range(0,dstHeight):#行 for j in range(0,dstWidth): iNew = int(i*(height*1.0/dstHeight)) jNew = int(j*(width*1.0/dstWidth)) dstImage[i,j] = img[iNew,jNew] cv2.imshow('dst',dstImage) cv2.waitKey(0) #1 opencv API resize 2 演算法原理 3 原始碼