使用OpenCV进行简单的图像分割

振华OPPO 发表于 2022/02/11 17:52:10 2022/02/11
【摘要】 场景描述给定任意一张图像,从中截取出你需要的区域,并且以指定的大小显示出来。比如我们想获得下面这张图像中的老K,并且竖直显示。实现代码看起来比较困难,但是用cv2库,实现起来其实只有9行代码。首先我们设置下输出图片的宽width为250,高height为350。然后读取我们的图片,就是上面这张图。定义目标区域的四个点坐标,分别为:左上、右上、左下、右下。可以使用画图工具打开原图,然后将鼠标放...
场景描述

给定任意一张图像,从中截取出你需要的区域,并且以指定的大小显示出来。比如我们想获得下面这张图像中的老K,并且竖直显示。
在这里插入图片描述

实现代码

看起来比较困难,但是用cv2库,实现起来其实只有9行代码。

  • 首先我们设置下输出图片的宽width为250,高height为350。
  • 然后读取我们的图片,就是上面这张图。
  • 定义目标区域的四个点坐标,分别为:左上、右上、左下、右下。可以使用画图工具打开原图,然后将鼠标放置在分割的四个点上,即可获取到坐标信息。
  • pst2是输出图片在图片框中的位置,选择平铺即可,固定写法。
  • 使用库函数实现透视变换,感兴趣的可以深入了解下原理。
  • 输出并且显示图片。
import cv2
import numpy as np
width,height=250,350
img=cv2.imread("Resources/poker.jpg")
pst1=np.float32([[734,185],[1101,266],[621,679],[1030,789]])
pst2=np.float32([[0,0],[width,0],[0,height],[width,height]])
matrix=cv2.getPerspectiveTransform(pst1,pst2)
imgOutput=cv2.warpPerspective(img,matrix,(width,height))

cv2.imshow("Image",img)
cv2.imshow("Output",imgOutput)
cv2.waitKey(0)
实现效果

左侧就是我们分割的图像,右侧是原图。可以看到分割的图像非常光滑,即使在原图中,它是侧身平躺在桌面上了,进行图像处理后竖直地呈现在我们面前。
在这里插入图片描述

无所谓一定要读硕士、读博士,只要找到合适自己的事情和位置就可以。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区),文章链接,文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:cloudbbs@huaweicloud.com进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。