验证码图片二值化去噪

package main

import (
	"image"

	"gocv.io/x/gocv"
)

func main() {
	mat := gocv.IMRead("2.png", gocv.IMReadColor)
	defer mat.Close()

	bilatera := gocv.NewMat()
	defer bilatera.Close()

	gocv.BilateralFilter(mat, &bilatera, 0, 100, 15)
	gocv.MedianBlur(bilatera, &mat, 5)

	gocv.CvtColor(mat, &mat, gocv.ColorBGRToGray)

	threshold := gocv.NewMat()
	defer threshold.Close()

	gocv.Threshold(mat, &threshold, 200, 255, gocv.ThresholdBinaryInv)

	kernel1 := gocv.GetStructuringElement(gocv.MorphRect, image.Pt(5, 4))
	kernel2 := gocv.GetStructuringElement(gocv.MorphRect, image.Pt(4, 5))
	kernel3 := gocv.GetStructuringElement(gocv.MorphRect, image.Pt(6, 6))
	gocv.MorphologyEx(threshold, &threshold, gocv.MorphOpen, kernel1)
	gocv.MorphologyEx(threshold, &threshold, gocv.MorphOpen, kernel2)
	gocv.MorphologyEx(threshold, &threshold, gocv.MorphClose, kernel3)

	gocv.BitwiseNot(threshold, &threshold)

	gocv.BilateralFilter(threshold, &mat, 0, 100, 15)

	ret := gocv.NewMat()
	defer ret.Close()

	gocv.MedianBlur(mat, &ret, 5)
	gocv.IMWrite("/tmp/ret.png", ret)
}

原图
转换后

原图内容识别可以直接 通过:

https://github.com/otiai10/ocrserver

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值