亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

python opencv實現圖片旋轉矩形分割

2020-02-15 22:32:01
字體:
來源:轉載
供稿:網友

有時候需要對有角度的矩形框內圖像從原圖片中分割出來。這里的程序思想是,先將圖片進行矩形角度的旋轉,使有角度的矩形處于水平狀態后,根據原來坐標分割圖片。
參考:python opencv實現旋轉矩形框裁減功能

修改原來的程序:

1.旋轉函數的輸入僅為矩形的四點坐標
2.角度由公式計算出來
3.矩形四點pt1,pt2,pt3,pt4由txt文件讀入
4.在旋轉程序中還處理了順時針和逆時針及出現矩形框翻轉的問題。

代碼:

# -*- coding:utf-8 -*-import cv2from math import *import numpy as npimport time,mathimport osimport re'''旋轉圖像并剪裁'''def rotate(    img, # 圖片    pt1, pt2, pt3, pt4):  print pt1,pt2,pt3,pt4  withRect = math.sqrt((pt4[0] - pt1[0]) ** 2 + (pt4[1] - pt1[1]) ** 2) # 矩形框的寬度  heightRect = math.sqrt((pt1[0] - pt2[0]) ** 2 + (pt1[1] - pt2[1]) **2)  print withRect,heightRect  angle = acos((pt4[0] - pt1[0]) / withRect) * (180 / math.pi) # 矩形框旋轉角度  print angle  if pt4[1]>pt1[1]:    print "順時針旋轉"  else:    print "逆時針旋轉"    angle=-angle  height = img.shape[0] # 原始圖像高度  width = img.shape[1]  # 原始圖像寬度  rotateMat = cv2.getRotationMatrix2D((width / 2, height / 2), angle, 1) # 按angle角度旋轉圖像  heightNew = int(width * fabs(sin(radians(angle))) + height * fabs(cos(radians(angle))))  widthNew = int(height * fabs(sin(radians(angle))) + width * fabs(cos(radians(angle))))  rotateMat[0, 2] += (widthNew - width) / 2  rotateMat[1, 2] += (heightNew - height) / 2  imgRotation = cv2.warpAffine(img, rotateMat, (widthNew, heightNew), borderValue=(255, 255, 255))  cv2.imshow('rotateImg2', imgRotation)  cv2.waitKey(0)  # 旋轉后圖像的四點坐標  [[pt1[0]], [pt1[1]]] = np.dot(rotateMat, np.array([[pt1[0]], [pt1[1]], [1]]))  [[pt3[0]], [pt3[1]]] = np.dot(rotateMat, np.array([[pt3[0]], [pt3[1]], [1]]))  [[pt2[0]], [pt2[1]]] = np.dot(rotateMat, np.array([[pt2[0]], [pt2[1]], [1]]))  [[pt4[0]], [pt4[1]]] = np.dot(rotateMat, np.array([[pt4[0]], [pt4[1]], [1]]))  # 處理反轉的情況  if pt2[1]>pt4[1]:    pt2[1],pt4[1]=pt4[1],pt2[1]  if pt1[0]>pt3[0]:    pt1[0],pt3[0]=pt3[0],pt1[0]  imgOut = imgRotation[int(pt2[1]):int(pt4[1]), int(pt1[0]):int(pt3[0])]  cv2.imshow("imgOut", imgOut) # 裁減得到的旋轉矩形框  cv2.waitKey(0)  return imgRotation # rotated image# 根據四點畫原矩形def drawRect(img,pt1,pt2,pt3,pt4,color,lineWidth):  cv2.line(img, pt1, pt2, color, lineWidth)  cv2.line(img, pt2, pt3, color, lineWidth)  cv2.line(img, pt3, pt4, color, lineWidth)  cv2.line(img, pt1, pt4, color, lineWidth)# 讀出文件中的坐標值def ReadTxt(directory,imageName,last):  fileTxt=directory+"http://rawLabel//"+imageName[:7]+last # txt文件名  getTxt=open(fileTxt, 'r') # 打開txt文件  lines = getTxt.readlines()  length=len(lines)  for i in range(0,length,4):    pt2=list(map(float,lines[i].split(' ')[:2]))    pt1=list(map(float,lines[i+1].split(' ')[:2]))    pt4=list(map(float,lines[i+2].split(' ')[:2]))    pt3=list(map(float,re.split('/n| ',lines[i+3])[:2]))    # float轉int    pt2=list(map(int,pt2))    pt1=list(map(int,pt1))    pt4=list(map(int,pt4))    pt3=list(map(int,pt3))    imgSrc = cv2.imread(imageName)    drawRect(imgSrc, tuple(pt1),tuple(pt2),tuple(pt3),tuple(pt4), (0, 0, 255), 2)    cv2.imshow("img", imgSrc)    cv2.waitKey(0)    rotate(imgSrc,pt1,pt2,pt3,pt4)if __name__=="__main__":  directory = "G://grasp//grapCode//trainImage//jpg//4"  last = 'cneg.txt'  imageName="pcd0247r.png"  ReadTxt(directory,imageName,last)            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产精品一区二区不卡中文| 久久精品中文字幕一区| 日本久久久久久久久| 日韩免费观看视频| 欧美国产第二页| 亚洲欧洲高清在线| 中文字幕在线看视频国产欧美在线看完整| 日本一区二三区好的精华液| 一区二区亚洲欧洲国产日韩| 欧美在线影院在线视频| 国产精品综合不卡av| 亚洲在线第一页| 日韩欧美高清视频| 中文字幕亚洲字幕| 成人97在线观看视频| 亚洲人线精品午夜| 91免费版网站入口| 欧美午夜片欧美片在线观看| 欧美超级乱淫片喷水| 国产成人小视频在线观看| 色悠久久久久综合先锋影音下载| 亚洲欧洲视频在线| 亚洲第五色综合网| 成人久久一区二区| 久久国产精品电影| 日韩av片免费在线观看| 91大神福利视频在线| 欧美大胆在线视频| 精品国产91久久久| 欧美最猛性xxxx| 国产精品久久久久国产a级| 国产亚洲视频在线观看| 国产亚洲精品久久久久动| 成人av.网址在线网站| 日韩精品日韩在线观看| 成人免费视频网址| 成人国产精品日本在线| 91精品国产91久久久久| 亚洲人成电影网站色www| 国产精品入口夜色视频大尺度| 欧美成人午夜激情在线| 日韩美女中文字幕| 日本国产精品视频| 亚洲free性xxxx护士白浆| 亚洲国产天堂网精品网站| 欧洲日本亚洲国产区| 亚洲精品久久久久久久久久久久久| 亚洲自拍偷拍网址| 中文字幕久热精品视频在线| 亚洲国产精品成人av| 日韩av大片免费看| 亚洲第一综合天堂另类专| 日本一区二区在线播放| 亚洲成人黄色在线观看| 欧洲午夜精品久久久| 岛国av一区二区在线在线观看| 成人激情视频小说免费下载| 欧美中文字幕视频在线观看| 伊人青青综合网站| 亚洲第一国产精品| 日韩免费在线视频| 高清一区二区三区四区五区| 亚洲精品网站在线播放gif| 亚洲国产精品专区久久| 国内外成人免费激情在线视频网站| 亚洲第一精品夜夜躁人人爽| 国产亚洲精品久久久久久777| 91国自产精品中文字幕亚洲| 日韩国产在线看| 九九精品视频在线| 亚洲第一区中文99精品| 亚州成人av在线| 日本精品免费一区二区三区| 国产精品扒开腿做爽爽爽男男| 欧美性生活大片免费观看网址| 欧美成人亚洲成人日韩成人| 国产欧美日韩91| 亚洲电影免费观看| 国产精品欧美久久久| 黑人极品videos精品欧美裸| 国产一区二区三区在线播放免费观看| 久久人人爽国产| 中国china体内裑精亚洲片| 精品无人区太爽高潮在线播放| 欧美限制级电影在线观看| 91色在线视频| 日韩中文在线视频| 久久五月情影视| 亚洲人成网7777777国产| 国产第一区电影| 欧美日韩成人在线播放| 亚洲free性xxxx护士hd| 成人444kkkk在线观看| 国产成人综合精品在线| 欧美在线免费看| 日韩大陆毛片av| 亚洲区免费影片| 日韩精品在线免费观看视频| 日韩成人网免费视频| 亚洲精品之草原avav久久| 欧美激情一级精品国产| 久久久91精品国产一区不卡| 38少妇精品导航| 中文字幕日本欧美| 色与欲影视天天看综合网| 国产精品久久久久久久久久东京| 亚洲人成电影网站| 亚洲男人的天堂在线播放| 亚洲天堂网站在线观看视频| 欧美在线观看www| 国产精品一区二区三区久久久| 神马国产精品影院av| 亚洲无线码在线一区观看| 欧美成人黑人xx视频免费观看| 欧美午夜视频一区二区| 亚洲天堂av在线播放| 国产精品亚洲欧美导航| 久久视频在线播放| 91九色视频在线| www.日本久久久久com.| 久久在精品线影院精品国产| 日韩av日韩在线观看| 久久在线视频在线| 亚洲欧洲国产精品| 欧美精品精品精品精品免费| 国内精品视频在线| 久久国产精品久久久久久| 成人欧美一区二区三区黑人孕妇| 亚洲一级一级97网| 92看片淫黄大片欧美看国产片| 91精品国产色综合| 亚洲欧洲一区二区三区久久| 国产日韩在线精品av| 国产精品久久久久不卡| 亚洲男女性事视频| 日本免费久久高清视频| 日韩欧美精品免费在线| 精品久久久久久中文字幕大豆网| 最近2019年中文视频免费在线观看| 国产精品久久久久久影视| 欧美电影第一页| 午夜精品福利视频| 中文欧美在线视频| 国产成人一区二区| 一区二区三区视频免费在线观看| 在线电影av不卡网址| 亚洲黄色免费三级| 成人免费视频a| 久久免费视频观看| 在线日韩中文字幕| 亚洲国产精品99久久| 欧美国产日韩一区二区三区| 亚洲电影免费在线观看| 欧美国产日韩中文字幕在线| 亚洲一区二区免费在线| 国产欧美精品一区二区| 国产在线日韩在线| 欧美日韩ab片| 午夜精品久久久久久久久久久久久| 韩剧1988免费观看全集| 亚洲一区第一页| 国产精品福利观看| 欧美激情影音先锋| 日本精品久久中文字幕佐佐木|