在C#中我们应用CogPMAlignTool类很多,主要用于零件的尺寸角度,中心点,角度确认(VISIONPRO9.0)
1.这个工具控件中我们需提供的是InputImage 为CogImage8Grey的灰图。
图片我们可以从相机来也可以文档的图片来,由于我这边没有相机,我采用网上下载的图片进行测试。
1 Bitmap A1 = (Bitmap)Bitmap.FromFile(@"D:\AVI\13.JPG");
2 CogImage8Grey ima1 = new CogImage8Grey(A1);
2.可以直接利用其控件cogPMAlignEditV2进行编辑,教示我们需确认的
具体教示请参考我之前发的控件学习。
3.教示完成后进行保存。
1 SaveFileDialog dig=new SaveFileDialog();
2 if (dig.ShowDialog() == DialogResult.OK)
3 {
4 CogSerializer.SaveObjectToFile(cogPMAlignEditV21.Subject ,dig.FileName);
5 }
4.进行测试确认,再输出数据:
1 Bitmap A1 = (Bitmap)Bitmap.FromFile(@"D:\AVI\13.JPG");
2 CogImage8Grey ima1 = new CogImage8Grey(A1);
3 tool2 = CogSerializer.LoadObjectFromFile(@"D:\AVI\pm1.vpp") as CogPMAlignTool;
4 tool2.InputImage = ima1;
5 tool2.Run();
6 cogRecordDisplay2.Record = tool2.CreateLastRunRecord().SubRecords[0];
7 CogTransform2DLinear aline= tool2.Results[0].GetPose();
8 label1.Text = string.Format("数据:角度:{0},\n X:{1},Y:\n{2},\n得分{3}", aline.Rotation, aline.TranslationX, aline.TranslationY, tool2.Results[0].Score * 100);
5.代码:
form2的代码:
1 using System;
2 using System.Collections.Generic;
3 using System.ComponentModel;
4 using System.Data;
5 using System.Drawing;
6 using System.Linq;
7 using System.Text;
8 using System.Windows.Forms;
9 using Cognex.VisionPro;
10 using Cognex.VisionPro.ToolBlock;
11 using Cognex.VisionPro.ImageFile;
12 using System.IO;
13 using Cognex.VisionPro.OCRMax;
14 using Cognex.VisionPro.ID;
15 using System.Diagnostics;
16 using Cognex.VisionPro.PMAlign;
17 using Cognex.VisionPro.Blob;
18
19 namespace qj
20 {
21 public partial class Form2 : Form
22 {
23 public Form2()
24 {
25 InitializeComponent();
26 }
27 CogImage8Grey ima1 = null;
28 private void button1_Click(object sender, EventArgs e) //导进新图片进行编辑
29 {
30 Bitmap A1 = (Bitmap)Bitmap.FromFile(@"D:\AVI\13.JPG");
31 ima1 = new CogImage8Grey(A1);
32 cogPMAlignEditV21.Subject.InputImage = ima1;
33 }
34
35 private void button3_Click(object sender, EventArgs e) //打开编辑
36 {
37 OpenFileDialog dig = new OpenFileDialog();
38 dig.Filter = "(*.vpp)|*.vpp";
39 if (dig.ShowDialog() == DialogResult.OK)
40 {
41 cogPMAlignEditV21.Subject = CogSerializer.LoadObjectFromFile(dig.FileName) as CogPMAlignTool;
42 }
43 }
44
45 private void button2_Click(object sender, EventArgs e) //保存
46 {
47 SaveFileDialog dig=new SaveFileDialog();
48 if (dig.ShowDialog() == DialogResult.OK)
49 {
50 CogSerializer.SaveObjectToFile(cogPMAlignEditV21.Subject ,dig.FileName);
51 }
52 }
53
54 private void button4_Click(object sender, EventArgs e) //测试运行
55 {
56 cogPMAlignEditV21.Subject.Run();
57 }
58 }
59 }
form1的原码:
1 private void button1_Click_1(object sender, EventArgs e) //定位测试
2 {
3 Bitmap A1 = (Bitmap)Bitmap.FromFile(@"D:\AVI\13.JPG");
4 CogImage8Grey ima1 = new CogImage8Grey(A1);
5
6 tool2 = CogSerializer.LoadObjectFromFile(@"D:\AVI\pm1.vpp") as CogPMAlignTool;
7 tool2.InputImage = ima1;
8 tool2.Run();
9 cogRecordDisplay2.Record = tool2.CreateLastRunRecord().SubRecords[0];
10 CogTransform2DLinear aline= tool2.Results[0].GetPose();
11 label1.Text = string.Format("数据:角度:{0},\n X:{1},Y:\n{2},\n得分{3}", aline.Rotation, aline.TranslationX, aline.TranslationY, tool2.Results[0].Score * 100);
12 }
13
14 private void button2_Click(object sender, EventArgs e)
15 {
16
17 }
18
19 private void button3_Click(object sender, EventArgs e) //CogPMAlignTool mark编辑
20 {
21 Form2 gi = new Form2();
22 gi.ShowDialog();
23 }