VM使用教程--SDK取图 视频笔记

2024-01-20 15:44

本文主要是介绍VM使用教程--SDK取图 视频笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本笔记均由海康机器人官网的V学院视频中记录所得,属于省流大师了[doge]

图像采集

图像采集包括1图像源,2多图采集,3输出图像,4缓存图像,5光源

1图像源

图像源包括本地图像,相机采图,SDK

本地图像:从本地图像中加载图像。

相机取图:从已配置的相机中获取图像。

SDK: 通过VM二次开发获取图像。

相机需要被其他软件占用等复杂情况,VM无法连接相机获取图像数据,为此,VM图像源支持二次开发情况下,利用SDK获取图像数据。

本期给大家带来在图像源中,选择SDK进行取图。

环境配置

在使用SDK取图前,我们需要进行二次开发所需的环境配置。

本文以VS2022为例。

第一步:新建项目。以C#为例,选择Windows窗体应用程序,框架:.NET Framework 4.8,创建项目。

第二步:设置属性。进入项目属性界面,进入生成窗口,平台目标:去掉32位勾选,保存。

右击项目名称,打开项目属性。在平台目标处勾选点首选32位。

如果在后期代码编写时出现环境问题报错,可以先检查自己是否去掉32位勾选。点击保存使相关设置生效。

第三步:添加引用。VisionMaster4.3.0\\Development\\V4.x\\ComControls\\Tool,选择项目路径,添加所需模块引用,重新加载引用。

属性设置完成后,打开VM安装路径,进入如下路径文件夹。VM4.3提供了快速应用工具,可以用于快速添加工具

选择刚刚创建好的项目路径。

我们可以自由选择所需添加的模块

此处,我们点击全部勾选,导入模式选择覆盖或者跳过同名。须等待进度条加载完毕。

点击退出,打开VS,点击全部重新加载。

第四步:添加控件

选择.NET Framework组件窗口,VisionMaster4.3.0\\Development\\V4.x\\ComControls\\Assemblylujin

在工具箱中,所有Windows窗体中右击。点击选择项,选择.NetFramework组件窗口,点击浏览,打开上述路径下的控件库

这里给大家列举VM控件对应的中英文。

VmFrontControl :前端运行界面控件

VmGlobalToolControl:全局模块控件

VmMainViewConfigControl:主界面控件。

VmParams:参数配置控件。

VmParamsConfigWithRederControl 参数配置带渲染控件

VmProcedureConfigControl :流程配置控件

VmRealTimeAcqControl: 时间配置控件

VmRenderControl:渲染控件

VmSingleModuleSetCongfigControl:独立Group控件

页面搭建

以上环境配置全部完成后,我们可以拖动控件去搭建一个简单的页面

首先,我们拖动GroupBox去搭建我们的整体框架。可以对该框架进行名称的修改。

接着,我们拖出Button来作为方案操作区,同样也可以修改名称,分别在流程显示区和图像显示区拖出对应控件。

一个简单的页面就搭建完成了。

接下来双击选择路径,进入对应界面进行程序编写。可以通过V学院二次开发视频学习代码。在结尾处我会放出VM二次开发的资料链接。

建议大家在回调函数中获取结果,不然高频运行环境可能会导致获取结果失败哦

 //选择路径private void button1_Click(object sender, EventArgs e){OpenFileDialog openFileDialog = new OpenFileDialog();openFileDialog.Filter = "VM Sol File|*.sol*";DialogResult openFileRes = openFileDialog.ShowDialog();if(DialogResult.OK == openFileRes){textBox1.Text = openFileDialog.FileName;}listBox1.Items.Add("选择路径成功");listBox1.TopIndex = listBox1.Items.Count - 1;}//加载方案private void button2_Click(object sender, EventArgs e){try{VmSolution.Load(textBox1.Text);listBox1.Items.Add("方案加载成功");listBox1.TopIndex = listBox1.Items.Count - 1;}catch(VmException ex){MessageBox.Show(Convert.ToString(ex.errorCode, 16));}}// 执行方案private void button3_Click(object sender, EventArgs e){try{// SDK 取图ImageSourceModuleTool imageSource = (ImageSourceModuleTool)VmSolution.Instance["流程1.图像源1"];imageSource.SetImagePath("F:\\土豆\\土豆图片2\\111\\1.bmp");VmSolution.Instance.SyncRun();listBox1.Items.Add("方案执行一次成功");listBox1.TopIndex = listBox1.Items.Count - 1;VmProcedure vmProcess1 = (VmProcedure)VmSolution.Instance["流程1"];vmRenderControl1.ModuleSource = vmProcess1;string ocrResult = vmProcess1.ModuResult.GetOutputString("out").astStringVal[0].strValue;listBox1.Items.Add("字符识别结果" + ocrResult);listBox1.TopIndex = listBox1.Items.Count - 1;listBox1.TopIndex = listBox1.Items.Count - 1;}catch(VmException ex){MessageBox.Show(Convert.ToString(ex.errorCode, 16));}}

各部分控件代码编写完后,右键单击生成,生成成功后点击启动,vs工程搭建完成

在执行方案前需要输入图像数据,所以需要创建一个图像源的实例。

ImageSourceModuleTool imageSource = (ImageSourceModuleTool)VmSolution.Instance["流程1.图像源1"];

如果这里出现CS0246 未能找到类型或命名空间名"ImageSourceModuleTool"(是否缺少using指令或程序集引用?)  说明我们需要添加下列的引用,此处我们需要引用using ImageSourceModuleCs,对流程中的图像源,有两种方法输入图像数据。第一种是使用SetImageData, 为图像源输入图像数据,该方法只是单次有效。

第二种是SetImagePath

  imageSource.SetImagePath("F:\\土豆\\土豆图片2\\111\\1.bmp");

可以从本地指定路径输入图像。

本次演示第二种方式,文件路径可以在图像文件的属性中查看

SDK即撰写完成,此处引用流程1的图像源,若VM方案中存在多个流程,各按实际情况引用

这篇关于VM使用教程--SDK取图 视频笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/626518

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]