参考文章链接:
1.https://blog.csdn.net/kobesdu/article/details/8142068
2.https://blog.csdn.net/fjssharpsword/article/details/52651845
一、识别图片的步骤顺序如下:
1.先使用java代码对图片的亮度、对比度、饱和度进行调整
2.对图片进行的灰度化和二值化以便更好的识别
3.使用OCR库对处理后的文件进行识别
二、图片的分类以及不同的处理办法
1.简单图片
图片的背景颜色比较单一的,例如红绿灯的倒计时。在图片预处理的时候只需要保留图片中的红色、绿色以及黄色即可
颜色比较单一,代码思路就是读取图片后获取各个像素点的RGB数值,然后根据下面的阈值进行颜色替换就可以,使用的OCR白底黑字识别较高,所以替换时需要保留的替换成黑色,其余颜色全部替换白色即可。
检测所用的阈值如下
其中ThR=0.4;ThG=0.3,ThB=0.4,thy=0.85
这种方式,阈值在这个空间里很容易地找到。然而,出现了一些问题:这个标准化的空间,因为照度低(低RGB值),该转换是不稳定的,并在接近零的值,噪声被放大。
2.复杂背景图片
图片的背景颜色可能是一种或多种的情况。在图片预处理的时候则需要对图片进行一系列调整,测试代码如下,测试代码中的参数可能需要调整。
//读取原图片转化为BufferedImage对象
public static BufferedImage file2img(String imgpath) {
try {
BufferedImage bufferedImage=ImageIO.read(new File(imgpath));
return bufferedImage;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
//调整图片对比度、亮度和饱和度
public static BufferedImage changeImage(BufferedImage src, BufferedImage dest,float contrast,float brightness){
int width = src.getWidth();
int height = src.getHeight();
if ( dest == null )
dest = creatCompatibleDestImage( src, null );