国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

利用Python將圖片中扭曲矩形的復原

瀏覽:2日期:2022-07-12 09:15:46

前言

日常生活中,手殘黨們經常會把一些照片拍歪,比如拍個證件、試卷、PPT什么的,

比如下面這本書的封面原本是個矩形,隨手一拍就成了不規則四邊形

想要把它變成規則的矩形,有什么辦法呢?

利用Python將圖片中扭曲矩形的復原

你一定想到了 PS,因為網上很多教程就是這么教的

打開PS ⟹Longrightarrow⟹ 濾鏡 ⟹Longrightarrow⟹鏡頭校正 ⟹Longrightarrow⟹自定 ⟹Longrightarrow⟹變換

可是這樣手工的調整數值實在是費勁喲!!

利用Python將圖片中扭曲矩形的復原

下面我們來寫個程序,自動將圖片恢復到任意矩形!

程序實現

1. 打開圖片并顯示

import cv2 as cvimport numpy as nppath = ’./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. 在圖片中標記四個角點

利用Python將圖片中扭曲矩形的復原

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+1def 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. 設定輸出矩形大小

# W = int(input(’輸出圖片寬度:’))# H = int(input(’輸出圖片高度:’))W,H = 600, 800target_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)

結果如下

利用Python將圖片中扭曲矩形的復原

結果沒有想象的完美,是因為書的封面已經不是一個平面了,書角翹起。。。

如果圖片中的矩形在一個平面上的話,效果還是挺不錯的!!

利用Python將圖片中扭曲矩形的復原

完整代碼下載

可關注后免費下載喔:https://download.csdn.net/download/itnerd/12819535(本地下載)

總結

到此這篇關于利用Python將圖片中扭曲矩形復原的文章就介紹到這了,更多相關Python圖片扭曲矩形復原內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产1000部成人免费视频 | 久久国产国内精品对话对白 | 女同日韩互慰互摸在线观看 | 久久全国免费久久青青小草 | 美女张开大腿让男人桶 | 男人的天堂高清在线观看 | 国产美女拍拍拍在线观看 | 四川一级片 | 在线观看国产一区二区三区99 | 德国女人一级毛片免费 | 美国一级片在线观看 | 日本欧美一区二区 | 欧美jizzhd极品欧美 | 91国内精品久久久久怡红院 | 国产大片中文字幕在线观看 | 夜色视频一区二区三区 | 成 人 动漫在线观看网站网站 | 国产高清久久 | 久久精彩视频 | 香港三级日本三级妇人三级 | 久草视频新 | 真正全免费视频a毛片 | 精品高清国产a毛片 | 欧美一级片网站 | 看5xxaaa免费毛片 | 国产一级毛片网站 | 99免费在线 | 欧美成人手机视频免费播放 | 久久香蕉国产线看免费 | 亚洲免费精品视频 | 日本a级特黄三级三级三级 日本a一级片 | 日本黄色官网 | 男女免费爽爽爽在线视频 | 国产成人 免费观看 | 精品国产一区二区三区久久影院 | 国产精品情人露脸在线观看 | 国产初高中生粉嫩无套第一次 | 亚洲国产高清一区二区三区 | 可以看的黄网 | 国产丶欧美丶日韩丶不卡影视 | 欧美成人aaaa免费高清 |