Python-OpenCV打开海康机器人黑白相机

将MvImport内所有文件拷贝至工作目录

项目结构

复制代码
requirements.txt
python 复制代码
# 基础科学计算库
numpy>=1.24.0

# 计算机视觉
opencv-python>=4.8.0
复制代码
hk_opencv.py
python 复制代码
import cv2
import numpy as np
from MvCameraControl_class import *
from CameraParams_header import *

# CameraNumber = 1为黑白相机,CameraNumber = 3为彩色相机
CameraNumber = 1

#-------------------opencv操作部分--------------------------------------
def opencv_action(img):
    result_img = img
    return result_img

#-----------------------海康相机设置部分---------------------------------------

ret = MvCamera.MV_CC_Initialize()
if ret != 0:
    print(f"初始化SDK失败,错误码: {ret}")
    exit()

# 枚举设备
deviceList = MV_CC_DEVICE_INFO_LIST()
n_layer_type = MV_GIGE_DEVICE | MV_USB_DEVICE | MV_GENTL_CAMERALINK_DEVICE
ret = MvCamera.MV_CC_EnumDevices(n_layer_type, deviceList)
if ret != 0:
    print("枚举设备失败")
    exit()

print(f"找到 {deviceList.nDeviceNum} 台设备")
if deviceList.nDeviceNum == 0:
    exit()

stDeviceList = cast(deviceList.pDeviceInfo[0], POINTER(MV_CC_DEVICE_INFO)).contents

camera = MvCamera()

ret = camera.MV_CC_CreateHandle(stDeviceList)

# 打开设备(使用已创建的句柄)
ret = camera.MV_CC_OpenDevice()
if ret != 0:
    print(f"打开设备失败,错误码: {ret}")
    exit()

# 获取相机参数
width = c_uint()
height = c_uint()
pixel_format = c_uint()
payload_size = c_uint()
stParam = MVCC_INTVALUE()

ret = camera.MV_CC_GetIntValue("PayloadSize", stParam)
if ret != 0:
    print(f"获取PayloadSize失败,错误码: {ret}")
    exit()
payload_size.value = stParam.nCurValue

# 获取宽度
ret = camera.MV_CC_GetIntValue("Width", stParam)
if ret != 0:
    print(f"获取宽度失败,错误码: {ret}")
    exit()
width.value = stParam.nCurValue

# 获取高度
ret = camera.MV_CC_GetIntValue("Height", stParam)
if ret != 0:
    print(f"获取高度失败,错误码: {ret}")
    exit()
height.value = stParam.nCurValue

print(width.value,height.value)


pixel_format.value = 17301505  # RGB8
# 或
#pixel_format.value = 17301514  # Mono8

#曝光时间
exposure_time = 15000  # 单位:微秒
ret = camera.MV_CC_SetFloatValue("ExposureTime", exposure_time)

# 开始抓图
ret = camera.MV_CC_StartGrabbing()
if ret != 0:
    print(f"开始抓图失败,错误码: {ret}")
    exit()

# 分配缓冲区
data_buf = (c_ubyte * payload_size.value)()
data_size = c_uint(payload_size.value)

stFrameInfo = MV_FRAME_OUT_INFO_EX()

#-----------------------------------------------运行部分---------------------------

# 创建OpenCV窗口
cv2.namedWindow("Camera", cv2.WINDOW_NORMAL)

try:
    while True:
        data_buf = (c_ubyte * payload_size.value)()
        ret = camera.MV_CC_GetOneFrameTimeout(
            byref(data_buf),
            payload_size.value,
            stFrameInfo,
            1000
        )

        if ret == 0:
            #print(f"获取到帧: 宽度={stFrameInfo.nWidth}, 高度={stFrameInfo.nHeight}, "f"像素格式={stFrameInfo.enPixelType}, 帧大小={stFrameInfo.nFrameLen}")

            frame = np.frombuffer(data_buf, dtype=np.uint8)
            actual_width = stFrameInfo.nWidth
            actual_height = stFrameInfo.nHeight
            # 黑白相机
            if stFrameInfo.enPixelType == 17301505:  # RGB8
                expected_size = actual_width * actual_height * CameraNumber
                if len(frame) != expected_size:
                    print(f"数据大小不匹配: 期望 {expected_size}, 实际 {len(frame)}")
                    continue

                frame = frame.reshape((actual_height, actual_width, CameraNumber))
                frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR)
            elif stFrameInfo.enPixelType == 17301514:  # Mono8
                expected_size = actual_width * actual_height
                if len(frame) != expected_size:
                    print(f"数据大小不匹配: 期望 {expected_size}, 实际 {len(frame)}")
                    continue

                frame = frame.reshape((actual_height, actual_width))
            elif stFrameInfo.enPixelType == 17301513:  # 可能是 Bayer 格式
                expected_size = actual_width * actual_height
                if len(frame) != expected_size:
                    print(f"数据大小不匹配: 期望 {expected_size}, 实际 {len(frame)}")
                    continue

                frame = frame.reshape((actual_height, actual_width))
                frame = cv2.cvtColor(frame, cv2.COLOR_BayerGB2BGR)

                frame = opencv_action(frame)
            else:
                print(f"不支持的像素格式: {stFrameInfo.enPixelType}")
                break

            cv2.imshow("Camera", frame)

            if cv2.waitKey(1) & 0xFF == ord("q"):
                break

        else:
            print(f"获取图像失败,错误码: {ret}")
            break

finally:
    # 停止抓图
    camera.MV_CC_StopGrabbing()
    # 关闭设备
    camera.MV_CC_CloseDevice()
    # 销毁句柄
    camera.MV_CC_DestroyHandle()
    # 销毁窗口
    cv2.destroyAllWindows()

最终效果:

相关推荐
源代码杀手5 分钟前
基于ROS2+Gazebo+RIVE的40项计算机视觉前沿机器人项目(含视觉算法原理与源码获取方式)
算法·计算机视觉·机器人
KaMeidebaby16 分钟前
卡梅德生物技术快报|细胞周期检测抗原流式分析:参数调试、软件拟合与问题排查
网络·人工智能·python·网络协议·tcp/ip·算法·机器学习
小O的算法实验室23 分钟前
2024年IEEE/CAA JAS,复杂环境下避障 Voronoi 单元的多机器人协同围捕
机器人
zmzb010326 分钟前
Python课后习题训练记录Day124
开发语言·python
Linlingu27 分钟前
OpenClaw对接飞书机器人完整配置教程(长连接模式)
windows·机器人·飞书·办公自动化·数字员工·小龙虾
geovindu27 分钟前
python: Broadcast Pattern
开发语言·python·设计模式·广播模式
winfredzhang36 分钟前
Python 实战:用 wxPython 写一个 MD5 文件查重清理工具
python·sqlite·json·wxpython·md5·预览·查重
装不满的克莱因瓶40 分钟前
了解不同机器学习模型的分类
人工智能·python·算法·机器学习·ai·分类·数据挖掘
kyle~1 小时前
ROS2---零拷贝
linux·c++·机器人·ros2
小江的记录本1 小时前
【Spring全家桶】Spring Cloud 2023.0.x:配置中心:Nacos Config、Apollo(附《思维导图》+《面试高频考点清单》)
java·spring boot·后端·python·spring·spring cloud·面试