MV-LEVD-200-4-PY 海康微视光源控制器协议封装类

海康微视光源控制器说明书

在这里插入图片描述

特点

1.输出电压脉冲的宽度(即光源的点亮时间)可设置 1us~999us,并可进行脉宽比例设置;
2.提升光源瞬间亮度达 400%以上,并延长光源使用寿命;
3.自动输出相机触发信号,并确保在光源点亮后同步触发相机采集图片;
4.可工作于外触发模式,按需要点亮光源;也可工作于内触发模式,按固定频率点亮光源;
5.当过载自动保护

规格

在这里插入图片描述

使用方法简述

前面板

在这里插入图片描述

使用方法:

在这里插入图片描述
在这里插入图片描述

串行通讯控制

串行通讯提供使用远程计算机控制本机。相关数据协议使用,如下说明,
连接串口通讯线缆后,同时按下 M 按键与 CH 按键,切换到串口控制模式:成功后 R 指示灯变亮!
如果通信成功后,会有相应字符反回!

在这里插入图片描述

光源脉宽亮度设置

在这里插入图片描述

内触发周期操作指令:

在这里插入图片描述

实例源码

  /// <summary>
    /// MV-LEVD-200-4-PY 海康微视光源控制器协议封装类
    /// </summary>
    public class MVLightControler
    {
        /// <summary>
        /// 控制器串口
        /// </summary>
        private SerialPort _serialPort;
        /// <summary>
        /// 控制器返回值
        /// </summary>
        private string _retStr;

        /// <summary>
        /// MV-LEVD-200-4-PY 光源控制器封装
        /// </summary>
        /// <param name="portName"></param>
        public MVLightControler(string portName)
        {
            _serialPort = new SerialPort(portName, 19200);
            _serialPort.DataBits = 8;//数据位:8
            _serialPort.StopBits = StopBits.One;//停止位:1
            _serialPort.Parity = Parity.None;//校验法:无
            _serialPort.DataReceived += _serialPort_DataReceived;
            _serialPort.Open();
        }

        private void _serialPort_DataReceived(object sender, SerialDataReceivedEventArgs e)
        {
            int nRead = _serialPort.BytesToRead;
            if (nRead > 0)
            {
                byte[] data = new byte[nRead];
                _serialPort.Read(data, 0, nRead);
                _retStr = System.Text.Encoding.Default.GetString(data);
                Logger.Info($"控制器返回:{_retStr}");
            }
        }

        /// <summary>
        /// 设置所有通道输出灯亮脉宽为x(us)
        /// 发送 SA0888#SB0000#SC0100#SD1023# 设置 CH1 亮度 888 CH2 亮度 0 CH3 亮度 100 CH4 亮度 1023
        /// </summary>
        /// <param name="x">灯亮脉宽(us)</param>
        public bool SetAllCHValue(int x)
        {
            if (x < 0)
                x = 0;
            if (x > 999)
                x = 999;
            string xxxx = x.ToString().PadLeft(4, '0');
            string str = $"SA{xxxx}#SB{xxxx}#SC{xxxx}#SD{xxxx}#";

            _retStr = "";
            _serialPort.Write(str);
            return (HiTimer.WaitCondition(() => !string.IsNullOrEmpty(_retStr)));
        }

        /// <summary>
        /// 设置某通道输出灯亮脉宽为x(us)
        /// </summary>
        /// <param name="ch">通道</param>
        /// <param name="x">灯亮脉宽(us)</param>
        public bool SetCHValue(CH ch,int x)
        {
            if (x < 0)
                x = 0;
            if (x > 999)
                x = 999;

            string xxxx = x.ToString().PadLeft(4, '0');
            string str = $"S{ch}{xxxx}#";

            _retStr = "";
            _serialPort.Write(str);
            return HiTimer.WaitCondition(() => !string.IsNullOrEmpty(_retStr)) && _retStr == $"{ch}";

            //例如:发送 SA0888# 返回值 A(CH1 通道灯亮脉宽为 888us)
            //例如:发送 SD0000# 返回值 D(CH4 通道灯亮脉宽为 0us,即关闭)
        }

        /// <summary>
        /// 设置触发模式
        /// </summary>
        /// <param name="trigerMode">触发模式</param>
        public bool SetTrigerMode(TrigerMode trigerMode)
        {
            _retStr = "";
            _serialPort.Write($"S{trigerMode}#");
            return HiTimer.WaitCondition(() => !string.IsNullOrEmpty(_retStr)) && _retStr == $"{trigerMode}";

            //例如:发送 SH# 返回值 H(设置内触发)
            //例如:发送 SL# 返回值 L(设置外触发)
        }

        /// <summary>
        /// 读取某通道输出灯亮脉宽(us)
        /// 例如:发送 SA# 返回值 a0888(即读回 CH1 通道灯亮脉宽为 888us)
        /// </summary>
        /// <param name="ch">通道</param>
        /// <returns>读取成功过返回正常值000~999,读取失败返回-1</returns>
        public int GetCHValue(CH ch)
        {
            _retStr = "";
            _serialPort.Write($"S{ch}#");

            if (HiTimer.WaitCondition(()=>!string.IsNullOrEmpty(_retStr)))
            {
                return Convert.ToInt32(_retStr.Substring(1));
            }
            return  -1;
        }
    }

    /// <summary>
    /// 通道
    /// </summary>
    public enum CH
    {
        /// <summary>
        /// CH1
        /// </summary>
        A,

        /// <summary>
        /// CH2
        /// </summary>
        B,

        /// <summary>
        /// CH3
        /// </summary>
        C,

        /// <summary>
        /// CH4
        /// </summary>
        D
    }

    public enum TrigerMode
    {
        /// <summary>
        /// 内触发
        /// </summary>
        H,

        /// <summary>
        /// 外触发
        /// </summary>
        L
    }
### 海康 VisionMaster 控制光源的方法与配置教程 #### 使用 XML-RPC 实现光源控制 为了通过海康 VisionMaster 或其硬件设备(如 VB2200 视觉控制器)实现光源的远程控制,可以利用 `LightControllForXmlRpc` 提供的功能。此工具基于 XML-RPC 请求协议,能够封装设置光源亮度和其他参数的操作[^1]。 具体操作流程如下: - **安装 IOController 应用程序** 首先需要确认已安装并运行了由海康提供的 `IOController.exe` 程序。该程序允许手动调整光源的相关参数,例如亮度、频率等。虽然它主要用于交互式调试,但在后台支持通过 API 进行调用。 - **集成 LightControllForXmlRpc 接口** 开发者可以通过编程方式发送 XML-RPC 请求给目标设备,从而动态修改光源的状态。这一步通常涉及编写客户端代码以连接到服务器端的服务地址,并传递必要的命令数据结构。 ```python import xmlrpc.client def set_light_brightness(server_url, brightness_value): proxy = xmlrpc.client.ServerProxy(server_url) result = proxy.SetBrightness(brightness_value) # 假设存在 SetBrightness 方法 return result server_address = "http://<your-vb2200-ip>:port" brightness_level = 50 # 设置为所需百分比值 response = set_light_brightness(server_address, brightness_level) print(f"Response from server: {response}") ``` 上述脚本展示了如何构建一个简单的 Python 客户端来更改指定视觉控制器上光源的强度水平。 #### SDK 和 .NET Framework 组件的支持 如果计划在更复杂的环境中部署解决方案,则可能还需要考虑引入官方发布的软件开发包 (SDK),以及相应的框架支持材料。对于 Windows 平台上的应用来说,推荐选用 Microsoft 的 .NET 技术栈作为基础架构之一[^2]。 当采用 Visual Studio 创建新项目时,请按照以下步骤添加所需的引用库: 1. 打开“添加引用”对话框; 2. 导航至自定义路径寻找预编译好的二进制文件集合位置——即类似于 `VisionMaster4.x.x\Development\Vx.x.x\ComControls\Assemblies` 的子目录; 3. 将找到的目标 DLL 加载进来即可开始进一步编码工作。 注意这里提到的具体版本号可能会随时间推移而有所变化,因此实际操作前务必查阅最新文档说明获取确切信息。 #### MFC 二次开发环境准备指南 针对某些特定场景下的高级定制需求,也许会涉及到使用微软基金会类(Microsoft Foundation Classes,MFC)来进行图形用户界面(GUI)设计等方面的工作。此时就需要额外做一些准备工作以便顺利开展后续任务[^3]: 1. 构建一个新的标准MFC应用程序模板; 2. 复制粘贴来自厂商分发包内的动态链接库(.dll)副本放置于最终产物所在的相对应输出区域内部 ; 3. 修改工程属性面板里关于C/C++选项卡中的附加包含目录字段内容 ,使其指向本地存储有头文件的位置 ; 4. 同样地更新链接阶段处理部分所指明的静态/共享对象档案所在处 ; 5. 插入那些预先打包完毕的小部件资源描述符记录进入当前活动单元格列表当中去 ; 完成以上各环节之后应该就可以正常加载各种功能模块并且不会报错丢失任何东西啦!记得最后测试一下能否成功实例化预期的对象实体哦~ #### 图像源属性设定注意事项 另外值得注意的是,在配置过程中还应当留意图像采集过程中的色彩模式选择问题。因为不同的应用场景往往决定了我们究竟要读取灰度级数较少但传输效率较高的单通道黑白影像(`Mono8`)呢?还是倾向于追求更加丰富的细节表现力因而愿意牺牲一点带宽占用率换取三原色合成后的全彩画面效果(`RGB24`)呢?[^4] 综上所述,借助恰当的技术手段完全可以达成对海康威视旗下产品系列中内置照明系统的精准操控目的! ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WayHonor-机器视觉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值