|
|
|
@ -10,6 +10,7 @@
|
|
|
|
|
#include "CommonFlowMgr.h"
|
|
|
|
|
#include "CameraHawkvis.h"
|
|
|
|
|
#include "ProgramCutMgr.h"
|
|
|
|
|
#include "PropertieMgr.h"
|
|
|
|
|
|
|
|
|
|
#include "SmartArchive.h"
|
|
|
|
|
#include <opencv2/opencv.hpp>
|
|
|
|
@ -61,8 +62,7 @@ void DlgHawkvisCamera::DoDataExchange(CDataExchange* pDX)
|
|
|
|
|
{
|
|
|
|
|
CDialogEx::DoDataExchange(pDX);
|
|
|
|
|
DDX_Control(pDX, IDC_ISP3000_LOGO_BTN, m_ISP3000LogoBtn);
|
|
|
|
|
DDX_Control(pDX, IDC_HAWKVISCTRLCTRL3, m_HawkvisCtrl1);
|
|
|
|
|
DDX_Control(pDX, IDC_HAWKVISCTRLCTRL4, m_HawkvisCtrl2);
|
|
|
|
|
DDX_Control(pDX, IDC_HAWKVISCTRLCTRL3, m_HawkvisCtrl);
|
|
|
|
|
|
|
|
|
|
DDX_Control(pDX, IDC_OPEN_CAM, m_OpenCamBtn);
|
|
|
|
|
DDX_Control(pDX, IDC_CLOSE_CAM, m_CloseCamBtn);
|
|
|
|
@ -85,7 +85,6 @@ void DlgHawkvisCamera::DoDataExchange(CDataExchange* pDX)
|
|
|
|
|
DDX_Text(pDX, IDC_EDIT_SET_EXP2, m_CurTrackThreshold);
|
|
|
|
|
DDX_Text(pDX, IDC_STATIC_CurValue, m_CurPic_Definition);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
BOOL DlgHawkvisCamera::OnInitDialog()
|
|
|
|
|
{
|
|
|
|
@ -105,105 +104,32 @@ BOOL DlgHawkvisCamera::OnInitDialog()
|
|
|
|
|
m_ContinueFrameBtn.SetUpColor(RGB_PINK);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Update();
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (m_HawkvisCtrl2.MV_SelectAdapterByIdx(1))
|
|
|
|
|
{
|
|
|
|
|
if (m_HawkvisCtrl2.MV_OpenCamera())
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl2;
|
|
|
|
|
m_HawkvisCtrl2.MV_SetCameraExpTime(gCameraHawkvis->m_nCam2Expore);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("相机2 MV_OpenCamera 失败!");
|
|
|
|
|
}
|
|
|
|
|
m_HawkvisCtrl2.SetCrossShow(1, 30, 30, -1, -1, TRUE);
|
|
|
|
|
if (m_HawkvisCtrl2.MV_GetOneFrame())
|
|
|
|
|
{
|
|
|
|
|
m_HawkvisCtrl2.ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("相机2 MV_GetOneFrame 失败!");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
Fresh();
|
|
|
|
|
|
|
|
|
|
if (m_HawkvisCtrl1.MV_SelectAdapterByIdx(0))
|
|
|
|
|
{
|
|
|
|
|
if (m_HawkvisCtrl1.MV_OpenCamera())
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl1;
|
|
|
|
|
m_HawkvisCtrl1.MV_SetCameraExpTime(gCameraHawkvis->m_nCam1Expore);
|
|
|
|
|
m_nExpore = gCameraHawkvis->m_nCam1Expore;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("相机1 MV_OpenCamera 失败!");
|
|
|
|
|
}
|
|
|
|
|
m_HawkvisCtrl1.SetCrossShow(1, 30, 30, -1, -1, TRUE);
|
|
|
|
|
if (m_HawkvisCtrl1.MV_GetOneFrame())
|
|
|
|
|
{
|
|
|
|
|
m_HawkvisCtrl1.ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("相机1 MV_GetOneFrame 失败!");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("打开相机异常.");
|
|
|
|
|
}
|
|
|
|
|
((CButton*)GetDlgItem(IDC_CROSS_CHECK))->SetCheck(TRUE);
|
|
|
|
|
UpdateData(FALSE);
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
//观察平台坐标的变化
|
|
|
|
|
void DlgHawkvisCamera::UpdateInfo()
|
|
|
|
|
{
|
|
|
|
|
//换文件时,自动换模板
|
|
|
|
|
if ((!gLogMgr->IsDebuging()) && gCameraHawkvis->GetCurShapeModelID() != m_ShapeModelID)
|
|
|
|
|
/*//换文件时,自动换模板
|
|
|
|
|
if (gCameraHawkvis->GetCurShapeModelID()!= m_ShapeModelID)
|
|
|
|
|
{
|
|
|
|
|
auto temp = m_pHawkvisCtrl;
|
|
|
|
|
|
|
|
|
|
m_ShapeModelID = gCameraHawkvis->GetCurShapeModelID();
|
|
|
|
|
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl1;
|
|
|
|
|
OnBnClickedLoadCatchTemp();
|
|
|
|
|
Sleep(200);
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl2;
|
|
|
|
|
OnBnClickedLoadCatchTemp();
|
|
|
|
|
|
|
|
|
|
m_pHawkvisCtrl = temp;
|
|
|
|
|
}
|
|
|
|
|
}*/
|
|
|
|
|
if (m_DlgCurCamIndex == gCameraHawkvis->GetCamIndex())
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
m_DlgCurCamIndex = gCameraHawkvis->GetCamIndex(); //系数立即刷新,避免重复进入
|
|
|
|
|
|
|
|
|
|
if (gCameraHawkvis->GetCamIndex() == 0)
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl1;
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(FALSE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(TRUE);
|
|
|
|
|
}
|
|
|
|
|
OnBnClickedToCam1();
|
|
|
|
|
|
|
|
|
|
if (gCameraHawkvis->GetCamIndex() == 1)
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl2;
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(TRUE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(FALSE);
|
|
|
|
|
//OnBnClickedToCam2();
|
|
|
|
|
}
|
|
|
|
|
OnBnClickedToCam2();
|
|
|
|
|
|
|
|
|
|
UpdateData(FALSE);
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::Update()
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::Fresh()
|
|
|
|
|
{
|
|
|
|
|
SetTimer(WORK_TIMER1, WORK_TIME_DELAY1, NULL);//用timer来更新,否则会报错
|
|
|
|
|
}
|
|
|
|
@ -221,7 +147,7 @@ void DlgHawkvisCamera::OnTimer(UINT nIDEvent)
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedOpenCam()
|
|
|
|
|
{
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (m_pHawkvisCtrl->MV_OpenCamera())
|
|
|
|
|
if (m_HawkvisCtrl.MV_OpenCamera())
|
|
|
|
|
#else
|
|
|
|
|
if (m_HawkvisCtrl.HV_OpenCamera())
|
|
|
|
|
#endif
|
|
|
|
@ -234,32 +160,23 @@ void DlgHawkvisCamera::OnBnClickedOpenCam()
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedCloseCam()
|
|
|
|
|
{
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (m_pHawkvisCtrl->MV_CloseCamera())
|
|
|
|
|
{
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : Close Cam OK");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : Close Cam Failed!");
|
|
|
|
|
}
|
|
|
|
|
m_HawkvisCtrl.MV_CloseCamera();
|
|
|
|
|
#else
|
|
|
|
|
m_HawkvisCtrl.HV_CloseCamera();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : Close Cam");
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedFrameOne()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
m_HawkvisCtrl.SetCrossShow(1, 30, 30, -1, -1, FALSE);
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
/*m_pHawkvisCtrl->MV_GetOneFrame();
|
|
|
|
|
Sleep(100);*/
|
|
|
|
|
if (m_pHawkvisCtrl->MV_GetOneFrame())
|
|
|
|
|
if (m_HawkvisCtrl.MV_GetOneFrame())
|
|
|
|
|
#else
|
|
|
|
|
if (m_HawkvisCtrl.HV_GetOneFrame())
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
//m_HawkvisCtrl.Rotate180();
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : FrameOne --OK");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
@ -269,14 +186,14 @@ Sleep(100);*/
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedFrameContinue()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
m_HawkvisCtrl.SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (m_pHawkvisCtrl->MV_GetContinueFrame())
|
|
|
|
|
if (m_HawkvisCtrl.MV_GetContinueFrame())
|
|
|
|
|
#else
|
|
|
|
|
if (m_HawkvisCtrl.HV_GetContinueFrame())
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : FrameContinue --OK");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
@ -286,13 +203,13 @@ void DlgHawkvisCamera::OnBnClickedFrameContinue()
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedReadBmp()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ReadImage();
|
|
|
|
|
m_HawkvisCtrl.ReadImage();
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedSaveBmp()
|
|
|
|
|
{
|
|
|
|
|
CFileMgr FileMgr;
|
|
|
|
|
CString path = FileMgr.GetWorkPath();
|
|
|
|
|
m_pHawkvisCtrl->WriteImage((LPCTSTR)path, "OutputImg");
|
|
|
|
|
m_HawkvisCtrl.WriteImage((LPCTSTR)path, "OutputImg");
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : SaveBmp");
|
|
|
|
|
}
|
|
|
|
|
//设置曝光值
|
|
|
|
@ -302,13 +219,15 @@ void DlgHawkvisCamera::OnBnClickedSetExpore()
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (m_DlgCurCamIndex == 0)
|
|
|
|
|
{
|
|
|
|
|
gCameraHawkvis->m_nCam1Expore = m_nExpore;
|
|
|
|
|
//gCameraHawkvis->m_nCam1Expore = m_nExpore;
|
|
|
|
|
gDevicePropertieMgr.ChangePropertieByVal(&gCameraHawkvis->m_nCam1Expore, m_nExpore);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
gCameraHawkvis->m_nCam2Expore = m_nExpore;
|
|
|
|
|
//gCameraHawkvis->m_nCam2Expore = m_nExpore;
|
|
|
|
|
gDevicePropertieMgr.ChangePropertieByVal(&gCameraHawkvis->m_nCam2Expore, m_nExpore);
|
|
|
|
|
}
|
|
|
|
|
m_pHawkvisCtrl->MV_SetCameraExpTime(m_nExpore);
|
|
|
|
|
m_HawkvisCtrl.MV_SetCameraExpTime(m_nExpore);
|
|
|
|
|
#else
|
|
|
|
|
m_HawkvisCtrl.HV_SetCameraExpTime(m_nExpore);
|
|
|
|
|
#endif
|
|
|
|
@ -320,140 +239,123 @@ void DlgHawkvisCamera::OnBnClickedSetExpore()
|
|
|
|
|
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedZoomFull()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedHkZoomIn()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomIn();
|
|
|
|
|
m_HawkvisCtrl.ZoomIn();
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedHkZoomOut()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomOut();
|
|
|
|
|
m_HawkvisCtrl.ZoomOut();
|
|
|
|
|
}
|
|
|
|
|
#if 1
|
|
|
|
|
//编辑模板
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedCreatCatchTemp()
|
|
|
|
|
{
|
|
|
|
|
//调用控件接口,创建基于形状的模板,输入参数为模板ID号。控件最多支持创建100个模板,即模板号为0~99
|
|
|
|
|
// m_HawkvisCtrl.CreateShapeModel(0);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->CreateShapeModel(gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("编辑模板 异常!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
m_HawkvisCtrl.CreateShapeModel(0);
|
|
|
|
|
//m_HawkvisCtrl.CreateShapeModel(gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedTestCatchTemp()
|
|
|
|
|
{
|
|
|
|
|
//清除之前绘制的圆
|
|
|
|
|
m_pHawkvisCtrl->ClearGraphicObject();
|
|
|
|
|
//抓取一帧
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
//清除之前绘制的圆
|
|
|
|
|
m_HawkvisCtrl.ClearGraphicObject();
|
|
|
|
|
//抓取一帧
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (!m_pHawkvisCtrl->MV_GetOneFrame())
|
|
|
|
|
if (!m_HawkvisCtrl.MV_GetOneFrame())
|
|
|
|
|
#else
|
|
|
|
|
if (!m_HawkvisCtrl->HV_GetOneFrame())
|
|
|
|
|
if (!m_HawkvisCtrl->HV_GetOneFrame())
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
CString str = _T("func : Hawkvis Get One Frame----->Error");
|
|
|
|
|
//CExceptionMsg Msg;
|
|
|
|
|
//Msg.SetMsg(str);
|
|
|
|
|
//throw Msg;
|
|
|
|
|
{
|
|
|
|
|
CString str = _T("func : Hawkvis Get One Frame----->Error");
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
}
|
|
|
|
|
Sleep(300);//等待数据结果输出到ocx 控件上
|
|
|
|
|
//模板查找
|
|
|
|
|
double pdbX[10], pdbY[10], pdbAngles[10], pdbScale[10], pdbSore[10];
|
|
|
|
|
long nCount[1] = { 1 };
|
|
|
|
|
//FindShapeMode 控件的模板查找函数。
|
|
|
|
|
//第一个参数,金字塔层数,取值范围1~5
|
|
|
|
|
//第二个参数,输出查找到的目标列坐标
|
|
|
|
|
//第三个参数,输出查找到的目标行坐标
|
|
|
|
|
//第四个参数,输出查找到的目标角度
|
|
|
|
|
//第五个参数,输出查找到的目标伸缩度
|
|
|
|
|
//第六个参数,输出查找到的目标分数
|
|
|
|
|
//第七个参数,输出查找到的目标个数
|
|
|
|
|
//第八个参数,输入查找模板的ID号
|
|
|
|
|
VARIANT *v_pdbX = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbY = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbAngles = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbScale = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbSore = new VARIANT[1];
|
|
|
|
|
|
|
|
|
|
bool ret = m_HawkvisCtrl.FindShapeModel(gCameraHawkvis->GetCurShapeModelID(), v_pdbY, v_pdbX, v_pdbAngles, v_pdbScale, v_pdbSore, nCount);
|
|
|
|
|
if (!ret)//2018-01-15 增加保护,否则下面可能会报错
|
|
|
|
|
{
|
|
|
|
|
CString str = _T("func : Hawkvis Find Shape Model----->Error");
|
|
|
|
|
//CExceptionMsg Msg;
|
|
|
|
|
//Msg.SetMsg(str);
|
|
|
|
|
//throw Msg;
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
//pdbX
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbX->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbX->parray, &index, pdbX + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbY
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbY->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbY->parray, &index, pdbY + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbAngles
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbAngles->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbAngles->parray, &index, pdbAngles + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbScale
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbScale->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbScale->parray, &index, pdbScale + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbSore
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbSore->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbSore->parray, &index, pdbSore + index);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//显示查找到的模板的位置
|
|
|
|
|
#if 1
|
|
|
|
|
Dbxy pt;
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("X: %0.3f, Y:%0.f", pdbX[0], pdbY[0]);
|
|
|
|
|
pt.x = pdbX[0];
|
|
|
|
|
pt.y = pdbY[0];
|
|
|
|
|
str.Format("X: %0.3f, Y:%0.3f", pt.x, pt.y);
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
}
|
|
|
|
|
Sleep(300);//等待数据结果输出到ocx 控件上
|
|
|
|
|
//模板查找
|
|
|
|
|
double pdbX[10], pdbY[10], pdbAngles[10], pdbScale[10], pdbSore[10];
|
|
|
|
|
long nCount[1] = { 1 };
|
|
|
|
|
//FindShapeMode 控件的模板查找函数。
|
|
|
|
|
//第一个参数,金字塔层数,取值范围1~5
|
|
|
|
|
//第二个参数,输出查找到的目标列坐标
|
|
|
|
|
//第三个参数,输出查找到的目标行坐标
|
|
|
|
|
//第四个参数,输出查找到的目标角度
|
|
|
|
|
//第五个参数,输出查找到的目标伸缩度
|
|
|
|
|
//第六个参数,输出查找到的目标分数
|
|
|
|
|
//第七个参数,输出查找到的目标个数
|
|
|
|
|
//第八个参数,输入查找模板的ID号
|
|
|
|
|
VARIANT *v_pdbX = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbY = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbAngles = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbScale = new VARIANT[1];
|
|
|
|
|
VARIANT *v_pdbSore = new VARIANT[1];
|
|
|
|
|
bool ret = false;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
ret = m_pHawkvisCtrl->FindShapeModel(gCameraHawkvis->GetCurShapeModelID(), v_pdbY, v_pdbX, v_pdbAngles, v_pdbScale, v_pdbSore, nCount);
|
|
|
|
|
#endif
|
|
|
|
|
//gCommonFlowMgr->CameraCatch();
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
ret = false;
|
|
|
|
|
AfxMessageBox("模板匹配 异常!");
|
|
|
|
|
}
|
|
|
|
|
if (!ret)//2018-01-15 增加保护,否则下面可能会报错
|
|
|
|
|
{
|
|
|
|
|
CString str = _T("func : Hawkvis Find Shape Model----->Error");
|
|
|
|
|
//CExceptionMsg Msg;
|
|
|
|
|
//Msg.SetMsg(str);
|
|
|
|
|
//throw Msg;
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
//pdbX
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbX->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbX->parray, &index, pdbX + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbY
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbY->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbY->parray, &index, pdbY + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbAngles
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbAngles->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbAngles->parray, &index, pdbAngles + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbScale
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbScale->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbScale->parray, &index, pdbScale + index);
|
|
|
|
|
}
|
|
|
|
|
//pdbSore
|
|
|
|
|
for (long index = 0; index < ::SafeArrayGetElemsize(v_pdbSore->parray); ++index) {
|
|
|
|
|
::SafeArrayGetElement(v_pdbSore->parray, &index, pdbSore + index);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//显示查找到的模板的位置
|
|
|
|
|
#if 1
|
|
|
|
|
Dbxy pt;
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("X: %0.3f, Y:%0.f", pdbX[0], pdbY[0]);
|
|
|
|
|
pt.x = pdbX[0];
|
|
|
|
|
pt.y = pdbY[0];
|
|
|
|
|
str.Format("X: %0.3f, Y:%0.3f", pt.x, pt.y);
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
#endif
|
|
|
|
|
//gCommonFlowMgr->CameraCatch();
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedLoadCatchTemp()
|
|
|
|
|
{
|
|
|
|
|
CFileMgr FileMgr;
|
|
|
|
|
CString path = FileMgr.GetWorkPath();
|
|
|
|
|
// auto b=m_HawkvisCtrl.LoadShapeModel((LPCTSTR)path);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
auto b = m_pHawkvisCtrl->LoadShapeModelByID(gCameraHawkvis->GetCurShapeModelID(), (LPCTSTR)path);
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("Hawkvis : LoadatchTemp [%d]", gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
auto b = m_HawkvisCtrl.LoadShapeModelByID(gCameraHawkvis->GetCurShapeModelID(), (LPCTSTR)path);
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("Hawkvis : LoadatchTemp [%d]", gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
|
|
|
|
|
if (b)
|
|
|
|
|
str += " 成功!";
|
|
|
|
|
else
|
|
|
|
|
str += " 失败!";
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("加载模板 异常!");
|
|
|
|
|
}
|
|
|
|
|
if (b)
|
|
|
|
|
str += " 成功!";
|
|
|
|
|
else
|
|
|
|
|
str += " 失败!";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
//gLogMgr->WriteDebugLog("Hawkvis : LoadCatchTemp");
|
|
|
|
|
}
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedSaveCatchTemp()
|
|
|
|
@ -464,59 +366,43 @@ void DlgHawkvisCamera::OnBnClickedSaveCatchTemp()
|
|
|
|
|
CFileMgr FileMgr;
|
|
|
|
|
CString path = FileMgr.GetWorkPath();
|
|
|
|
|
//auto b= m_HawkvisCtrl.SaveShapeModel((LPCTSTR)path);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
auto b = m_pHawkvisCtrl->SaveShapeModelByID(gCameraHawkvis->GetCurShapeModelID(), (LPCTSTR)path);
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("Hawkvis : SaveCatchTemp [%d]", gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
if (b)
|
|
|
|
|
str += " 成功!";
|
|
|
|
|
else
|
|
|
|
|
str += " 失败!";
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("保存模板 异常!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auto b = m_HawkvisCtrl.SaveShapeModelByID(gCameraHawkvis->GetCurShapeModelID(), (LPCTSTR)path);
|
|
|
|
|
CString str;
|
|
|
|
|
str.Format("Hawkvis : SaveCatchTemp [%d]", gCameraHawkvis->GetCurShapeModelID());
|
|
|
|
|
if (b)
|
|
|
|
|
str += " 成功!";
|
|
|
|
|
else
|
|
|
|
|
str += " 失败!";
|
|
|
|
|
gLogMgr->WriteDebugLog(str);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedToCam1()
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl1;
|
|
|
|
|
return;
|
|
|
|
|
/*try
|
|
|
|
|
//提前刷新索引,避免重复进入
|
|
|
|
|
m_DlgCurCamIndex = 0;
|
|
|
|
|
gCameraHawkvis->SetCamIndex(0);
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->MV_CloseCamera();
|
|
|
|
|
if (m_pHawkvisCtrl->MV_SelectAdapterByIdx(0))
|
|
|
|
|
m_HawkvisCtrl.MV_CloseCamera();
|
|
|
|
|
if (m_HawkvisCtrl.MV_SelectAdapterByIdx(0))
|
|
|
|
|
{
|
|
|
|
|
if (m_pHawkvisCtrl->MV_OpenCamera())
|
|
|
|
|
if (m_HawkvisCtrl.MV_OpenCamera())
|
|
|
|
|
{
|
|
|
|
|
OnBnClickedLoadCatchTemp();//读取模板
|
|
|
|
|
m_pHawkvisCtrl->MV_SetCameraExpTime(gCameraHawkvis->m_nCam1Expore);
|
|
|
|
|
OnBnClickedLoadCatchTemp();//读取模板
|
|
|
|
|
m_HawkvisCtrl.MV_SetCameraExpTime(gCameraHawkvis->m_nCam1Expore);
|
|
|
|
|
m_nExpore = gCameraHawkvis->m_nCam1Expore;
|
|
|
|
|
//UpdateData(FALSE);
|
|
|
|
|
//OnBnClickedSetExpore();//设置曝光
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
m_pHawkvisCtrl->SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
if (m_pHawkvisCtrl->MV_GetOneFrame())
|
|
|
|
|
m_HawkvisCtrl.SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
if (m_HawkvisCtrl.MV_GetOneFrame())
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
/ *else
|
|
|
|
|
{
|
|
|
|
|
static bool bfirst = true;
|
|
|
|
|
if (bfirst)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("相机1连续采集失败!");//报错一次
|
|
|
|
|
bfirst = false;
|
|
|
|
|
}
|
|
|
|
|
}* /
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
@ -524,83 +410,75 @@ void DlgHawkvisCamera::OnBnClickedToCam1()
|
|
|
|
|
if (bfirst)
|
|
|
|
|
{
|
|
|
|
|
bfirst = false;
|
|
|
|
|
AfxMessageBox("打开相机1失败!");//报错一次
|
|
|
|
|
|
|
|
|
|
AfxMessageBox("打开相机1失败!");//报错一次
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
m_DlgCurCamIndex = 0;
|
|
|
|
|
gCameraHawkvis->SetCamIndex(0);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(TRUE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(FALSE);
|
|
|
|
|
gLogMgr->WriteDebugLog("Switch To Cam1");
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("打开相机1 异常!");//报错一次
|
|
|
|
|
}*/
|
|
|
|
|
AfxMessageBox("切换至相机1发生异常!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(TRUE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(FALSE);
|
|
|
|
|
gLogMgr->WriteDebugLog("Switch To Cam1");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedToCam2()
|
|
|
|
|
{
|
|
|
|
|
{ //提前刷新索引,避免重复进入
|
|
|
|
|
m_DlgCurCamIndex = 1;
|
|
|
|
|
gCameraHawkvis->SetCamIndex(1);
|
|
|
|
|
|
|
|
|
|
m_pHawkvisCtrl = &m_HawkvisCtrl2;
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
try
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
m_HawkvisCtrl.MV_CloseCamera();
|
|
|
|
|
if (m_HawkvisCtrl.MV_SelectAdapterByIdx(1))
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->MV_CloseCamera();
|
|
|
|
|
if (m_pHawkvisCtrl->MV_SelectAdapterByIdx(1))
|
|
|
|
|
if (m_HawkvisCtrl.MV_OpenCamera())
|
|
|
|
|
{
|
|
|
|
|
OnBnClickedLoadCatchTemp();//读取模板
|
|
|
|
|
m_HawkvisCtrl.MV_SetCameraExpTime(gCameraHawkvis->m_nCam2Expore);
|
|
|
|
|
m_nExpore = gCameraHawkvis->m_nCam2Expore;
|
|
|
|
|
//UpdateData(FALSE);
|
|
|
|
|
//OnBnClickedSetExpore();//设置曝光
|
|
|
|
|
}
|
|
|
|
|
m_HawkvisCtrl.SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
if (m_HawkvisCtrl.MV_GetOneFrame())
|
|
|
|
|
{
|
|
|
|
|
if (m_pHawkvisCtrl->MV_OpenCamera())
|
|
|
|
|
{
|
|
|
|
|
OnBnClickedLoadCatchTemp();//读取模板
|
|
|
|
|
m_pHawkvisCtrl->MV_SetCameraExpTime(gCameraHawkvis->m_nCam2Expore);
|
|
|
|
|
m_nExpore = gCameraHawkvis->m_nCam2Expore;
|
|
|
|
|
//UpdateData(FALSE);
|
|
|
|
|
//OnBnClickedSetExpore();//设置曝光
|
|
|
|
|
}
|
|
|
|
|
m_pHawkvisCtrl->SetCrossShow(1, 30, 30, -1, -1, ((CButton*)GetDlgItem(IDC_CROSS_CHECK))->GetCheck());
|
|
|
|
|
if (m_pHawkvisCtrl->MV_GetOneFrame())
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
static bool bfirst = true;
|
|
|
|
|
if (bfirst)
|
|
|
|
|
{
|
|
|
|
|
static bool bfirst = true;
|
|
|
|
|
if (bfirst)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("打开相机2失败!");//报错一次
|
|
|
|
|
bfirst = false;
|
|
|
|
|
}
|
|
|
|
|
AfxMessageBox("打开相机2失败!");//报错一次
|
|
|
|
|
bfirst = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
m_DlgCurCamIndex = 1;
|
|
|
|
|
gCameraHawkvis->SetCamIndex(1);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(TRUE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(FALSE);
|
|
|
|
|
gLogMgr->WriteDebugLog("Switch To Cam2");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("切换至相机2发生异常!");
|
|
|
|
|
}
|
|
|
|
|
catch (...)
|
|
|
|
|
{
|
|
|
|
|
AfxMessageBox("打开相机2 异常!");//报错一次
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO1))->SetCheck(TRUE);
|
|
|
|
|
((CButton*)GetDlgItem(IDC_RADIO3))->SetCheck(FALSE);
|
|
|
|
|
gLogMgr->WriteDebugLog("Switch To Cam2");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void DlgHawkvisCamera::OnBnClickedTestDefinition()
|
|
|
|
|
{
|
|
|
|
|
#ifdef __HAWKVIS_MINDVISION_CCD__
|
|
|
|
|
if (m_pHawkvisCtrl->MV_GetOneFrame())
|
|
|
|
|
if (m_HawkvisCtrl.MV_GetOneFrame())
|
|
|
|
|
#else
|
|
|
|
|
if (m_HawkvisCtrl.HV_GetOneFrame())
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
m_pHawkvisCtrl->ZoomFitWindow();
|
|
|
|
|
m_HawkvisCtrl.ZoomFitWindow();
|
|
|
|
|
gLogMgr->WriteDebugLog("Hawkvis : FrameOne --OK");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
@ -613,7 +491,7 @@ void DlgHawkvisCamera::OnBnClickedTestDefinition()
|
|
|
|
|
|
|
|
|
|
CFileMgr fg;
|
|
|
|
|
CString path = fg.GetWorkPath();
|
|
|
|
|
m_pHawkvisCtrl->WriteImage((LPCTSTR)path, "PicForDefinition");
|
|
|
|
|
m_HawkvisCtrl.WriteImage((LPCTSTR)path, "PicForDefinition");
|
|
|
|
|
Sleep(50);
|
|
|
|
|
path += "\\PicForDefinition.bmp";
|
|
|
|
|
Mat imageSource = imread((LPCTSTR)path);
|
|
|
|
@ -625,7 +503,7 @@ void DlgHawkvisCamera::OnBnClickedTestDefinition()
|
|
|
|
|
Sobel(imageSource, imageSobel, CV_16U, 1, 1);
|
|
|
|
|
m_CurPic_Definition = mean(imageSobel)[0];
|
|
|
|
|
PostMessage(WM_UPDATE_FALSE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool DlgHawkvisCamera::bCurPicDefinitionOK()
|
|
|
|
|
{
|
|
|
|
|