验证码图片二值化问题 BitmapData 怎么解决

对不起,这算是一篇求助啦,先上图,防止不清楚,放大了一点,下面是图片,上面是没有二值化的,下面是二值化之后的,我其实不懂什么是二值化啦,就是一定范围变黑,变白

问题:

为什么我的结果上面还是有很多彩色的小点点呢?原来都是没有的……

谁能帮我看看代码怎么改!谢谢大牛们帮忙!!

                Bitmap bit1 = new Bitmap(bit);

                Rectangle rect1 = new Rectangle(0, 0, bit1.Width, bit1.Height);
                BitmapData bitd = bit1.LockBits(rect1, ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);  

                IntPtr srcPtr = bitd.Scan0;

                int scanWidth = bitd.Width * 3;
                int src_bytes = scanWidth * bitd.Height;
                byte[] srcRGBValues = new byte[src_bytes];

                Marshal.Copy(srcPtr, srcRGBValues, 0, src_bytes);

                    //灰度化处理
                    int m = 0, i = 0, j = 0;  //m表示行,j表示列
                    int k = 0;

                    for (i = 0; i < bit.Height; i++)  //只获取图片的rows行像素值
                    {
                        for (j = 0; j < bit.Width; j++)
                        {
                            //只处理每行中图像像素数据,舍弃未用空间
                            //注意位图结构中RGB按BGR的顺序存储
                            k = 3 * j;
                            var grays = Convert.ToInt16(srcRGBValues[i * scanWidth + k + 2]) +
                                        Convert.ToInt16(srcRGBValues[i * scanWidth + k + 1]) +
                                        Convert.ToInt16(srcRGBValues[i * scanWidth + k + 0]);
                            if (grays >= 382)
                            {
                                srcRGBValues[i * scanWidth + k + 2] = Convert.ToByte(255);
                                srcRGBValues[i * scanWidth + k + 1] = Convert.ToByte(255);
                                srcRGBValues[i * scanWidth + k + 0] = Convert.ToByte(255);
                            }
                            else
                            {
                                srcRGBValues[i * scanWidth + k + 2] = Convert.ToByte(0);
                                srcRGBValues[i * scanWidth + k + 1] = Convert.ToByte(0);
                                srcRGBValues[i * scanWidth + k + 0] = Convert.ToByte(0);

                            }
                        }
                        m++;
                    }
                Marshal.Copy(srcRGBValues, 0, srcPtr, src_bytes);
                bit1.UnlockBits(bitd);
                Image image1 = bit1;
时间: 2024-10-13 02:41:18

验证码图片二值化问题 BitmapData 怎么解决的相关文章

C#图片灰度处理(位深度24→位深度8)、C#图片二值化处理(位深度8→位深度1)

C#图片灰度处理(位深度24→位深度8) #region 灰度处理 /// <summary> /// 将源图像灰度化,并转化为8位灰度图像. /// </summary> /// <param name="original"> 源图像. </param> /// <returns> 8位灰度图像. </returns> public static Bitmap RgbToGrayScale(Bitmap orig

Ubuntu 14.04 下使用 OpenCV 图片二值化处理

参考: OpenCV - Ubuntu 14.04 64 bit 图片二值化工具 Ubuntu 14.04 下使用 OpenCV 图片二值化处理 TBD. 原文地址:https://www.cnblogs.com/qq952693358/p/8996719.html

python图片二值化提高识别率

import cv2from PIL import Imagefrom pytesseract import pytesseractfrom PIL import ImageEnhanceimport reimport string def createFile(filePath,newFilePath): img = Image.open(filePath) # 模式L”为灰色图像,它的每个像素用8个bit表示,0表示黑,255表示白,其他数字表示不同的灰度. Img = img.conver

c#实现图片二值化例子(黑白效果)

C#将图片2值化示例代码,原图及二值化后的图片如下: 原图: 二值化后的图像: 实现代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 7

机器学习进阶-项目实战-信用卡数字识别 1.cv2.findContour(找出轮廓) 2.cv2.boudingRect(轮廓外接矩阵位置) 3.cv2.threshold(图片二值化操作) 4.cv2.MORPH_TOPHAT(礼帽运算突出线条) 5.cv2.MORPH_CLOSE(闭运算图片内部膨胀) 6. cv2.resize(改变图像大小) 7.cv2.putText(在图片上放上文本)

7. cv2.putText(img, text, loc, text_font, font_scale, color, linestick) # 参数说明:img表示输入图片,text表示需要填写的文本str格式,loc表示文本在图中的位置,font_size可以使用cv2.FONT_HERSHEY_SIMPLEX, font_scale表示文本的规格,color表示文本颜色,linestick表示线条大小 信用卡数字识别: 信用卡      数字模板涉及到的内容:主要是采用模板匹配的思想 思

基于Java对图片进行二值化处理

一直以来对Java的图形处理能力表无力,但好像又不是那么一回事,之前用PHP做过一些应用,涉及到验证码的识别,其中有个图片二值化的步骤,今天换成Java来实现下 在java的扩展包javax.imageio中为我们提供了一个类叫ImageIO,这个类提供了一些执行简单编码和解码的静态便捷方法,具体说明大家可以翻下API看看 下面来说下关于图片二值化的原理: 1.首先要获取每个像素点的灰度值. 2.定义一个阀值. 3.将每个像素点的灰度值和它周围的8个像素点的灰度值相叠加再除以9,然后和阀值进行比

[Python]图像二值化

https://blog.csdn.net/qq_35531549/article/details/96134760 # 识别前处理# 图片二值化from PIL import Imageimport osos.chdir('D:\OCR')img = Image.open('test.png') # 模式L”为灰色图像,它的每个像素用8个bit表示,0表示黑,255表示白,其他数字表示不同的灰度.Img = img.convert('L')Img.save("test1.png")

一种超级快速的图像二值化技术

在计算机视觉中,对图像进行二值化恐怕是最常见的操作了.为了检测目标,可能需要对每一帧图像的每一个像素点进行运算.如果能提升二值化的速度,那么,你的算法的效率就会大大的提高.本文,将介绍一种超级快速的图像二值化技术. 要解决的问题: 如上图所示,需要把彩色图像中, (1) R通道介于(smoevalue1, somevalue2)(2) G通道介于(somevalue3, somevalue4)(3) B通道介于(somevalue5, somevalue6)当图像中某个像素点同时满足上面3个条件

atitit.验证码识别step4--------图形二值化 灰度化

atitit.验证码识别step4--------图形二值化 灰度化 1. 常见二值化的方法原理总结 1 1.1. 方法一:该方法非常简单,对RGB彩色图像灰度化以后,扫描图像的每个像素值,值小于127的将像素值设为0(黑色),值大于等于127的像素值设为255(白色). 1 1.2. 方法二:最常见的二值处理方法是计算像素的平均值K, 2 1.3. 方法三:使用直方图方法来寻找二值化阈值, 2 1.4. 方法四:使用近似一维Means方法寻找二值化阈值,(推荐) 3 2. 使用类库imagei