(信号灯二)三格子信号灯三等分截取

本文详细介绍了如何实现一个三格子信号灯的三等分截取功能,包括构建代码的步骤、代码执行过程以及最终得到的结果展示。
摘要由CSDN通过智能技术生成

构建代码

import matplotlib.pyplot as plt
import matplotlib.image as mpimg
import cv2
# 切割
def get_three_box(img_shape):
    # 横向三座信号灯
    if img_shape[0] > 2*img_shape[1]:
        a = (img_shape[1], img_shape[0]) # 横向尺寸, 纵向尺寸
        circle_point = (int(a[0]/2),int(a[1]/2))
        x_inch = int(a[0]*0.45)
        y_inch = int(a[1]*0.14)
        dy = int(a[1]*0.015)
        box_middle = (circle_point[0]-x_inch, circle_point[1]-y_inch+2*dy, circle_point[0]+x_inch, circle_point[1]+y_inch+2*dy)
        box_up = (box_middle[0], 4*dy, box_middle[2], box_middle[1])
        box_down = (box_middle[0], box_middle[3], box_middle[2], a[1]-4*dy)
        
        return box_up, box_middle, box_down
    # 竖向三座信号灯
    else:
        a = (img_shape[1], img_shape[0]) # 横向尺寸, 纵向尺寸
        circle_point = (int(a[0]/2),int(a[1]/2))
        x_inch = int(a[0]*0.14)
        y_inch = int(a[1]*0.45)
        dx = int(a[0]*0.015)
        box_middle = (circle_point[0]-x_inch+2*dx, circle_point[1]-y_inch, circle_point[0]+x_inch+2*dx, circle_point[1]+y_inch)
        box_up = (6*dx, box_middle[1], box_middle[0], box_middle[3])
        box_down = (box_middle[2], box_middle[1], a[0]-6*dx, box_middle[3])
        
        return box_up, box_middle, box_down
# 截取
def cut_three_box_from_tl(img):
    box_up, box_middle, box_down = get_three_box(img.shape)
    img_up = img[box_up[1]:box_up[3], box_up[0]:box_up[2]]
    img_middle = img[box_middle[1]:box_middle[3], box_middle[0]:box_middle[2]]
    img_down = img[box_down[1]:box_down[3], box_down[0]:box_down[2]]
    return img_up, img_middle, img_down

执行代码

img = mpimg.imread('./test_images/114.jpg')
img_up, img_middle, img_down = cut_three_box_from_tl(img)
fig = plt.gcf()
fig.set_size_inches(6, 5)

plt.subplot(221)
plt.imshow(img)
plt.axis('off')
plt.title('original_img1')

plt.subplot(222)
plt.imshow(img_up)
plt.axis('off')
plt.title('img_up')

plt.subplot(223)
plt.imshow(img_middle)
plt.axis('off')
plt.title('img_middle')

plt.subplot(224)
plt.imshow(img_down)
plt.axis('off')
plt.title('img_down')

结果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值