VisionPro之ToolBlock输出添加复杂输出类型

VisionPro中ToolBlock工具允许用户添加系统默认(bool、int、double等)数据类型以及VisionPro自定义(CogImage8Grey、ICogImage等)数据类型,常见数据类型的添加入下图所示。
添加VisionPro自定义数据类型添加系统默认数据类型
但是,有时需要在ToolBlock输出端添加List等相对复杂的数据类型。例如,返回当前匹配工具获取到的多个产品的XY坐标以及角度。首先,每个变量需要存储X、Y、A三个维度的信息。其次,每张图像中可能含有多个产品且产品个数不确定。具体实现方式如下:

  1. 添加List的程序集以及命名空间
  2. 创建List 对象
  3. 在初始化函数中创建CogToolBlockTerminal 对象与创建的List对象进行绑定,用CogToolBlockTerminal类的Add方法添加到ToolBlock的输出终端。
  4. 在GroupRun中对List实例对象进行数据的修改
using System;
using System.Collections;
using System.Drawing;
using System.IO;
using System.Windows.Forms;
using Cognex.VisionPro;
using Cognex.VisionPro.ToolBlock;
using System.Collections.Generic;
public class CogToolBlockAdvancedScript : CogToolBlockAdvancedScriptBase
{

  private Cognex.VisionPro.ToolBlock.CogToolBlock mToolBlock;
  List<Tuple<double,double,double>> MatchedPosition= null;
  public override bool GroupRun(ref string message, ref CogToolResultConstants result)
  {
    foreach(ICogTool tool in mToolBlock.Tools)
      mToolBlock.RunTool(tool, ref message, ref result);
      //此处添加对MatchedPosition的访问与修改
    return false;
  }
 
  public override void Initialize(Cognex.VisionPro.ToolGroup.CogToolGroup host)
  {
    base.Initialize(host);
    this.mToolBlock = ((Cognex.VisionPro.ToolBlock.CogToolBlock)(host));
    if(MatchedPosition== null)
    {
      MatchedPosition = new List<Tuple<double,double,double>>();
    }
    if(!mToolBlock.Outputs.Contains("MatchedPosition"))
    {
      CogToolBlockTerminal m = new CogToolBlockTerminal("MatchedPosition", MatchedPosition.GetType());
      mToolBlock.Outputs.Add(m);
    }
  
  }
}

### VisionPro 高级脚本使用教程 #### 1. 高级脚本的功能概述 VisionPro 的高级脚本允许开发者通过自定义逻辑来增强其功能。这些脚本可以用于自动化复杂的图像处理流程、与其他应用程序集成以及扩展内置工具的能力[^1]。 #### 2. 脚本类与方法详解 VisionPro 提供了多个级别的脚本支持,主要包括 `ToolGroup` 类、`ToolBlock` 类和 `Job` 类。每种类型的脚本适用于不同的场景: - **ToolGroup 脚本类**: 控制一组工具的整体行为。 - **ToolBlock 脚本类**: 处理单个工具块的行为。 - **Job 脚本类**: 定义整个作业的工作流。 具体来说,在实际应用中可以通过以下方式实现特定需求[^2]: ```csharp // 判断工具是否成功运行并设置输出值 if (pat.RunStatus.Result == CogToolResultConstants.Accept) { mToolBlock.Outputs["patCount"].Value = pat.Count; } else { mToolBlock.Outputs["patCount"].Value = "error"; mToolBlock.Outputs["patZuoBiao"].Value = "工具运行失败"; } ``` 上述代码片段展示了如何在 `ToolBlock` 中捕获工具执行状态,并根据结果更新输出变量[^5]。 #### 3. 实践案例分析 以下是几个常见的高级脚本应用场景及其解决方案: ##### 3.1 自动调整曝光时间 利用 `Job` 脚本来动态控制相机参数,从而优化图像质量: ```csharp private void AdjustExposureTime() { double currentExposure = Camera.ExposureTime; while (!IsImageSufficientlyExposed()) { currentExposure += 10; // 增加曝光时间 Camera.ExposureTime = currentExposure; CaptureImage(); // 获取新图像 } } bool IsImageSufficientlyExposed() { // 添加具体的亮度检测算法 return true; // 示例返回值 } ``` ##### 3.2 显示 Blob 区域的中心坐标 通过 `ToolBlock` 脚本计算目标区域的位置信息: ```csharp CogBlobTool blobTool = new CogBlobTool(); blobTool.InputImage = InputImage; foreach (var region in blobTool.Regions) { var centroidX = region.Centroid.X; var centroidY = region.Centroid.Y; Console.WriteLine($"Centroid: ({centroidX}, {centroidY})"); } ``` #### 4. 插件式开发与事件机制 为了进一步提升灵活性,VisionPro 支持将脚本封装成独立的“插件”程序集。这种设计使得复杂业务逻辑可以从主项目分离出来,便于维护和重用[^4]。 此外,还可以借助 .NET 平台中的事件与委托模型实现异步操作或回调通知: ```csharp public delegate void ImageProcessedEventHandler(object sender, EventArgs e); public class CustomProcessor : IDisposable { public event ImageProcessedEventHandler OnImageProcessed; private void ProcessImage(CogImage input) { // 图像处理逻辑... OnImageProcessed?.Invoke(this, EventArgs.Empty); } public void Dispose() => GC.SuppressFinalize(this); } ``` #### 5. 调试技巧总结 当遇到脚本问题时,推荐按照如下步骤排查: - 使用 Visual Studio 进行断点调试[^3]; - 查看日志文件定位异常位置; - 对比官方文档验证 API 调用是否正确。 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值