yizhiyu_hh 2021-12-01 11:38 采纳率: 75%
浏览 45
已结题

想用for循环遍历图中的两个轮廓,但是只能显示一半

问题遇到的现象和发生背景

img

问题相关代码,请勿粘贴截图
import cv2
import numpy as np

imagepath = 'E:/149_v4.png'
# imagepath = ''
img = cv2.imread(imagepath, 1)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 二值化
ret, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 图片轮廓
image, contours, hierarchy = cv2.findContours(thresh, 2, 1)

print(len(contours))
for i in range(len(contours)):
    if len(contours[i]) < 10:        # 删除图中可能存在的独立小凸包
        contours.remove(contours[i])

for j in contours:
    cnt = j

    # 寻找凸包并绘制凸包(轮廓)
    hull = cv2.convexHull(cnt)
    # hull = np.asarray(hull)

    length = len(hull)-1
    # print(length)
    dis_list = []
    for k in range(length):
        dis = np.linalg.norm(hull[k] - hull[k + 1])
        if dis < 100:
            dis_list.append(hull[k])
            length -= 1
        # new_hull = np.delete(hull, k + 1, axis=0)
        # print(dis)

        # dis_list.append(dis)
    dis_list = np.asarray(dis_list)

    temp = np.zeros(img.shape, np.uint8)        # 创建一个黑色的背景图
    cv2.polylines(temp, [dis_list], True, (255, 255, 2), 2)
    # cv2.polylines(temp, [s_dis_list], True, (255, 5, 255), 2)
    # cv2.polylines(img, [hull], True, (0, 255, 0), 2)
    # 显示图片
    cv2.imshow('line', temp)
    cv2.waitKey()
运行结果及报错内容

img

我的解答思路和尝试过的方法
我想要达到的结果

如何能让两个轮廓在一起显示

  • 写回答

2条回答 默认 最新

  • 技术专家团-Bamboo 2021-12-01 12:32
    关注
    lst=[]
    for j in contours:
        # 显示图片
        lst.append(temp)
    both = np.hstack(lst)
    cv2.imshow('line', both)
    cv2.waitKey()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月8日
  • 已采纳回答 7月31日
  • 创建了问题 12月1日

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!