导航

    • 登录
    • 搜索
    • 版块
    • 产品
    • 教程
    • 论坛
    • 淘宝
    1. 主页
    2. pa2f
    P
    • 举报资料
    • 资料
    • 关注
    • 粉丝
    • 屏蔽
    • 帖子
    • 楼层
    • 最佳
    • 群组

    pa2f

    @pa2f

    0
    声望
    7
    楼层
    248
    资料浏览
    0
    粉丝
    0
    关注
    注册时间 最后登录

    pa2f 关注

    pa2f 发布的帖子

    • 怎么滤波才能让摄像头在不同的光线强度下识别色块(彩图和灰度图)更准?

      无无无无无无无无无无

      发布在 OpenMV Cam
      P
      pa2f
    • 测距--特征点检测测距

      能直接通过特征点检测检测到物体,然后得到这个物体的距离吗?

      发布在 OpenMV Cam
      P
      pa2f
    • OpenMV可以识别整个图像中某一个色块中的RGB三通道的值吗?怎么能锁定具体的色块?

      暂无具体代码内容

      发布在 OpenMV Cam
      P
      pa2f
    • 滤波往往都用来做些什么?是为了让图片更清晰还是什么?能否举几个例子

      相关代码太多,暂时不发代码了

      发布在 OpenMV Cam
      P
      pa2f
    • 滤波中的腐蚀和膨胀一般在什么情况下应用?也就是说用来做什么呢?
      # 腐蚀和膨胀的例子
      #
      # 这个例子展示了可以在二进制图像上运行的腐蚀和膨胀函数来消除噪声。
      # 这个例子最初是一个测试,但是它对于展示这些函数是如何工作的很有用。
      
      import pyb, sensor, image
      
      sensor.reset()
      sensor.set_framesize(sensor.QVGA)
      
      #设置阈值
      grayscale_thres = (170, 255)
      rgb565_thres = (70, 100, -128, 127, -128, 127)
      
      while(True):
      
          sensor.set_pixformat(sensor.GRAYSCALE)
          for i in range(20):
              img = sensor.snapshot()
              #先对图像进行分割,二值化,将在阈值内的区域变为白色,阈值外区域变为黑色
              img.binary([grayscale_thres])
              #对图像边缘进行侵蚀,侵蚀函数erode(size, threshold=Auto),size为
              #kernal的大小,去除边缘相邻处多余的点。threshold用来设置去除相邻点的个数,
              #threshold数值越大,被侵蚀掉的边缘点越多,边缘旁边白色杂点少;数值越小,
              #被侵蚀掉的边缘点越少,边缘旁边的白色杂点越多。
              img.erode(2)
          for i in range(20):
              img = sensor.snapshot()
              img.binary([grayscale_thres])
              img.dilate(2)
              #对图像边缘进行膨胀,膨胀函数image.dilate(size, threshold=Auto),size为
              #kernal的大小,使边缘膨胀。threshold用来设置去除相邻点的个数,threshold数值
              #越大,边缘越膨胀;
              #数值越小,边缘膨胀的小。        
      
          sensor.set_pixformat(sensor.RGB565)
          for i in range(20):
              img = sensor.snapshot()
              img.binary([rgb565_thres])
              img.erode(2)
          for i in range(20):
              img = sensor.snapshot()
              img.binary([rgb565_thres])
              img.dilate(2)
      
      发布在 OpenMV Cam
      P
      pa2f
    • clock.fps返回的值对应的是最近一次调用的clock.tick吗。
      # 色块监测 例子
      #
      # 这个例子展示了如何通过find_blobs()函数来查找图像中的色块
      # 这个例子查找的颜色是深绿色
      
      import sensor, image, time
      
      # 颜色追踪的例子,一定要控制环境的光,保持光线是稳定的。
      green_threshold   = (   0,   80,  -70,   -10,   -0,   30)
      #设置绿色的阈值,括号里面的数值分别是L A B 的最大值和最小值(minL, maxL, minA,
      # maxA, minB, maxB),LAB的值在图像左侧三个坐标图中选取。如果是灰度图,则只需
      #设置(min, max)两个数字即可。
      
      sensor.reset() # 初始化摄像头
      sensor.set_pixformat(sensor.RGB565) # 格式为 RGB565.
      sensor.set_framesize(sensor.QQVGA) # 使用 QQVGA 速度快一些
      sensor.skip_frames(time = 2000) # 跳过2000s,使新设置生效,并自动调节白平衡
      sensor.set_auto_gain(False) # 关闭自动自动增益。默认开启的,在颜色识别中,一定要关闭白平衡。
      sensor.set_auto_whitebal(False)
      #关闭白平衡。白平衡是默认开启的,在颜色识别中,一定要关闭白平衡。
      clock = time.clock() # 追踪帧率
      
      while(True):
          clock.tick() # Track elapsed milliseconds between snapshots().
          img = sensor.snapshot() # 从感光芯片获得一张图像
      
          blobs = img.find_blobs([green_threshold])
          #find_blobs(thresholds, invert=False, roi=Auto),thresholds为颜色阈值,
          #是一个元组,需要用括号[ ]括起来。invert=1,反转颜色阈值,invert=False默认
          #不反转。roi设置颜色识别的视野区域,roi是一个元组, roi = (x, y, w, h),代表
          #从左上顶点(x,y)开始的宽为w高为h的矩形区域,roi不设置的话默认为整个图像视野。
          #这个函数返回一个列表,[0]代表识别到的目标颜色区域左上顶点的x坐标,[1]代表
          #左上顶点y坐标,[2]代表目标区域的宽,[3]代表目标区域的高,[4]代表目标
          #区域像素点的个数,[5]代表目标区域的中心点x坐标,[6]代表目标区域中心点y坐标,
          #[7]代表目标颜色区域的旋转角度(是弧度值,浮点型,列表其他元素是整型),
          #[8]代表与此目标区域交叉的目标个数,[9]代表颜色的编号(它可以用来分辨这个
          #区域是用哪个颜色阈值threshold识别出来的)。
          if blobs:
          #如果找到了目标颜色
              for b in blobs:
              #迭代找到的目标颜色区域
                  # Draw a rect around the blob.
                  img.draw_rectangle(b[0:4]) # rect
                  #用矩形标记出目标颜色区域
                  img.draw_cross(b[5], b[6]) # cx, cy
                  #在目标颜色区域的中心画十字形标记
      
          print(clock.fps()) # 注意: 你的OpenMV连到电脑后帧率大概为原来的一半
          #如果断开电脑,帧率会增加
      
      发布在 OpenMV Cam
      P
      pa2f