您的位置:首页 > 科技 > 能源 > 互联网公司估值达到一定基数后就不会再增长_上海红蚂蚁装潢设计有限公司官网_合肥seo网络营销推广_网络营销首先要进行

互联网公司估值达到一定基数后就不会再增长_上海红蚂蚁装潢设计有限公司官网_合肥seo网络营销推广_网络营销首先要进行

2024/12/23 5:18:54 来源:https://blog.csdn.net/UruseiBest/article/details/141188347  浏览:    关键词:互联网公司估值达到一定基数后就不会再增长_上海红蚂蚁装潢设计有限公司官网_合肥seo网络营销推广_网络营销首先要进行
互联网公司估值达到一定基数后就不会再增长_上海红蚂蚁装潢设计有限公司官网_合肥seo网络营销推广_网络营销首先要进行

  版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。

教程VB.net版本请访问:EmguCV学习笔记 VB.Net 目录-CSDN博客

教程C#版本请访问:EmguCV学习笔记 C# 目录-CSDN博客

笔者的博客网址:https://blog.csdn.net/uruseibest

教程配套文件及相关说明以及如何获得pdf教程和代码,请移步:EmguCV学习笔记

学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客

 学习C#知识,请移步:C# 教程 目录_c#教程目录-CSDN博客

12.1 二维码解析

QRCodeDetector类是Emgu CV库中用于检测和解码二维码的类。

常用方法:

1、Detect方法:检测图像中的QR二维码

Public Function Detect (input As IInputArray, points As IOutputArray) As Boolean

参数说明:

  1. Input:包含二维码的输入图像。
  2. points:存储QR二维码位置信息。这是一个VectorOfPoint对象。

该方法执行成功,将返回二维码四个顶点坐标。

【代码位置:frmChapter12】Button1_Click

    '二维码检测

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click

        Dim qr As New QRCodeDetector()

        '需要测试的图像文件

        Dim m As New Mat("C:\learnEmgucv\qrcode1.png", ImreadModes.Color)

        Dim vp As New VectorOfPoint

        '返回二维码四个顶点坐标

        If qr.Detect(m, vp) = False Then

            Exit Sub

        End If

        CvInvoke.Line(m, vp(0), vp(1), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(m, vp(1), vp(2), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(m, vp(2), vp(3), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(m, vp(3), vp(0), New MCvScalar(255, 0, 0), 2)

        ImageBox1.Image = m

End Sub

输出结果如下图所示:

图12-1 获得二维码坐标位置

2、Decode方法:用于解码获得的QR二维码的内容。

Public Function Decode (image As IInputArray, points As IInputArray, Optional straightQrcode As IOutputArray = Nothing) As String

  1. Image:包含二维码的输入图像。
  2. points:存储QR二维码位置信息。
  3. straightQrcode:经过校正后的二维码图像。

该法方法执行成功,将返回二维码的文字内容。

【代码位置:frmChapter12】Button2_Click

   '二维码识别

    Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click

        Dim qr As New QRCodeDetector()

        '需要测试的图像文件

        Dim m As New Mat("C:\learnEmgucv\qrcode2.png", ImreadModes.Color)

        Dim vp As New VectorOfPoint

        '返回二维码四个顶点坐标

        If qr.Detect(m, vp) = False Then

            Exit Sub

        End If

        Dim mout1 As Mat = m.Clone

        CvInvoke.Line(mout1, vp(0), vp(1), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(mout1, vp(1), vp(2), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(mout1, vp(2), vp(3), New MCvScalar(255, 0, 0), 2)

        CvInvoke.Line(mout1, vp(3), vp(0), New MCvScalar(255, 0, 0), 2)

        ImageBox1.Image = mout1

        Dim strout As String

        Dim mout2 As New Mat

        strout = qr.Decode(m, vp, mout2)

        ImageBox2.Image = mout2

        MessageBox.Show(strout)

End Sub

输出结果如下图所示:

 

图12-2 获得二维码信息

QRCodeDetector类也提供了同时对多个二维码检测和解码的方法,但是经过测试,效果不好。可以使用WeChatQRCode类来代替(请参看12.2节【WeChatQRCode】)。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com