OpenCV打开摄像头,RGB转HSV空间
生活随笔
收集整理的這篇文章主要介紹了
OpenCV打开摄像头,RGB转HSV空间
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 前言
- 一、使用OpenCV打開攝像頭
- 二、使用OpenCV進行圖像預處理
前言
有段時間沒有更新了,最近主要在忙一個項目,用到了OpenCV,故想把一些常用代碼在這里備份一下,一起學習。
環境:Pycharm+Python3.7
一、使用OpenCV打開攝像頭
''' 版本:1.0 日期:2022/7/19 作者:Chen 功能:使用Opencv完成多張照片拍攝并保存至指定目錄下 '''import cv2 if __name__ == '__main__':i = 1cap = cv2.VideoCapture(0, cv2.CAP_DSHOW) # 打開攝像頭ret = cap.set(3, 1280) # 設置幀寬ret = cap.set(4, 720) # 設置幀高while (1):ret, frame = cap.read()cv2.imshow("capture", frame)k = cv2.waitKey(1)if k == ord('s'):cv2.imwrite('./Resources/Pic/' + str(i) + '.jpg', frame)print('拍照成功,獲得第', i, '張照片')i += 1elif k == ord("q"):breakcap.release()cv2.destroyAllWindows()二、使用OpenCV進行圖像預處理
將RGB轉化為HSV空間,提取感興趣的區域
import cv2 as cvclass Hsv_change:# hsv 調試def __init__(self):self.i1 = 0self.i2 = 0self.i3 = 0self.i4 = 0self.i5 = 0self.i6 = 0passdef onChange(self, a, b, hsv):if a == 1:self.i1 = belif a == 2:self.i2 = belif a == 3:self.i3 = belif a == 4:self.i4 = belif a == 5:self.i5 = belif a == 6:self.i6 = blowerb = (self.i1, self.i2, self.i3)upperb = (self.i4, self.i5, self.i6)mask = cv.inRange(hsv, lowerb, upperb)cv.imshow("mask", mask)print(self.i1, self.i2, self.i3, self.i4, self.i5, self.i6)## 調用次方法,傳入文件路徑def inRange_byFilePath(self, pathFile="Acquisition-1.jpg"):# img = cv2.imread("data2/test_aubo2.png")# img_copy=img.copy()dstImgggg = cv.imread(pathFile)img_copysize = cv.resize(dstImgggg, (int(dstImgggg.shape[1] / 2), int(dstImgggg.shape[0] / 2)))cv.imshow("img_copysize", img_copysize)hsv = cv.cvtColor(img_copysize, cv.COLOR_BGR2HSV)cv.imshow("hsv", hsv)cv.namedWindow("mask")cv.createTrackbar("h1", "mask", 0, 255, lambda a: self.onChange(1, a, hsv))cv.createTrackbar("s1", "mask", 0, 255, lambda a: self.onChange(2, a, hsv))cv.createTrackbar("v1", "mask", 0, 255, lambda a: self.onChange(3, a, hsv))cv.createTrackbar("h2", "mask", 0, 255, lambda a: self.onChange(4, a, hsv))cv.createTrackbar("s2", "mask", 0, 255, lambda a: self.onChange(5, a, hsv))cv.createTrackbar("v2", "mask", 0, 255, lambda a: self.onChange(6, a, hsv), )cv.waitKey(0)cv.destroyAllWindows()## 調用次方法,傳入圖片def inRange_byImage(self, dstImgggg):img_copysize = cv.resize(dstImgggg, (int(dstImgggg.shape[1] / 2), int(dstImgggg.shape[0] / 2)))cv.imshow("img_copysize", img_copysize)hsv = cv.cvtColor(img_copysize, cv.COLOR_BGR2HSV)cv.imshow("hsv", hsv)cv.namedWindow("mask")cv.createTrackbar("h1", "mask", 0, 255, lambda a: self.onChange(1, a, hsv))cv.createTrackbar("s1", "mask", 0, 255, lambda a: self.onChange(2, a, hsv))cv.createTrackbar("v1", "mask", 0, 255, lambda a: self.onChange(3, a, hsv))cv.createTrackbar("h2", "mask", 0, 255, lambda a: self.onChange(4, a, hsv))cv.createTrackbar("s2", "mask", 0, 255, lambda a: self.onChange(5, a, hsv))cv.createTrackbar("v2", "mask", 0, 255, lambda a: self.onChange(6, a, hsv), )cv.waitKey(0)cv.destroyAllWindows()if __name__ == '__main__':##使用:h = Hsv_change()h.inRange_byFilePath("./Resources/Pic/1.jpg")總結
以上是生活随笔為你收集整理的OpenCV打开摄像头,RGB转HSV空间的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 非平衡电桥电阻计算_惠斯通电桥不平衡怎么
- 下一篇: link2sd或者app2sd前的分区—