技术标签: 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;
}
开始接收连续帧图像
题库来源:安全生产模拟考试一点通公众号小程序2020年土建方向-通用基础(施工员)多少分及格及土建方向-通用基础(施工员)新版试题,包含土建方向-通用基础(施工员)多少分及格答案和解析及土建方向-通用基础(施工员)新版试题练习。由安全生产模拟考试一点通公众号结合国家土建方向-通用基础(施工员)考试最新大纲及土建方向-通用基础(施工员)考试真题汇总,有助于土建方向-通用基础(施工员)模拟试题考前练习。1、【判断题】挠度观测属于变形观测的一种。(√)2、【判断题】水准仪粗略整平的目的是使...
摘要: EMR资讯: EMR上线新地域:德国法兰克福资讯 AI 大师云集!CCAI 2017 中国人工智能大会盛大开幕7 月 22 - 23 日,在中国科学技术协会、中国科学院的指导下,由中国人工智能学会、阿里巴巴集团 & 蚂蚁金服主办,CSDN、中国科学院自动化研究所承办的 2017 中国人工智能大会(CCAI 2017)在杭州国际会议中心盛大召开。EMR资讯:EMR上线新地
随着vr全景应用范围的扩大和普及,使得很多朋友关注到了这一技术。相较于图文视频等展现方式而言,vr全景像是展现形式的一个重大升级,不仅能够提供身临其境般的视角体验,更是能够融合各种功能和技术。这也给vr全景这一富媒体技术赋予了更多可能,针对不同的应用场景,结合不同技术和功能,就能够解决不同的行业痛点。很多感兴趣的朋友一定对vr全景制作方法还比较疑惑,今天这里就为大家带来了vr全景拍摄制作教程,相信大家看完全部的流程及总结之后就会全明白了。一、准备拍摄设备:相机、云台、三脚架、存储卡、相机电池、鱼眼镜头
首先介绍一下如何使用webpack来配置vue组件。第一步:在终端运行npm i vue-loader vue-template-compiler -D,安装处理vue组件的加载器,其中vue-template-compiler -D是vue-loader的内置依赖项。第二步:在项目的webpack.config.js文件中添加vue-loader的配置:①首先需要导入vue组件插件:const VueLoaderPlugin = require('vue-loader/lib/plugin.j
案例1. 找到这个字符串中的每个字符串出现了多少次&lt;script&gt; var str = "hello wod odd ott fbo nhyo"; var key = "o"; // 开始的位置 var index = 0; // 要找的字符串 while ((index =str.index...
wepy-CLI安装npm install -g wepy-cliwepy init standard my-projecthttps://github.com/Tencent/wepy特性:类Vue开发风格支持自定义组件开发支持引入NPM包支持Promise支持ES2015+特性,如Async Functions支持多种编译器,Less/Sass/Stylus/Post...
在.vscode目录下新建一个json文件:c_cpp_properties.json,注意includePath和compilerPath要指定到msys2安装目录下。还有个问题,就是VSCode显示#include 这一行有错,鼠标移上去显式找不到依赖文件stddef.h。把这个目录也添加到c_cpp_properties.json的includePath中,问题解决。原因是VSCode做代码分析的时候不知道gcc,选择了MSVC,添加配置文件把编译器改为gcc.愉快的coding!
running pre-commit hook: lint-staged前言错误日志分析解决办法前言vue项目中有些做了语法校验,遇到了git提交失败,根据错误提示,成功解决了问题。错误日志running pre-commit hook: lint-staged分析这句话的意思,大概是有一个钩子,提交前检查项目代码的规范,eslint的检查。提交失败的原因:项目中error过多,导致...
如题,目前cddis网站提供了既有rinex2、也有rinex3的数据,gamit 10.71的sh_get_rinex命令,如果从cddis网站下载,会首先下载两种格式的观测数据,也就是,例如brst0960.18d.ZBRST00FRA_R_20180960000_01D_30S_MO.crx.gz会把这2种格式的数据都下载到本地,然后解压,仅保留1个rinex3的o文件,其余的压缩文...
使用centos开发C语言程序,GCC编译时报错:bash:gcc:command not found解决方式,安装gcc环境我们知道,用yum install gcc可以安装gcc编译环境,关于 GCC 在 CentOS 下通过 yum 安装默认版本号,CentOS 5 是 4.1.2;CentOS 6 是 4.4.7;CentOS 7 是 4.8.3。很多时候在编译安装软件都需要高版本的 GC...
2.Mysql安装步骤:1)查看CentOS自带的mysql输入 rpm -qa | grep mysql2)将自带的mysql卸载rpm -e --nodeps mysql*3)上传Mysql到linux4)安装mysql的依赖(选做)yum -y install libaio.so.1 libgcc_s.so.1 libstdc++.so.6yum update libstdc+±4.4.7-4.el6.x86_645)解压Mysql到/usr/local/下的mysql目录(mys
1.光标移动到aaa的开头,按 v 按e 按y2.光标移动到bbb的开头,按 v 按e 按p也就说,快速选中一个单词,按v按e即可。