技术标签: Sapera LT++ vs2017
Sapera LT++ 连续帧视频的抓取
提示:以下是本篇文章正文内容
新建MFC对话框工程,配置环境变量,主要以下两张图的配置,附加包含目录和附加依赖项
D:\Program Files\Teledyne DALSA\Sapera\Classes\Basic
D:\Program Files\Teledyne DALSA\Sapera\Classes\Gui
D:\Program Files\Teledyne DALSA\Sapera\Include
添加包含目录根据自己的安装Sapera LT的路径下找,本文是在D:/Program Files/下
D:\Program Files\Teledyne DALSA\Sapera\Lib\Win64\SapClassBasic.lib
D:\Program Files\Teledyne DALSA\Sapera\Lib\Win64\VS2017\SapClassGuiD.lib
#include"SapClassBasic.h"
#include"SapClassGui.h"
所建项目的头文件代码如下(GrabMFCDlg.h):
// GrabMFCDlg.h: 头文件
//
#pragma once
#include"SapClassBasic.h"
#include"SapClassGui.h"
#include<opencv2/opencv.hpp>
// CGrabMFCDlg 对话框
class CGrabMFCDlg : public CDialogEx
{
// 构造
public:
CGrabMFCDlg(CWnd* pParent = nullptr); // 标准构造函数
static void XferCallback(SapXferCallbackInfo*pInfo);
SapAcquisition *m_Acq; // 设备的连接地址
SapBuffer *m_Buffers; // 缓存对象
SapTransfer *m_Xfer;
SapView *m_View;
// 对话框数据
//#ifdef AFX_DESIGN_TIME
enum {
IDD = IDD_GRABMFC_DIALOG };
//#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
HICON m_hIcon;
// 生成的消息映射函数
virtual BOOL OnInitDialog();
afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
afx_msg void OnDestroy();
DECLARE_MESSAGE_MAP()
public:
//...........................................
static int staticCount;
};
// GrabMFCDlg.cpp: 实现文件
//
#include "pch.h"
#include "framework.h"
#include "GrabMFC.h"
#include "GrabMFCDlg.h"
#include "afxdialogex.h"
#include<string>
using namespace std;
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();
// 对话框数据
#ifdef AFX_DESIGN_TIME
enum {
IDD = IDD_ABOUTBOX };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX)
{
}
int CGrabMFCDlg::staticCount = 0;
static long currentFrame = 1;
static SapGio *m_pGioInput;
cv::Mat global_source_image;
bool callback_flag;
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()
// CGrabMFCDlg 对话框
CGrabMFCDlg::CGrabMFCDlg(CWnd* pParent /*=nullptr*/)
: CDialogEx(IDD_GRABMFC_DIALOG, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CGrabMFCDlg::XferCallback(SapXferCallbackInfo * pInfo)
{
CGrabMFCDlg *pDlg = (CGrabMFCDlg*)pInfo->GetContext();
//Refresh view
pDlg->m_View->Show();
//BYTE pData;
//void* pDataAddr = &pData;
//BOOL success = pDlg->m_Buffers->GetAddress(staticCount, &pDataAddr);
//int width = pDlg->m_Buffers->GetWidth();
//int height = pDlg->m_Buffers->GetHeight();
//cv::Mat img = cv::Mat::zeros(cv::Size(width, height), CV_8U);
//memcpy(img.data, pDataAddr, width*height);
//img.copyTo(global_source_image);
//cv::namedWindow("image", cv::WINDOW_AUTOSIZE);
//cv::imshow("image", img);
//stringstream str1;
//str1 << "D:/picture/00" << currentFrame << ".jpg";
imwrite(str1.str(), img);
//currentFrame++;
//callback_flag = true; //自定义全局变量
//cv::waitKey(10);
}
void CGrabMFCDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CGrabMFCDlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_WM_DESTROY()
END_MESSAGE_MAP()
// CGrabMFCDlg 消息处理程序
BOOL CGrabMFCDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 将“关于...”菜单项添加到系统菜单中。
// IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != nullptr)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// 设置此对话框的图标。 当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标
// TODO: 在此添加额外的初始化代码
CAcqConfigDlg dlg(this, nullptr);
INT_PTR nResponse = dlg.DoModal();
if (nResponse == IDOK) {
m_Acq = new SapAcquisition(dlg.GetAcquisition());
m_Buffers = new SapBufferWithTrash(2, m_Acq);
m_View = new SapView(m_Buffers, GetSafeHwnd());
m_Xfer = new SapAcqToBuf(m_Acq, m_Buffers, XferCallback, this);
// Create acquisition object
if (m_Acq && !*m_Acq && !m_Acq->Create())
OnCancel();
// Create buffer object
if (m_Buffers && !*m_Buffers && !m_Buffers->Create())
OnCancel();
// Set client area dimensions to match the dimensions of the buffer
RECT windowRect, clientRect;
int MarginsWidth, MarginsHeight, ScreenWidth, ScreenHeight, WindowWidth, WindowHeight;
GetClientRect(&clientRect);
GetWindowRect(&windowRect);
ScreenWidth = GetSystemMetrics(SM_CXSCREEN);
ScreenHeight = GetSystemMetrics(SM_CYSCREEN);
MarginsWidth = (windowRect.right - windowRect.left) - clientRect.right;
MarginsHeight = (windowRect.bottom - windowRect.top) - clientRect.bottom;
WindowWidth = ((m_Buffers->GetWidth() + MarginsWidth) < ScreenWidth) ? (m_Buffers->GetWidth() + MarginsWidth) : ScreenWidth;
WindowHeight = ((m_Buffers->GetHeight() + MarginsHeight) < ScreenHeight) ? (m_Buffers->GetHeight() + MarginsHeight) : ScreenHeight;
MoveWindow(windowRect.left, windowRect.top, WindowWidth, WindowHeight);
// Create transfer object
if (m_Xfer && !*m_Xfer && !m_Xfer->Create())
OnCancel();
// Create view object
if (m_View && !*m_View && !m_View->Create())
OnCancel();
// Start continuous transfer (live grab)
m_Xfer->Grab();
//m_Xfer->Snap(m_Buffers->GetCount());
}
else
{
MessageBox(_T("No acquisition server found"));
OnCancel();
}
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CGrabMFCDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}
// 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。
void CGrabMFCDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作区矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialogEx::OnPaint();
}
}
//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CGrabMFCDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CGrabMFCDlg::OnDestroy()
{
CDialogEx::OnDestroy();
// TODO: 在此处添加消息处理程序代码
// Stop acquisition
if (m_Xfer && *m_Xfer)
{
m_Xfer->Freeze();
// Wait for the acquisition to complete
if (CAbortDlg(this, m_Xfer).DoModal() != IDOK)
m_Xfer->Abort();
}
// Destroy view object
if (m_View && *m_View) m_View->Destroy();
// Destroy transfer object
if (m_Xfer && *m_Xfer) m_Xfer->Destroy();
// Destroy buffer object
if (m_Buffers && *m_Buffers) m_Buffers->Destroy();
// Destroy acquisition object
if (m_Acq && *m_Acq) m_Acq->Destroy();
// Delete all objects
if (m_View) delete m_View;
if (m_Xfer) delete m_Xfer;
if (m_Buffers) delete m_Buffers;
if (m_Acq) delete m_Acq;
}
开始接收连续帧图像
文章浏览阅读1.7k次。转载自https://www.jianshu.com/p/fd447413e335信用风险与反欺诈哪个更加重要?为什么是先讲策略再谈模型?一个完整的反欺诈流程如何搭建?如何说服CEO接受模型测试成本?在一本财经商学院举办的第二期风控闭门课程上,天创信用首席科学家陈黎明一一做出解答。以下是她现场分享的部分干货:01基本概念今天我讲的主要课题是“反欺诈策略和模型”。为什么要把策略放前面呢?因为不管是拍脑袋决定,还是通过数据挖掘出来,反欺诈一般是先有策略,然后通过数据的积累,慢慢去构建模型。首先讲一下
文章浏览阅读5.6k次。经验证,hive中修改字段顺序并没有将字段对应的值移动,只是单纯的修改字段名,如果是空表(没有数据),可以使用以上两步;其中CASCADE选项为选填的字段,但是对于分区表,一定要加上,否则其历史分区的元数据信息(metadata)将无法正常更新,导致访问历史分区时会报莫名的错误。背景:项目中,客户使用hive内表,由于逻辑变更,原hive表结构需要调整,新增字段。如果已经添加了字段,可以修改字段时,在修改字段名时带上,在修改回来。实际上,使用alter语句,把保留的字段全部列出来,删除的字段不要列出来。_hive 新增字段
文章浏览阅读357次。测试 insert 时,hoodie.datasource.write.payload.class 有影响,而 hoodie.compaction.payload.class.class 没有影响,即使设置为错误值。_error -1 (00000) : while preparing sql: upsert into driver_point("id","latit
文章浏览阅读331次,点赞9次,收藏8次。Linux快捷键小技巧
文章浏览阅读192次。Pimpl习惯用法指的是pointer to implementation,即指涉到实现的指针。这种技巧就是把某类的数据成员用一个指涉到某实现类的指针替代,然后把原来在主类中的数据成员放置到实现类中,并通过指针间接访问这些数据成员。示例代码://Widget.h中class Widget {public: Widget();private: class Impl; //声明结构体或类 std::unique_ptr<Impl.._pimpl effecitve modern c++
文章浏览阅读834次,点赞19次,收藏20次。温故而知新,我们来简单回顾一下上篇的内容,上一篇我们分析了SpringApplication 对象的构建过程及 SpringBoot 自己实现的一套 SPI 机制,现将关键步骤再浓缩总结下:在 SpringBoot 启动过程中,每个不同的启动阶段会分别广播不同的内置生命周期事件,然后相应的监听器会监听这些事件来执行一些初始化逻辑工作比如会监听事件来加载配置文件的环境变量等。因此本篇内容将来分析下 SpringBoot 的事件监听机制的源码。为了探究 SpringBoot 广播内置生命周期事件流程,我们再来回_springboot监听机制
文章浏览阅读857次,点赞21次,收藏23次。写清楚需求:在给出提示词的时候,我们通过添加场景、添加角色,让我们的需求更加明确。将复杂的任务拆分为更简单的子任务:需求分析本身就是一个复杂的过程,我们需要逐步拆解,并纠正GPT的回复,引导GPT给到更多的信息。系统的测试变化:在返回信息过程中,如果返回信息不满足需求,或者有偏差,需要测试回复信息,并予以修正。角色扮演:在给出提示词的过程中,我们告诉GPT,需要以一个测试工程师的角色给出对应的测试点。
文章浏览阅读1w次,点赞3次,收藏14次。大家都知道,我们会做倒计时装置,而倒计时装置就需要暂停(等待)时间。如何实现这个功能呢?_c++怎么让程序暂停几秒
文章浏览阅读688次,点赞2次,收藏7次。↑↑↑关注后"星标"Datawhale每日干货&每月组队学习,不错过Datawhale干货作者:李金泽,清华大学,Datawhale作者前言一晃接近三个月..._李金泽 清华大学论文
文章浏览阅读24次。0 简介今天学长向大家介绍一个机器视觉的毕设项目毕业设计 lstm股价预测长短期记忆 (LSTM) 神经网络属于循环神经网络 (RNN) 的一种,特别适合处理和预测与时间序列相关的重要事件。以下面的句子作为一个上下文推测的例子:“我从小在法国长大,我会说一口流利的??由于同一句话前面提到”法国“这个国家,且后面提到“说”这个动作。因此,LSTM便能从”法国“以及”说“这两个长短期记忆中重要的讯号推测出可能性较大的”法语“这个结果。
文章浏览阅读1.7w次。i7-11800H基本参数为:8 核16 线程,2.3-4.6GHz,三级缓存达到了24MB。作为对比,去年的移动端主力标压处理器i7-10875H为8 核16 线程,2.3-5.1GHz,三级缓存16MB。i7-11800H 的核显也升级到了最新的 Xe 架构,32EU,1.45GHz选i9 11980HK、i7 11800h还是i9 11900H 这些点很重要!看完你就知道了http://www.adiannao.cn/dyi9 11980HK采用10nm SuperFin工艺制程,拥有8核16线_i9-11980hk 需要开启超频吗
文章浏览阅读6k次。2015年11月17上传以下是我实现的相机标定 C++ 类,构造函数如下:CCalibration::CCalibration(CvSize _board_sz, double _board_dt, int _n_boards){ //标定板的信息 board_sz = _board_sz; board_dt = _board_dt; n_boards = _n_boar_vscode opencv c++ 双目相机标定