python3+openCV 获取图片中文本区域的最小外接矩形实例


Posted in Python onJune 02, 2020

我就废话不多说了,大家还是直接看代码吧!

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)

有哪路朋友路过,帮一下忙,给指点一二,多谢朋友

附实验问题截图:

python3+openCV 获取图片中文本区域的最小外接矩形实例

补充知识: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);
}

以上这篇python3+openCV 获取图片中文本区域的最小外接矩形实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用Python开发windows GUI程序入门实例
Oct 23 Python
Python中使用SAX解析xml实例
Nov 21 Python
Python语言实现百度语音识别API的使用实例
Dec 13 Python
浅谈flask中的before_request与after_request
Jan 20 Python
python实现人人自动回复、抢沙发功能
Jun 08 Python
python得到单词模式的示例
Oct 15 Python
django+echart绘制曲线图的方法示例
Nov 26 Python
Python3实现的判断回文链表算法示例
Mar 08 Python
django框架实现一次性上传多个文件功能示例【批量上传】
Jun 19 Python
python 用所有标点符号分隔句子的示例
Jul 15 Python
用Pytorch训练CNN(数据集MNIST,使用GPU的方法)
Aug 19 Python
Opencv实现二维直方图的计算及绘制
Jul 21 Python
python编写一个会算账的脚本的示例代码
Jun 02 #Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
Jun 02 #Python
什么是Python中的顺序表
Jun 02 #Python
opencv 实现特定颜色线条提取与定位操作
Jun 02 #Python
Python爬虫入门有哪些基础知识点
Jun 02 #Python
Python实现进度条和时间预估的示例代码
Jun 02 #Python
python爬虫容易学吗
Jun 02 #Python
You might like
织梦模板标记简介
2007/03/11 PHP
通俗易懂的php防注入代码
2010/04/07 PHP
PHPEXCEL 使用小记
2013/01/06 PHP
基于CI框架的微信网页授权库示例
2016/11/25 PHP
PHP 实现人民币小写转换成大写的方法及大小写转换函数
2017/11/17 PHP
php记录搜索引擎爬行记录的实现代码
2018/03/02 PHP
php探针使用原理和技巧讲解
2019/09/17 PHP
原生js拖拽(第一课 未兼容)拖拽思路
2013/03/29 Javascript
jQuery判断div随滚动条滚动到一定位置后停止
2014/04/02 Javascript
fixedBox固定div漂浮代码支持ie6以上大部分主流浏览器
2014/06/26 Javascript
Javascript控制div属性动态变化实例分析
2015/10/08 Javascript
使用JavaScript判断手机浏览器是横屏还是竖屏问题
2016/08/02 Javascript
Bootstrap导航条的使用和理解3
2016/12/14 Javascript
jQuery插件ContextMenu自定义图标
2017/03/15 Javascript
JS移动端/H5同时选择多张图片上传并使用canvas压缩图片
2017/06/20 Javascript
jQuery+ajax读取json数据并按照价格排序示例
2018/03/28 jQuery
微信小程序中显示倒计时代码实例
2019/05/09 Javascript
jquery实现拖拽添加元素功能
2020/12/01 jQuery
[53:15]Newbee vs Pain 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
[01:38:19]夜魇凡尔赛茶话会 第五期
2021/03/11 DOTA
python数据类型_字符串常用操作(详解)
2017/05/30 Python
简单谈谈python中的lambda表达式
2018/01/19 Python
Python使用functools实现注解同步方法
2018/02/06 Python
简单实现Python爬取网络图片
2018/04/01 Python
Pandas中把dataframe转成array的方法
2018/04/13 Python
基于python神经卷积网络的人脸识别
2018/05/24 Python
和孩子一起学习python之变量命名规则
2018/05/27 Python
解决python "No module named pip" 的问题
2018/10/13 Python
Python Lambda函数使用总结详解
2019/12/11 Python
解决import tensorflow导致jupyter内核死亡的问题
2021/02/06 Python
HTML5输入框下拉菜单功能的示例代码
2020/09/08 HTML / CSS
财务学生的职业生涯发展
2014/02/11 职场文书
党校培训自我鉴定范文
2014/04/10 职场文书
2014年乡镇安全生产工作总结
2014/12/02 职场文书
医疗纠纷调解协议书
2015/08/06 职场文书
公司岗位说明书
2015/10/08 职场文书