สอบถามว่า ต้องเขียน Code อย่างไร จึงจะทำให้ระบบ Coin Segmentation : Python OpenCV สามารถนับของจากภาพนิ่ง ที่เป็นแบบสี่เหลี่ยมได้ และมีหน้าจอ File Select ให้เลือกไฟล์ภาพนิ่งก่อน แล้วจะนับของจากภาพนิ่งครับ
สอบถามว่า ต้องเขียน Code อย่างไร จึงจะทำให้ระบบ Coin Segmentation : Python OpenCV สามารถนับของจากภาพนิ่ง ที่เป็นแบบสี่เหลี่ยมได้ และมีหน้าจอ File Select ให้เลือกไฟล์ภาพนิ่งก่อน แล้วจะนับของจากภาพนิ่งครับ
ผมศึกษาบทความเรื่อง Coin Segmentation : Python OpenCV จาก link บทความ https://medium.com/@kongruksiamza/coin-secmentation-python-opencv-9c7a9537002c และ link Source Code https://github.com/kongruksiamza/Coin-Segmentation
ปัญหาที่เจอ คือ นับของได้เฉพาะแบบทรงกลม เช่น เหรียญ ยังนับของจากภาพนิ่ง ที่เป็นแบบสี่เหลี่ยมไม่ได้ และยังไม่มีหน้าจอ File Select ให้เลือกไฟล์ภาพนิ่งก่อน แล้วจะนับของจากภาพนิ่งครับ
ตัวอย่าง Code ครับ
1. CoinDetection.py
import cv2
import numpy as np
cap=cv2.VideoCapture("Coin2.mp4")
while(cap.read()) :
ref,frame = cap.read()
roi=frame[:1080,0:1920]
gray=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
gray_blur=cv2.GaussianBlur(gray,(15,15),0)
thresh=cv2.adaptiveThreshold(gray_blur,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,cv2.THRESH_BINARY_INV,11,1)
kernel=np.ones((3,3),np.uint8)
closing=cv2.morphologyEx(thresh,cv2.MORPH_CLOSE,kernel,iterations=4)
result_img=closing.copy()
contours,hierachy=cv2.findContours(result_img,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
counter=0
for cnt in contours:
area = cv2.contourArea(cnt)
if area<5000 or area > 35000:
continue
ellipse = cv2.fitEllipse(cnt)
cv2.ellipse(roi,ellipse,(0,255,0),2)
counter+=1
cv2.putText(roi,str(counter),(10,100),cv2.FONT_HERSHEY_SIMPLEX,4,(255,0,0),2,cv2.LINE_AA)
cv2.imshow("Show",roi)
if cv2.waitKey(1) & 0xFF==ord('q'):
break
cap.release()
cv2.destroyAllWindows()
2. ไฟล์รูปตัวอย่าง ที่ต้องการนับของจากภาพนิ่ง ที่เป็นแบบสี่เหลี่ยม ตาม link ด้านล่างครับ
https://inwfile.com/s-fn/uzr1at.png
3. หน้าตา หน้าจอ File Select ให้เลือกไฟล์ภาพนิ่งก่อน แล้วจะนับของจากภาพนิ่ง ที่ต้องการครับ
Tag : PHP, Python, Linux, Mac, Windows
Date :
2020-06-26 15:59:49
By :
doanga2007
View :
2586
Reply :
3
ขุ่นพระ! python ก็ถามใน php!?
คราวก่อนก็มี .net หลุดเข้ามาที ส่วน css, js (script forum) นี่เข้ามาในนี้ประจำ...
แต่จะว่าไปหมวด python ก็ไม่มี!
คุณวินครับ น่าจะได้เวลายกเครื่องฟอรัม thaicreate ได้แล้วมั้ง??
เอาแบบคล้ายๆ stackoverflow ก็ดีนะ แหะๆ
Date :
2020-06-26 17:15:43
By :
mr.v
ความคืบหน้า : สามารถเพิ่ม หน้าจอ File Select ให้เลือกไฟล์ภาพนิ่งก่อน แล้วจะนับของจากภาพนิ่ง ที่ต้องการ ได้แล้ว พร้อมทั้งสามารถ Compile ให้กลายเป็นไฟล์ EXE ได้ด้วย ซึ่งมีขั้นตอน ดังนี้
1. ทำการติดตั้ง pyinstaller / auto-py-to-exe / win32com ซึ่งได้ข้อมูลจากเว็บ
ด้วยคำสั่ง
pip install https://github.com/pyinstaller/pyinstaller/archive/develop.zip
pip install auto-py-to-exe
pip install pywin32
2. ทำการเขียน Code ดังนี้
BoxDetection.py
import cv2
import numpy as np
from tkinter import Tk
from tkinter.filedialog import askopenfilename
Tk().withdraw() # we don't want a full GUI, so keep the root window from appearing
filename = askopenfilename() # show an "Open" dialog box and return the path to the selected file
cap=cv2.VideoCapture(filename) # Compatible with box2 mp4 video file
while(cap.read()) :
ref,frame = cap.read()
roi=frame[:1080,0:1920]
gray=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
gray_blur=cv2.GaussianBlur(gray,(25,25),0)
thresh=cv2.adaptiveThreshold(gray_blur,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,cv2.THRESH_BINARY_INV,21,4)
kernel=np.ones((3,3),np.uint8)
closing=cv2.morphologyEx(thresh,cv2.MORPH_CLOSE,kernel,iterations=4)
result_img=closing.copy()
contours,hierachy=cv2.findContours(result_img,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
counter=0
for cnt in contours:
area = cv2.contourArea(cnt)
if area<800 :
continue
# ellipse = cv2.fitEllipse(cnt)
# cv2.ellipse(roi,ellipse,(0,255,0),2)
counter+=1
cv2.putText(roi,str(counter),(10,100),cv2.FONT_HERSHEY_SIMPLEX,4,(0,0,255),4,cv2.LINE_AA)
cv2.imshow("Show",roi)
if cv2.waitKey(300000) & 0xFF==ord('q'):
break
cap.release()
cv2.destroyAllWindows()
และมีไฟล์ตัวอย่าง VDO box2.mp4 ตาม link - https://doanga2007.github.io/box2.mp4 ครับ
3. ทำการเปิด cmd แล้วพิมพ์คำสั่ง auto-py-to-exe เพื่อเปิดโปรแกรม ทำการเลือกไฟล์ Python ให้เรียบร้อย แล้วกดปุ่ม Compile ให้กลายเป็นไฟล์ EXE ได้ทันที
4. ได้ไฟล์ BoxDetection.exe ตาม link - https://drive.google.com/file/d/1tnnnDWRrg1NbPZ3hr9mhY-t_4zry21rB/view?usp=sharing ครับ
Date :
2020-08-19 14:10:23
By :
doanga2007
Load balance : Server 01