ly93969 2022-02-28 15:48 采纳率: 36.4%
浏览 23
已结题

ROS编写服务问题:图像处理相关

这是我写的图像处理python代码,基于opencv。现在想把它封装成一个ros服务。请问各位该如何去改呢?
以下是源码。

 
import cv2
import numpy as np
import os
 
 
def imgdetect(image):
    blue_lower = np.array([100, 50, 50])
    blue_upper = np.array([124, 255, 255])
    hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
    mask = cv2.inRange(hsv, lowerb=blue_lower, upperb=blue_upper)
    Canny = cv2.Canny(mask, 9, 9)
    circle = cv2.HoughCircles(Canny, cv2.HOUGH_GRADIENT, 1, 100, param1=100, param2=30, minRadius=100, maxRadius=200)
    return circle
 
 
myList = os.listdir('ImagesQuery')
 
cap = cv2.VideoCapture(0)
 
while True:
    success, image = cap.read()
    imgOriginal = image.copy()
    cir = imgdetect(image)
    if not cir is None:
        cir = np.uint16(np.around(cir))
        max_r, max_i = 0, 0
        for i in range(len(cir[:, :, 2][0])):
            if cir[:, :, 2][0][i] > 50 and cir[:, :, 2][0][i] > max_r:
                max_i = i
                max_r = cir[:, :, 2][0][i]
        x, y, r = cir[:, :, :][0][max_i]
        if y > r and x > r:
            square = imgOriginal[y - r:y + r, x - r:x + r]
            img_gray = cv2.cvtColor(square, cv2.COLOR_BGR2GRAY)
            cv2.imshow('img_gray', img_gray)
            for i in range(4):
                template = cv2.imread('ImagesQuery/' + myList[i])
                template = cv2.cvtColor(template, cv2.COLOR_BGR2GRAY)
                res = cv2.matchTemplate(img_gray, template, cv2.TM_CCORR_NORMED)
                (_, score, _, _) = cv2.minMaxLoc(res)
                threshold = 0.8
                h, w = template.shape[:2]
                if score > 0.93:
                    cv2.rectangle(imgOriginal, (x - r - 5, y - r - 5), (x + r + 5, y + r + 5), (0, 255, 0), 2)
                    if i == 0:
                        cv2.putText(imgOriginal, 'Back', (x, y + r + 10), cv2.FONT_HERSHEY_DUPLEX, 1, (255, 0, 0), 2)
                    if i == 1:
                        cv2.putText(imgOriginal, 'Forward', (x, y + r + 10), cv2.FONT_HERSHEY_DUPLEX, 1, (255, 0, 0), 2)
                    if i == 2:
                        cv2.putText(imgOriginal, 'Left', (x, y + r + 10), cv2.FONT_HERSHEY_DUPLEX, 1, (255, 0, 0), 2)
                    if i == 3:
                        cv2.putText(imgOriginal, 'Right', (x, y + r + 10), cv2.FONT_HERSHEY_DUPLEX, 1, (255, 0, 0), 2)
    cv2.imshow('img', imgOriginal)
    cv2.waitKey(1)
 

  • 写回答

1条回答 默认 最新

  • 赵4老师 2022-03-02 15:01
    关注

    发布/订阅
    sensor_msgs::Image

    sensor_msgs::CompressedImage

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月16日
  • 已采纳回答 3月8日
  • 创建了问题 2月28日

悬赏问题

  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测
  • ¥88 python部署量化回测异常问题
  • ¥30 酬劳2w元求合作写文章
  • ¥15 在现有系统基础上增加功能
  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码