• OpenMV VSCode 扩展发布了,在插件市场直接搜索OpenMV就可以安装
  • 如果有产品硬件故障问题,比如无法开机,论坛很难解决。可以直接找售后维修
  • 发帖子之前,请确认看过所有的视频教程,https://singtown.com/learn/ 和所有的上手教程http://book.openmv.cc/
  • 每一个新的提问,单独发一个新帖子
  • 帖子需要目的,你要做什么?
  • 如果涉及代码,需要报错提示全部代码文本,请注意不要贴代码图片
  • 必看:玩转星瞳论坛了解一下图片上传,代码格式等问题。
  • 帧率只有零点几是怎么回事 只有两层for循环



    • # Untitled - By: SAU - 周二 2月 28 2023
      
      import sensor, image, time,math,gc
      
      sensor.reset()
      sensor.set_pixformat(sensor.GRAYSCALE)
      sensor.set_framesize(sensor.QQVGA)
      sensor.skip_frames(10)
      clock = time.clock()
      
      
      while(True):
          clock.tick()
          img = sensor.snapshot()
          img.gaussian(1)
          grad = [[0  for i in range(img.height())] for j in range(img.width())]
          for i in range(1, img.width()- 1):
              for j in range(1, img.height() - 1):
                  grad_x = 2*img.get_pixel(i+1,j) + img.get_pixel(i+1,j-1) + img.get_pixel(i+1,j+1) - 2*img.get_pixel(i-1,j) - img.get_pixel(i-1,j-1) - img.get_pixel(i-1,j+1)
                  grad_y = 2*img.get_pixel(i,j+1) + img.get_pixel(i-1,j+1) + img.get_pixel(i+1,j+1) - 2*img.get_pixel(i,j-1) - img.get_pixel(i-1,j-1) - img.get_pixel(i+1,j-1)
                  grad_x = math.floor(grad_x / 4)
                  grad_y = math.floor(grad_y / 4)
                  #合梯度
                  grad[i][j] = math.floor(math.sqrt(grad_x * grad_x + grad_y * grad_y))
                  img.set_pixel(i,j,(math.floor(math.sqrt(grad_x * grad_x + grad_y * grad_y))))
          print(clock.fps())
      
      


    • 自己遍历整个图片,帧率当然低。

      https://book.openmv.cc/example/04-Image-Filters/edge-filter.html