当前位置: 首页 > news >正文

探索机器视觉:从工业相机采集到模板匹配

机器视觉,OpenCV,Qt,工业相机采集,图像采集,图像处理,卡尺工具,找线,找圆,颜色检测,模板匹配,形状匹配,海康工业相机采集+基于形状的模板匹配界面,提前说明,形状匹配算法封装成dll直接调用的,其他都是源码,是不错的学习资料,程序资料

在当今的工业自动化和智能制造领域,机器视觉技术就像是一双敏锐的“眼睛”,能让机器像人类一样“看”懂周围的世界。今天咱们就来聊聊机器视觉里的那些事儿,涉及到 OpenCV、Qt、工业相机采集以及各种实用的图像处理工具。

工业相机采集与图像获取

工业相机采集是机器视觉系统的第一步,就好比我们人类睁开眼睛去接收外界的信息。这里我们选用海康工业相机,它在工业领域可是相当受欢迎。下面是一段简单的 Python 代码示例,用于海康工业相机的图像采集:

import cv2 from hikvisionapi import Client # 连接到海康相机 cam = Client('http://192.168.1.100', 'admin', 'password') # 获取图像 response = cam.Streaming.channels[101].picture(method='get', type='opaque_data') with open('temp.jpg', 'wb') as f: f.write(response.content) # 使用 OpenCV 读取图像 image = cv2.imread('temp.jpg') cv2.imshow('Captured Image', image) cv2.waitKey(0) cv2.destroyAllWindows()

代码分析

这段代码首先通过hikvisionapi库连接到海康相机,这里需要填写相机的 IP 地址、用户名和密码。接着,我们从相机的指定通道获取图像数据,并将其保存为temp.jpg文件。最后,使用 OpenCV 的imread函数读取该图像,并通过imshow函数显示出来。

图像处理与工具应用

采集到图像后,就需要对其进行处理和分析。这里介绍几种常见的图像处理工具。

卡尺工具与找线

卡尺工具可以帮助我们测量图像中物体的尺寸,而找线则是确定图像中线条的位置和方向。以下是使用 OpenCV 进行找线的示例代码:

import cv2 import numpy as np # 读取图像 image = cv2.imread('temp.jpg', 0) # 边缘检测 edges = cv2.Canny(image, 50, 150) # 霍夫变换找线 lines = cv2.HoughLinesP(edges, 1, np.pi/180, threshold=50, minLineLength=50, maxLineGap=10) # 绘制检测到的线 if lines is not None: for line in lines: x1, y1, x2, y2 = line[0] cv2.line(image, (x1, y1), (x2, y2), (0, 255, 0), 2) cv2.imshow('Lines Detected', image) cv2.waitKey(0) cv2.destroyAllWindows()

代码分析

首先,我们以灰度模式读取图像。然后使用 Canny 边缘检测算法提取图像的边缘。接着,通过霍夫变换(HoughLinesP)在边缘图像中检测直线。最后,将检测到的直线绘制在原始图像上并显示出来。

找圆与颜色检测

找圆可以帮助我们定位图像中的圆形物体,而颜色检测则可以根据颜色特征识别特定的物体。以下是一个简单的颜色检测示例代码:

import cv2 import numpy as np # 读取图像 image = cv2.imread('temp.jpg') # 转换到 HSV 颜色空间 hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV) # 定义颜色范围(这里以红色为例) lower_red = np.array([0, 100, 100]) upper_red = np.array([10, 255, 255]) lower_red2 = np.array([160, 100, 100]) upper_red2 = np.array([180, 255, 255]) # 创建掩码 mask1 = cv2.inRange(hsv, lower_red, upper_red) mask2 = cv2.inRange(hsv, lower_red2, upper_red2) mask = cv2.bitwise_or(mask1, mask2) # 应用掩码 result = cv2.bitwise_and(image, image, mask=mask) cv2.imshow('Color Detection', result) cv2.waitKey(0) cv2.destroyAllWindows()

代码分析

我们先将图像从 BGR 颜色空间转换到 HSV 颜色空间,因为 HSV 更适合进行颜色检测。然后定义红色的颜色范围,创建两个掩码(因为红色在 HSV 空间中不连续),并将它们合并。最后,通过按位与操作将掩码应用到原始图像上,得到只包含红色部分的图像。

模板匹配与形状匹配

模板匹配和形状匹配是机器视觉中常用的目标识别方法。这里我们主要介绍基于形状的模板匹配,并且形状匹配算法已经封装成 DLL 直接调用。

基于形状的模板匹配界面

我们使用 Qt 来创建一个基于形状的模板匹配界面。以下是一个简单的 Qt 界面代码示例:

import sys from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QVBoxLayout import cv2 import numpy as np class TemplateMatchingApp(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # 读取模板和图像 template = cv2.imread('template.jpg', 0) image = cv2.imread('image.jpg', 0) # 进行模板匹配 result = cv2.matchTemplate(image, template, cv2.TM_CCOEFF_NORMED) min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result) top_left = max_loc h, w = template.shape # 在图像上绘制匹配结果 bottom_right = (top_left[0] + w, top_left[1] + h) cv2.rectangle(image, top_left, bottom_right, 255, 2) # 将 OpenCV 图像转换为 Qt 图像 height, width = image.shape bytesPerLine = width qImg = QImage(image.data, width, height, bytesPerLine, QImage.Format_Grayscale8) # 创建 QLabel 显示图像 label = QLabel(self) pixmap = QPixmap.fromImage(qImg) label.setPixmap(pixmap) # 设置布局 layout = QVBoxLayout() layout.addWidget(label) self.setLayout(layout) self.setWindowTitle('Template Matching') self.show() if __name__ == '__main__': app = QApplication(sys.argv) ex = TemplateMatchingApp() sys.exit(app.exec_())

代码分析

在这个 Qt 界面代码中,我们首先读取模板图像和待匹配的图像。然后使用 OpenCV 的matchTemplate函数进行模板匹配,找到匹配度最高的位置。接着在原始图像上绘制矩形框标记匹配结果。最后,将 OpenCV 图像转换为 Qt 图像,并使用QLabel显示在界面上。

这些程序资料可是不错的学习资料,涵盖了从工业相机采集到各种图像处理和模板匹配的内容,大家可以根据自己的需求进行学习和扩展。希望大家在机器视觉的学习和实践中取得好成绩!

http://www.jsqmd.com/news/114511/

相关文章:

  • 用户资料报协议(UDP)详解
  • 电力电缆生产厂家推荐2025年权威认证!涵中低压、低压、中压变频电缆生产厂家推荐(12月更新) - 品牌2026
  • 【Open-AutoGLM进程管理终极指南】:掌握高效自动化运维的5大核心技巧
  • 2025年合肥靠谱有实力的装修专业公司排行榜,口碑优选不错的装修专业公司推荐 - 工业推荐榜
  • 虾皮上新怎么增加流量
  • Open-AutoGLM启动报错怎么办:3步快速定位并解决90%常见故障
  • 医疗客服也能AI化?Linly-Talker在行业场景中的落地实践
  • 2025年靠谱的微晶铸石板厂家最新用户好评榜 - 品牌宣传支持者
  • Open-AutoGLM日志系统揭秘,掌握这6个参数才算真正入门
  • 大数据领域数据复制的性能优化策略
  • 2025年井口装置涂装推荐制造商排名,专业快速涂装服务商全解析 - mypinpai
  • 揭秘Open-AutoGLM定时任务配置难点:3步实现零误差任务调度
  • 2025合肥诚信装修企业TOP5推荐:售后完善的装修专业公司助力安心家装 - myqiye
  • Linly-Talker与HeyGen对比:谁才是中小企业的最佳选择?
  • 你真的会开日志吗?Open-AutoGLM运行日志开启的5个致命误区
  • Open-AutoGLM启动异常深度解析(专家级排障流程曝光)
  • 2025年质量好的三合一复合陶瓷衬板/陶瓷衬板厂家推荐及选购参考榜 - 品牌宣传支持者
  • 为什么你的Open-AutoGLM没有日志?一文搞定运行日志开启难题
  • Linly-Talker技术深度拆解:ASR+TTS+LLM如何协同工作
  • 2025年合肥热门家装公司服务推荐:装修公司服务哪家好? - 工业推荐榜
  • 实时日志监控怎么做?Open-AutoGLM一键告警配置全公开
  • Linly-Talker在梯田耕作系统中的水土保持讲解
  • 企业级Open-AutoGLM部署难题,90%工程师忽略的3个关键配置点
  • 【AI开发避坑必备】:Open-AutoGLM报错代码精准定位与修复策略
  • 如何在10分钟内搞定Open-AutoGLM启动异常:一线工程师实战经验分享
  • 2025年自动化变频控制柜厂家排行榜,谁领风骚?,水处理PLC的电气控制柜/室外电气控制柜/水泵专用控制柜自动化变频控制柜生产厂家有哪些 - 品牌推荐师
  • 中国家装公司十强:创新引领行业变革,金煌家装铸就健康人居标杆 - 速递信息
  • 【Open-AutoGLM安全加固秘籍】:3大核心规则让攻击者无从下手
  • 揭秘Open-AutoGLM日志系统:如何快速启用运行日志并捕获关键执行轨迹
  • zak的论文