五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

python識別圍棋定位棋盤位置

發(fā)布日期:2022-02-21 16:14 | 文章來源:源碼之家

最近需要做一個圍棋識別的項目,首先要將棋盤位置定位出來,效果圖如下:

效果圖

原圖

中間處理效果

最終結(jié)果

思路分析

我們利用python opencv的相關(guān)函數(shù)進(jìn)行操作實(shí)現(xiàn),根據(jù)棋盤顏色的特征,尋找到相關(guān)特征,將棋盤區(qū)域摳出來。最好從原始圖像中將棋盤位置截取出來。

源碼:定位棋盤位置

from PIL import ImageGrab
import numpy as np
import cv2
from glob import glob
imglist = sorted(glob("screen/*.jpg"))
for i in imglist:
# while 1:
 img = cv2.imread(i)
 image = img.copy()
 w,h,c = img.shape
 img2 =  np.zeros((w,h,c), np.uint8)
 img3 =  np.zeros((w,h,c), np.uint8)
 # img = ImageGrab.grab() #bbox specifies specific region (bbox= x,y,width,height *starts top-left)
 
 hsv=cv2.cvtColor(img,cv2.COLOR_BGR2HSV)
 lower = np.array([10,0,0])
 upper = np.array([40,255,255])
 mask = cv2.inRange(hsv,lower,upper)
 erodeim = cv2.erode(mask,None,iterations=2)  # 腐蝕 
 dilateim = cv2.dilate(erodeim,None,iterations=2) 
 img = cv2.bitwise_and(img,img,mask=dilateim)
 frame = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
 ret, dst = cv2.threshold(frame, 100, 255, cv2.THRESH_BINARY)
 contours,hierarchy = cv2.findContours(dst, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)

 cv2.imshow("0",img)
 i = 0
 maxarea = 0
 nextarea = 0
 maxint = 0
 for c in contours:
  if cv2.contourArea(c)>maxarea:
maxarea = cv2.contourArea(c)
maxint = i
  i+=1
 #多邊形擬合
 epsilon = 0.02*cv2.arcLength(contours[maxint],True)
 if epsilon<1:
  continue
 
 #多邊形擬合
 approx = cv2.approxPolyDP(contours[maxint],epsilon,True)
 [[x1,y1]] = approx[0]
 [[x2,y2]] = approx[2]
 checkerboard = image[y1:y2,x1:x2]
 cv2.imshow("1",checkerboard)
 cv2.waitKey(1000)
cv2.destroyAllWindows()

帶保存圖像

from PIL import ImageGrab
import numpy as np
import cv2
from glob import glob
import os
imglist = sorted(glob("screen/*.jpg"))
a=0
for i in imglist:
# while 1:
 a=a+1
 img = cv2.imread(i)
 image = img.copy()
 w,h,c = img.shape
 img2 =  np.zeros((w,h,c), np.uint8)
 img3 =  np.zeros((w,h,c), np.uint8)
 # img = ImageGrab.grab() #bbox specifies specific region (bbox= x,y,width,height *starts top-left)
 
 hsv=cv2.cvtColor(img,cv2.COLOR_BGR2HSV)
 lower = np.array([10,0,0])
 upper = np.array([40,255,255])
 mask = cv2.inRange(hsv,lower,upper)
 erodeim = cv2.erode(mask,None,iterations=2)  # 腐蝕 
 dilateim = cv2.dilate(erodeim,None,iterations=2) 
 img = cv2.bitwise_and(img,img,mask=dilateim)
 frame = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
 ret, dst = cv2.threshold(frame, 100, 255, cv2.THRESH_BINARY)
 contours,hierarchy = cv2.findContours(dst, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
 # 保存圖片的地址
 img_file_1 = "./temp"
 # 確認(rèn)上述地址是否存在
 if not os.path.exists(img_file_1):
  os.mkdir(img_file_1)
 cv2.imshow("0",img)
 cv2.imwrite(img_file_1 + "/" + 'temp_%d.jpg'%a, img)
 i = 0
 maxarea = 0
 nextarea = 0
 maxint = 0
 for c in contours:
  if cv2.contourArea(c)>maxarea:
maxarea = cv2.contourArea(c)
maxint = i
  i+=1
 #多邊形擬合
 epsilon = 0.02*cv2.arcLength(contours[maxint],True)
 if epsilon<1:
  continue
 
 #多邊形擬合
 approx = cv2.approxPolyDP(contours[maxint],epsilon,True)
 [[x1,y1]] = approx[0]
 [[x2,y2]] = approx[2]
 checkerboard = image[y1:y2,x1:x2]
 cv2.imshow("1",checkerboard)
 cv2.waitKey(1000)
 # 保存圖片的地址
 img_file_2 = "./checkerboard"
 # 確認(rèn)上述地址是否存在
 if not os.path.exists(img_file_2):
  os.mkdir(img_file_2)
 cv2.imwrite(img_file_2 + "/" + 'checkerboard_%d.jpg'%a, checkerboard)
cv2.destroyAllWindows()

到此這篇關(guān)于python識別圍棋定位棋盤位置的文章就介紹到這了,更多相關(guān)python 圍棋定位棋盤位置內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時開通

自選配置、實(shí)時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部