有贼出没?看我用python来捉"贼"

  • 2019 年 11 月 3 日
  • 笔记

最近丢东西了,接二连三丢东西,很是糟心。是谁干的?真想把他给揪出来。 自己用python捣鼓了个程序,看看效果。

最近自己的工位老是丢东西,关键只丢一样东西,而且每天早上来,桌子上都是乱七八糟的。像是遭了贼。

本来上班心情就不是那么愉快,这下心情更不爽了。 也没丢啥值钱的东西,就是苹果手机充电的线。本来测试的时候也要用,就插在电脑上没拔,结果总是丢。

为这点破事跟人事说,也犯不着。也许谁拿去用用,说不定就还回来了。结果几个星期过去了,没有还的,只有丢的,接二连三,感觉是盯上我了。

丢到第四根的时候,扛不住了,害我自己的手机天天没地方充电。测试机也没法充电。

我得想办法把他找出来,找他要回来。 我自己的电脑是一个macpro, 很大的屏,平时也不关机,它不有个摄像头么?我得从这上面下功夫。

import cv2    def make_photo():      """使用opencv拍照"""      cap = cv2.VideoCapture(0)  # 默认的摄像头      while True:          ret, frame = cap.read()          if ret:              cv2.imshow("capture", frame)  # 弹窗口              # 等待按键q操作关闭摄像头              if cv2.waitKey(1) & 0xFF == ord('q'):                  file_name = "theif.jpeg"                  cv2.imwrite(file_name, frame)                  break          else:              break        cap.release()      cv2.destroyAllWindows()      def make_video():      """使用opencv录像"""      cap = cv2.VideoCapture(0)  # 默认的摄像头      # 指定视频代码      fourcc = cv2.VideoWriter_fourcc(*"DIVX")      out = cv2.VideoWriter('thief.mp4', fourcc, 20.0, (640, 480))      while (cap.isOpened()):          ret, frame = cap.read()          if ret:              out.write(frame)              #              cv2.imshow('frame', frame)              # 等待按键q操作关闭摄像头              if cv2.waitKey(1) & 0xFF == ord('q'):                  break          else:              break      cap.release()      out.release()      cv2.destroyAllWindows()      if __name__ == '__main__':      make_video()      make_photo()

运行起来似乎还可以。

但是有个问题,如果我一直开机,一直拍照或者录制视频。感觉存储空间会抗不住。如果镜头有变化,才录制,这样会减少很多无用的录制,而且回放也简单很多。 改进一下:

import cv2  import numpy, os, sys      def isPicChanged(dividePar, pointDelta, judgeTh):      '''      通过前后帧对比,判断画面是否改变      :param dividePar = 40 # 对比间隔点,减少计算量      :param pointDelta = 500 # 像素点的差异大于该值认为是差异点      :param judgeTh = 640 # 判断变化画面大小的阈值:画面(1/judgeTh)      '''        capIdx = 0  # 截图命名      camIdx = -1      while (int(camIdx) < 0 or int(camIdx) > 10):          print("enter camera index in 0 and 10:")          camIdx = int(input())        if not (os.path.isdir('cap')):  # 创建存放截图的文件夹          os.system('mkdir -p {}'.format("cap"))        cap = cv2.VideoCapture(camIdx)  # 调整参数实现读取视频或调用摄像头      ret, frameBak = cap.read()      for i in range(10):  # 刚打开相机时,曝光不稳定,清理10张          ret, frameBak = cap.read()        frameWidth = int(cap.get(cv2.WIDTH))      frameHeight = int(cap.get(cv2.HEIGHT))      print("frameWidth:{},frameHeight:{}".format(frameWidth, frameHeight))      if frameWidth == 0:          exit("camera is not available.")        while True:          frameBak = frame          ret, frame = cap.read()      cap.release()      cv2.destroyAllWindows()    if __name__ == "__main__":      isPicChanged(4, 50, 64)

测试一下,效果还真有。镜头变化了,才录制。 后面想想,还有个问题,如果镜头变化很久,存储也会吃紧。 于是又写个程序,隔段时间,来检测图片的变化,如果相似度太高的,可以删除一部分。 ssim对比:

from skimage.measure import compare_ssim  import cv2    class CompareImage():        def compare_image(self, path_image1, path_image2):            imageA = cv2.imread(path_image1)          imageB = cv2.imread(path_image2)            grayA = cv2.cvtColor(imageA, cv2.COLOR_BGR2GRAY)          grayB = cv2.cvtColor(imageB, cv2.COLOR_BGR2GRAY)            (score, diff) = compare_ssim(grayA, grayB, full=True)          print("SSIM: {}".format(score))          return score      compare_image = CompareImage()  compare_image.compare_image("1.jpg", "2.jpg")

直方图对比:

import cv2  import numpy as py    img = cv2.imread("../image-030.png")  img1 = cv2.imread("../image-002.jpg")  # 计算图img的直方图  H1 = cv2.calcHist([img], [1], None, [256],[0,256])  H1 = cv2.normalize(H1, H1, 0, 1, cv2.NORM_MINMAX, -1) # 对图片进行归一化处理    # 计算图img2的直方图  H2 = cv2.calcHist([img1], [1], None, [256],[0,256])  H2 = cv2.normalize(H2, H2, 0, 1, cv2.NORM_MINMAX, -1)    # 利用compareHist()进行比较相似度  similarity = cv2.compareHist(H1, H2,0)  print(similarity)

还有哈希对比等。 这样有可以节约一些空间。

后面还想深入一点,人脸识别。可是我没那么厚的功底,就没费那大的劲。而且我的代码似乎也够用了。 这种监控,还可以应用到家用摄像头。 当然,涉及到隐私问题。所以这也是一个很敏感的问题,所以上面的代码也不全,防止有人干坏事。

最后我抓到“贼”了没?请听下回分解。