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

网站建设中的功能宿迁网站制作公司

网站建设中的功能,宿迁网站制作公司,中国建筑网官网app,司瓦图网站一.项目示例 分析: 以上这种属于检测液体是否发表, 由于相机拍摄很模糊,下面我们会用到, 图像与处理工具,CogIPOneImageTool ,和像素处理 CogPixelMapTool 二 . 原图: 三. 题目要求 液位高度检测 手动定义一条基准线(绿色线条 通过卡尺工具和createline) 测量值液位高度…

一.项目示例

分析:

以上这种属于检测液体是否发表, 由于相机拍摄很模糊,下面我们会用到,

图像与处理工具,CogIPOneImageTool  ,和像素处理 CogPixelMapTool

二 . 原图:

三. 题目要求

液位高度检测  手动定义一条基准线(绿色线条 通过卡尺工具和createline)  测量值液位高度到基准线高度  大于130 小于110为NG

四. 解决方法

注意:我这里写的比较少,好多工具都是手搓出来的

1.工具

2.图像处理

 

3.接下来,就是我手搓的两个工具 CogCreateSegmentTool  和  CogDistanceSegmentLineTool  (这里就不给大家拉了,学习任务繁重,望理解)

 拉好之后是这个样子

4.声明

 CogGraphicCollection dt = new CogGraphicCollection();CogGraphicLabel label;CogCreateSegmentTool segment;CogDistanceSegmentLineTool segmentLine;

5.将拉的工具进行声明

    dt.Clear();CogPixelMapTool pixel = mToolBlock.Tools["CogPixelMapTool1"]as CogPixelMapTool;CogPMAlignTool pma = mToolBlock.Tools["CogPMAlignTool1"]as CogPMAlignTool;CogCaliperTool caliper = mToolBlock.Tools["CogCaliperTool1"]as CogCaliperTool;CogCreateLineTool line = mToolBlock.Tools["CogCreateLineTool1"]as CogCreateLineTool;

6.循环并创建多个卡尺

  for(int i = 0;i < pma.Results.Count;i++){caliper.Region.CenterX = pma.Results[i].GetPose().TranslationX;caliper.Region.CenterY = pma.Results[i].GetPose().TranslationY;caliper.Run();

7.给卡尺的位置创建一条线段

 segment = new CogCreateSegmentTool();segment.InputImage = pixel.OutputImage;segment.Segment.StartX = caliper.Results[0].Edge0.PositionX;segment.Segment.StartY = caliper.Results[0].Edge0.PositionY;segment.Segment.EndX = caliper.Results[0].Edge0.PositionX + 20;segment.Segment.EndY = caliper.Results[0].Edge0.PositionY;segment.Run();segment.GetOutputSegment().Color = CogColorConstants.Purple;dt.Add(segment.GetOutputSegment());

8.线段连接线,找出线段到线的那段距离

segmentLine = new CogDistanceSegmentLineTool();segmentLine.InputImage = pixel.OutputImage;segmentLine.Segment = segment.GetOutputSegment();segmentLine.Line = line.GetOutputLine();segmentLine.Run();

9.判断,距离是否合格

 label = new CogGraphicLabel();double width = Math.Round((segmentLine.Distance),2);double x = caliper.Results[0].Edge0.PositionX;double y = caliper.Results[0].Edge0.PositionY;if(width > 130 || width < 110){label.Color = CogColorConstants.Red;label.SetXYText(x, y -15, "NG:" + width);}else{label.Color = CogColorConstants.Green;label.SetXYText(x, y -15, "OK:" + width);}label.Font = new Font("楷体", 15);dt.Add(label);}  

10.最后把集合遍历出来,放在你想要放的工具页面上去

 foreach(ICogGraphic s in dt){mToolBlock.AddGraphicToRunRecord(s, lastRecord, "CogPixelMapTool1.输出图像", "script");}

五. 代码

#region namespace imports
using System;
using System.Collections;
using System.Drawing;
using System.IO;
using System.Windows.Forms;
using Cognex.VisionPro;
using Cognex.VisionPro.ToolBlock;
using Cognex.VisionPro3D;
using Cognex.VisionPro.ImageProcessing;
using Cognex.VisionPro.PixelMap;
using Cognex.VisionPro.PMAlign;
using Cognex.VisionPro.CalibFix;
using Cognex.VisionPro.Caliper;
using Cognex.VisionPro.Dimensioning;
#endregionpublic class CogToolBlockAdvancedScript : CogToolBlockAdvancedScriptBase
{#region Private Member Variablesprivate Cognex.VisionPro.ToolBlock.CogToolBlock mToolBlock;#endregionCogGraphicCollection dt = new CogGraphicCollection();CogGraphicLabel label;CogCreateSegmentTool segment;CogDistanceSegmentLineTool segmentLine;/// <summary>/// Called when the parent tool is run./// Add code here to customize or replace the normal run behavior./// </summary>/// <param name="message">Sets the Message in the tool's RunStatus.</param>/// <param name="result">Sets the Result in the tool's RunStatus</param>/// <returns>True if the tool should run normally,///          False if GroupRun customizes run behavior</returns>public override bool GroupRun(ref string message, ref CogToolResultConstants result){// To let the execution stop in this script when a debugger is attached, uncomment the following lines.// #if DEBUG// if (System.Diagnostics.Debugger.IsAttached) System.Diagnostics.Debugger.Break();// #endifdt.Clear();CogPixelMapTool pixel = mToolBlock.Tools["CogPixelMapTool1"]as CogPixelMapTool;CogPMAlignTool pma = mToolBlock.Tools["CogPMAlignTool1"]as CogPMAlignTool;CogCaliperTool caliper = mToolBlock.Tools["CogCaliperTool1"]as CogCaliperTool;CogCreateLineTool line = mToolBlock.Tools["CogCreateLineTool1"]as CogCreateLineTool;// Run each tool using the RunTool functionforeach(ICogTool tool in mToolBlock.Tools)mToolBlock.RunTool(tool, ref message, ref result);for(int i = 0;i < pma.Results.Count;i++){caliper.Region.CenterX = pma.Results[i].GetPose().TranslationX;caliper.Region.CenterY = pma.Results[i].GetPose().TranslationY;caliper.Run();segment = new CogCreateSegmentTool();segment.InputImage = pixel.OutputImage;segment.Segment.StartX = caliper.Results[0].Edge0.PositionX;segment.Segment.StartY = caliper.Results[0].Edge0.PositionY;segment.Segment.EndX = caliper.Results[0].Edge0.PositionX + 20;segment.Segment.EndY = caliper.Results[0].Edge0.PositionY;segment.Run();segment.GetOutputSegment().Color = CogColorConstants.Purple;dt.Add(segment.GetOutputSegment());segmentLine = new CogDistanceSegmentLineTool();segmentLine.InputImage = pixel.OutputImage;segmentLine.Segment = segment.GetOutputSegment();segmentLine.Line = line.GetOutputLine();segmentLine.Run();label = new CogGraphicLabel();double width = Math.Round((segmentLine.Distance),2);double x = caliper.Results[0].Edge0.PositionX;double y = caliper.Results[0].Edge0.PositionY;if(width > 130 || width < 110){label.Color = CogColorConstants.Red;label.SetXYText(x, y -15, "NG:" + width);}else{label.Color = CogColorConstants.Green;label.SetXYText(x, y -15, "OK:" + width);}label.Font = new Font("楷体", 15);dt.Add(label);}  return false;}#region When the Current Run Record is Created/// <summary>/// Called when the current record may have changed and is being reconstructed/// </summary>/// <param name="currentRecord">/// The new currentRecord is available to be initialized or customized.</param>public override void ModifyCurrentRunRecord(Cognex.VisionPro.ICogRecord currentRecord){}#endregion#region When the Last Run Record is Created/// <summary>/// Called when the last run record may have changed and is being reconstructed/// </summary>/// <param name="lastRecord">/// The new last run record is available to be initialized or customized.</param>public override void ModifyLastRunRecord(Cognex.VisionPro.ICogRecord lastRecord){foreach(ICogGraphic s in dt){mToolBlock.AddGraphicToRunRecord(s, lastRecord, "CogPixelMapTool1.输出图像", "script");}}#endregion#region When the Script is Initialized/// <summary>/// Perform any initialization required by your script here/// </summary>/// <param name="host">The host tool</param>public override void Initialize(Cognex.VisionPro.ToolGroup.CogToolGroup host){// DO NOT REMOVE - Call the base class implementation first - DO NOT REMOVEbase.Initialize(host);// Store a local copy of the script hostthis.mToolBlock = ((Cognex.VisionPro.ToolBlock.CogToolBlock)(host));}#endregion}

http://www.dtcms.com/wzjs/801293.html

相关文章:

  • 网站生成手机站网站建设博客
  • 周大福网站建设主要工作物流公司在哪做网站
  • 移动网站开发语言猪八戒做网站要多少钱
  • 上海做网站的公司哪家好网站设计与网站开发是同时进行的
  • 检察院做网站的目的照片分享网站开发费用
  • 电子商务主要是做什么的牡丹江seo
  • 企业网站设计有名 乐云seo开发一款小程序软件需要多少钱
  • 淘宝建设网站的目的是什么意思建筑工程电影网
  • 做警员编号网站jianshe导航网站
  • 生态农庄网站模板企业网站模板 asp
  • 深圳建网站哪wordpress一键ssl
  • 网站后台密码平台推广员是做什么的
  • 企业网站维护兼职做网站预算表
  • 肥城住房和城乡建设局网站没有公司做网站
  • 广西网站看男科一般花多少钱
  • 杭州市萧山区市场建设开发网站做网站找俊义 合优
  • 网站首页像素网站内链规划
  • wordpress适合建什么网站哈尔滨大型网站制作
  • 购物网站的名称和网址网站建设项目考察范文
  • 网站源码下载软件自己做的网站不满屏
  • 机械网站怎么做网站备案没公司名称
  • 网站百度知道怎么做推广长沙模板建站欢迎咨询
  • 前端企业网站开发seo视频教程汇总
  • 中国建设银行网站网站建设部门管理制度
  • 物流公司在哪做网站网络空间安全
  • 滕州网站开发广东深圳地图全图
  • 响应式网站建设服务提供商毕设帮做网站
  • 网站下载的文件在哪里网站后台功能需求
  • 手机网站建设行业分析网络推广外包sem营销外包
  • 旅游网站建设网站目的手机网速慢怎么办