利用Python將圖片中扭曲矩形的復原
前言
日常生活中,手殘黨們經(jīng)常會把一些照片拍歪,比如拍個證件、試卷、PPT什么的,
比如下面這本書的封面原本是個矩形,隨手一拍就成了不規(guī)則四邊形
想要把它變成規(guī)則的矩形,有什么辦法呢?

你一定想到了 PS,因為網(wǎng)上很多教程就是這么教的
打開PS
可是這樣手工的調(diào)整數(shù)值實在是費勁喲?。?/p>

下面我們來寫個程序,自動將圖片恢復到任意矩形!
程序?qū)崿F(xiàn)
1. 打開圖片并顯示
import cv2 as cv import numpy as np path = './book.jpg' src = cv.imread(path) def get_window_size(src, bound=600): h,w = src.shape[0], src.shape[1] if h > w: h, w = bound, int(w*bound/h) else: h, w = int(h*bound/w), bound return (h, w) h, w = get_window_size(src) win_name = 'RecAdjust' cv.namedWindow(win_name, cv.WINDOW_NORMAL) cv.resizeWindow(win_name, width=w, height=h) cv.imshow(win_name, src) cv.waitKey(0) cv.destroyAllWindows()
2. 在圖片中標記四個角點

src_copy = src.copy()
class Indexer:
def __init__(self, bound=4):
self.id = 0
self.bound=bound
def get_id(self):
self.id = (self.id+1)%self.bound
return (self.id-1)%self.bound+1
def on_EVENT_LBUTTONDOWN(event, x, y, flags, param):
if event == cv.EVENT_LBUTTONDOWN:
img = param['src']
win_name = param['window']
indexer = param['indexer']
points = param['points']
curr_id = indexer.get_id()
points.append((x,y))
print('第{}個頂點: ({},{})'.format(curr_id, x, y))
cv.circle(img, (x, y), 10, (0, 0, 255), thickness = 2)
cv.putText(
img,
str(curr_id), # 文字
(x, y), # 坐標
cv.FONT_HERSHEY_PLAIN,
5, # 字號
(0,0,255), # 字體顏色
thickness = 2 # 粗細
)
cv.imshow(win_name, img)
points = []
indexer = Indexer()
win_name = 'RecAdjust'
cv.namedWindow(win_name, cv.WINDOW_NORMAL)
cv.resizeWindow(win_name, width=w, height=h)
cv.imshow(win_name, src)
cv.setMouseCallback(win_name, on_EVENT_LBUTTONDOWN, param={'src':src,'window':win_name, 'indexer':indexer, 'points':points})
cv.waitKey(0)
cv.destroyAllWindows()
print(points)
3. 設(shè)定輸出矩形大小
# W = int(input('輸出圖片寬度:'))
# H = int(input('輸出圖片高度:'))
W,H = 600, 800
target_points = [(0,0),(W,0),(W,H),(0,H)]
4. 求解透視變換矩陣
points, target_points = np.array(points, dtype=np.float32), np.array(target_points, dtype=np.float32)
M = cv.getPerspectiveTransform(points, target_points)
print('透視變換矩陣:',M)
5. 透視變換并保存圖片
result = cv.warpPerspective(src_copy, M, (0, 0)) result = result[:H, :W] win_name = 'Result' cv.namedWindow(win_name, cv.WINDOW_NORMAL) cv.resizeWindow(win_name, width=W, height=H) cv.imshow(win_name, result) cv.waitKey(0) cv.destroyAllWindows() output_file = 'result.jpg' cv.imwrite(output_file, result)
結(jié)果如下

結(jié)果沒有想象的完美,是因為書的封面已經(jīng)不是一個平面了,書角翹起。。。
如果圖片中的矩形在一個平面上的話,效果還是挺不錯的??!

完整代碼下載
可關(guān)注后免費下載喔:https://download.csdn.net/download/itnerd/12819535(本地下載)
總結(jié)
到此這篇關(guān)于利用Python將圖片中扭曲矩形復原的文章就介紹到這了,更多相關(guān)Python圖片扭曲矩形復原內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Flask SQLAlchemy一對一,一對多的使用方法實踐
Flask-SQLAlchemy一對一,一對多的使用方法實踐,需要的朋友可以參考下2013-02-02
Anaconda下Python中h5py與netCDF4模塊下載與安裝的教程詳解
這篇文章主要為大家詳細介紹了基于Anaconda,下載并安裝Python中h5py與netCDF4這兩個模塊的方法,感興趣的小伙伴可以跟隨小編一起學習一下2024-01-01
Pytorch轉(zhuǎn)keras的有效方法,以FlowNet為例講解
這篇文章主要介紹了Pytorch轉(zhuǎn)keras的有效方法,以FlowNet為例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
Python sklearn中的K-Means聚類使用方法淺析
這篇文章主要介紹了Python sklearn中的K-Means聚類使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2022-12-12
基于Linux系統(tǒng)中python matplotlib畫圖的中文顯示問題的解決方法
下面小編就為大家?guī)硪黄贚inux系統(tǒng)中python matplotlib畫圖的中文顯示問題的解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06

