C# OpenCvSharp 基于直线检测的文本图像倾斜校正

效果

项目

代码

复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;

namespace OpenCvSharp_基于直线检测的文本图像倾斜校正
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            string path = "1.jpg";

            pictureBox1.Image = new Bitmap(path);
            Mat mat = new Mat(path);

            Mat gray = new Mat(path, ImreadModes.Grayscale);

            Mat binary = new Mat();
            Cv2.Threshold(gray, binary, 50, 255, ThresholdTypes.BinaryInv);

            Mat element = Cv2.GetStructuringElement(MorphShapes.Rect, new OpenCvSharp.Size(7, 1));

            Mat dilation = new Mat();
            Cv2.Dilate(binary, dilation, element);

            Mat cannyDst = new Mat();
            Cv2.Canny(dilation, cannyDst, 150, 200);

            Mat houghDst = new Mat();
            mat.CopyTo(houghDst);

            LineSegmentPolar[] lineing = Cv2.HoughLines(cannyDst, 1, Cv2.PI / 180, 110, 0, 0);
            Scalar color = new Scalar(0, 255, 255);

            double meanAngle = 0.0;
            int numCnt = 0;

            for (int i = 0; i < lineing.Length; i++)
            {
                double rho = lineing[i].Rho;//线长
                double theta = lineing[i].Theta;//角度

                OpenCvSharp.Point pt1 = new OpenCvSharp.Point();
                OpenCvSharp.Point pt2 = new OpenCvSharp.Point();
                double a = Math.Cos(theta);
                double b = Math.Sin(theta);
                double x0 = a * rho, y0 = b * rho;

                pt1.X = (int)Math.Round(x0 + 600 * (-b));
                pt1.Y = (int)Math.Round(y0 + 600 * a);
                pt2.X = (int)Math.Round(x0 - 600 * (-b));
                pt2.Y = (int)Math.Round(y0 - 600 * a);

                Cv2.Line(houghDst, pt1, pt2, color, 1, LineTypes.Link4);

                theta = theta * 180 / Cv2.PI - 90;

                meanAngle += theta;
                numCnt++;
            }
            //Cv2.ImShow("houghDst", houghDst);

            meanAngle /= numCnt;
            Point2f center = new Point2f(mat.Cols / 2.0f, mat.Rows / 2.0f);

            Mat warpDst = new Mat();
            Mat rot_mat = Cv2.GetRotationMatrix2D(center, meanAngle, 1.0);
            OpenCvSharp.Size dst_sz = new OpenCvSharp.Size(mat.Cols, mat.Rows);

            Cv2.WarpAffine(mat, warpDst, rot_mat, dst_sz);

            pictureBox2.Image = new Bitmap(warpDst.ToMemoryStream());
        }
    }
}

Demo下载

相关推荐
张人玉4 小时前
TCP 的三次握手和四次挥手
网络·tcp/ip·c#
曹牧4 小时前
C#:三元运算符
开发语言·c#
m0_748248027 小时前
C++与C#布尔类型深度解析:从语言设计到跨平台互操作
c++·stm32·c#
LeonDL1688 小时前
【通用视觉框架】基于C#+VisionPro开发的视觉框架软件,全套源码,开箱即用
人工智能·c#·visionpro·通用视觉框架·机器视觉框架·视觉框架软件·机器视觉软件
一抓掉一大把9 小时前
RuoYi .net-实现商城秒杀下单(redis,rabbitmq)
redis·mysql·c#·rabbitmq·.net
睡前要喝豆奶粉10 小时前
在.NET Core Web Api中使用阿里云OSS
阿里云·c#·.netcore
缺点内向16 小时前
C#: 高效移动与删除Excel工作表
开发语言·c#·.net·excel
yue00818 小时前
C# 分部类读取学生信息
开发语言·c#
聪明努力的积极向上19 小时前
【C#】事件简单解析
开发语言·c#
qq_124987075320 小时前
基于C#的贵州省黔北地区乡村避暑生活共享平台设计与实现(源码+论文+部署+安装)
c#·毕业设计·asp.net·生活