• OpenMV VSCode 扩展发布了,在插件市场直接搜索OpenMV就可以安装
  • 如果有产品硬件故障问题,比如无法开机,论坛很难解决。可以直接找售后维修
  • 发帖子之前,请确认看过所有的视频教程,https://singtown.com/learn/ 和所有的上手教程http://book.openmv.cc/
  • 每一个新的提问,单独发一个新帖子
  • 帖子需要目的,你要做什么?
  • 如果涉及代码,需要报错提示全部代码文本,请注意不要贴代码图片
  • 必看:玩转星瞳论坛了解一下图片上传,代码格式等问题。
  • 为啥程序烧录之后摄像头没图像了,显示程序还运行着 但就是摄像头黑了 求解答



    • from pyb import Servo
      import time
      s1 = Servo(1) # servo on position 1 (P8)设置下方转动舵机
      s2 = Servo(2) # servo on position 1 (P7)设置上方俯仰舵机
      import sensor, image, math
      red   = (11, 30, 14, 35, 0, 28)             # 红色阈值设置
      green = (29, 44, -37, -17, 14, 37)          # 绿色阈值设置
      blue  = (40, 65, -36, -10, -17, 7)          # 蓝色阈值设置
      # 颜色识别区域
      rectX0 =  120#120
      rectY0 =  120
      rectXL =  20#80 320
      rectYL =  100#50
      r_num = 0
      r_x_weighted = 0
      r_x = 0
      r_y = 150
      sensor.reset()
      sensor.set_pixformat(sensor.RGB565)
      sensor.set_framesize(sensor.QVGA)
      sensor.skip_frames(time = 2000)
      sensor.set_auto_gain(False) # must be turned off for color tracking
      sensor.set_auto_whitebal(False, rgb_gain_db = (-6.02073, -5.886325, -4.30291)) # must be turned off for color tracking
      clock = time.clock()
      
      while(True):
          #s2.angle(-22) # move to 45 degrees 俯仰  平放桌面可看到6个色卡的角度  度数增加摄像头下弯 度数减少摄像头上仰
          #time.sleep(1800)
          #s1.angle(-40) # move to 45 degrees -40度正中间度数 转动  俯视往左度数增加 往右度数减小
          #time.sleep(1800)
          #s1.angle(-50) # move to 45 degrees 右转转动识别第三个干旱色卡
          #time.sleep(1800)
          #s1.angle(-30) # move to 45 degrees 左转转动识别第一个干旱色卡
          #time.sleep(1800)
          clock.tick()
          img = sensor.snapshot()
          for blobs in img.find_blobs([red],  merge=True,y_stride = 10,area_threshold = 50,roi = [rectX0,rectY0,rectXL,rectYL]): #merge=True不合并所有没有被过滤掉的色块,这些色块的边界矩形不互相交错重叠 y_stride查找某色块时需要跳过的y像素的数量 若一个色块的边界框区域小于 area_threshold ,则会被过滤掉  roi 是感兴趣区域的矩形元组(x,y,w,h)。
              if blobs:
                  img.draw_rectangle(blobs.rect(),(255,0,0))  
                  r_x += blobs.cx() * blobs.w()   #blob.w()返回色块的边界框的w坐标(int)。  blob.cx()返回色块(int)的中心x位置。 LHL
                  #r_y += blobs.cy()
                  r_x_weighted += blobs.w()
                  r_num += 1
                  img.draw_cross(r_x, r_y, (255,0,0), size=5)#画准星
          print(clock.fps())
      


    • 13行set_auto_whitebal不对,注释掉就好了。