使用OpenCV进行简单的图像分割
【摘要】 场景描述给定任意一张图像,从中截取出你需要的区域,并且以指定的大小显示出来。比如我们想获得下面这张图像中的老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)