python3+openCV 获取图片中文本区域的最小外接矩形实例
作者:高胜超 时间:2022-03-16 00:57:11
我就废话不多说了,大家还是直接看代码吧!
print("thresh =",thresh)
coords = np.column_stack(np.where(thresh > 0))//获取thresh二值灰度图片中的白色文字区域的点
print("coords =",coords)
min_rect = cv2.minAreaRect(coords)//由点集获取最小矩形(包含中心坐标点、宽和高、偏转角度)
print("min_rec =",min_rect)
box = cv2.boxPoints(min_rect)//获取最小矩形的4个顶点坐标。
但是通过一下这个绘制矩形函数,画出来上述的最小矩形与文字区域偏差很大,但是获取到的偏转角度是对的。
不明白他们什么关系啊?
# 根据四点画原矩形
def drawRect(img, pt1, pt2, pt3, pt4, color, lineWidth):
cv2.line(img, tuple(pt1), tuple(pt2), color, lineWidth)
cv2.line(img, tuple(pt2), tuple(pt3), color, lineWidth)
cv2.line(img, tuple(pt3), tuple(pt4), color, lineWidth)
cv2.line(img, tuple(pt1), tuple(pt4), color, lineWidth)
有哪路朋友路过,帮一下忙,给指点一二,多谢朋友
附实验问题截图:
补充知识:opencv2 3.2 类中实现提取蓝天颜色
我就废话不多说了,大家还是直接看代码吧!
#include<iostream>
#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
using namespace std;
using namespace cv;
class ColorDetector{
private:
int maxDist; //最小差距
Vec3b target ; //目标颜色
Mat result;
public:
ColorDetector():maxDist(100),target(0,0,0)
{
}
void setColorDistanceThreshold(int distance) //设置颜色差距的阈值
{
if(distance<0)
distance=0;
maxDist=distance;
}
int getColorDistanceThreshold() const //取得颜色差距的阈值
{
return maxDist;
}
void setTargetColor(uchar blue,uchar green,uchar red) //设置需要检测的颜色
{
target=Vec3b(blue,green,red);
}
void setTargetColor(Vec3b color)
{
target=color;
}
Vec3b getTargetColor() const
{
return target;
}
Mat process(const cv::Mat &image) ;
int getDistance(const Vec3b &color) ;
};
Mat ColorDetector::process(const cv::Mat &image)
{
result.create(image.rows,image.cols,CV_8U);
Mat_<Vec3b>::const_iterator it=image.begin<Vec3b>();
Mat_<Vec3b>::const_iterator itend=image.end<Vec3b>();
Mat_<uchar>::iterator itout=result.begin<uchar>();
for ( ; it!= itend; ++it, ++itout)
{
if (getDistance(*it)<maxDist)
{
*itout=255;
}
else
{
*itout=0;
}
}
return result;
}
int ColorDetector::getDistance(const Vec3b &color)
{
return abs(color[0]-target[0])+
abs(color[1]-target[1])+
abs(color[2]-target[2]);
}
void main()
{
ColorDetector cdetect;
Mat img=imread("C:\\Users\\Administrator\\Desktop\\工作\\testp\\boldt.jpg");
if(img.empty())
return;
cdetect.setTargetColor(230,190,130);
imshow("original",img);
imshow("result",cdetect.process(img));
waitKey(0);
}
来源:https://blog.csdn.net/u012891980/article/details/89054289
标签:python3,openCV,图片,矩形
0
投稿
猜你喜欢
python集合的新增元素方法整理
2022-10-13 02:45:28
python pygame实现挡板弹球游戏
2022-11-25 17:50:42
ECMAScript6函数默认参数
2024-05-13 09:18:24
python中return如何写
2023-11-17 21:44:56
python 的 scapy库,实现网卡收发包的例子
2021-08-08 17:25:05
丢失的数据忘记备份的处理方法[图文]第1/2页
2024-01-18 22:18:41
npm qs模块使用详解
2024-04-25 13:11:14
Python详解如何动态给对象增加属性和方法
2022-11-14 23:00:46
Python可视化单词统计词频统计中文分词的实现步骤
2023-10-24 17:16:49
某大型网络公司应聘时的笔试题目附答案
2023-11-15 02:01:21
解决jupyter加载文件失败的问题
2022-07-21 19:17:05
oracle 函数
2010-07-23 13:06:00
Python编程实现线性回归和批量梯度下降法代码实例
2021-10-13 07:33:27
python中使用urllib2伪造HTTP报头的2个方法
2022-10-19 07:05:06
django-crontab实现服务端的定时任务的示例代码
2021-02-13 05:15:06
pytorch获取vgg16-feature层输出的例子
2021-04-16 20:56:47
最简洁的asp多重查询的解决方案
2011-04-15 10:50:00
python中遍历文件的3个方法
2022-10-21 08:41:07
Mysql存储过程学习笔记--建立简单的存储过程
2024-01-23 14:41:21
python-opencv获取二值图像轮廓及中心点坐标的代码
2021-03-10 01:12:02