MyLabJackDlg.h
// MyLabJackDlg.h : 头文件
//
#pragma once
#include "afxwin.h"
#include <stdio.h>
#include <windows.h>
#include "C:\Program Files (x86)\LabJack\Drivers\LabJackUD.h"
// CMyLabJackDlg 对话框
class CMyLabJackDlg : public CDialogEx
{
// 构造
public:
CMyLabJackDlg(CWnd* pParent = NULL); // 标准构造函数
// 对话框数据
enum { IDD = IDD_MYLABJACK_DIALOG };
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();
DECLARE_MESSAGE_MAP()
public:
CString Edit_AIN0;
CString Edit_AIN1;
CString Edit_AIN2;
CString Edit_AIN3;
CButton bt_start;
CButton bt_stop;
double StartAIN0;
double StartAIN1;
bool setvalue;
bool timerstate;
LJ_ERROR lngErrorcode;
LJ_HANDLE lngHandle;
double dblValue;
long lngValue;
long lngBinary;
afx_msg void OnTimer(UINT_PTR nIDEvent);
afx_msg void OnBnClickedButton1();
afx_msg void OnBnClickedButton2();
afx_msg void OnBnClickedButton3();
CString Edit_SAIN0;
CString Edit_SAIN1;
CString Edit_Arcsin0;
CString Edit_Arcsin1;
CButton bt_setvalue;
void ErrorHandler (LJ_ERROR lngErrorcode, long lngLineNumber, long lngIteration);
};
MyLabJackDlg.cpp
// MyLabJackDlg.cpp : 实现文件
//
#include "stdafx.h"
#include "MyLabJack.h"
#include "MyLabJackDlg.h"
#include "afxdialogex.h"
#include <math.h>
#include <iostream>
#include <fstream>
using namespace std;
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();
// 对话框数据
enum { IDD = IDD_ABOUTBOX };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
ON_WM_MOVING()
END_MESSAGE_MAP()
// CMyLabJackDlg 对话框
CMyLabJackDlg::CMyLabJackDlg(CWnd* pParent /*=NULL*/)
: CDialogEx(CMyLabJackDlg::IDD, pParent)
, Edit_SAIN0(_T(""))
, Edit_SAIN1(_T(""))
, Edit_Arcsin0(_T(""))
, Edit_Arcsin1(_T(""))
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
Edit_AIN0 = _T("");
}
void CMyLabJackDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
DDX_Control(pDX, IDC_BUTTON1, bt_start);
DDX_Control(pDX, IDC_BUTTON2, bt_stop);
DDX_Text(pDX, IDC_EDIT1, Edit_AIN0);
DDV_MaxChars(pDX, Edit_AIN0, 30);
DDX_Text(pDX, IDC_EDIT2, Edit_AIN1);
DDV_MaxChars(pDX, Edit_AIN1, 30);
DDX_Text(pDX, IDC_EDIT3, Edit_AIN2);
DDV_MaxChars(pDX, Edit_AIN2, 30);
DDX_Text(pDX, IDC_EDIT4, Edit_AIN3);
DDV_MaxChars(pDX, Edit_AIN3, 30);
DDX_Text(pDX, IDC_EDIT5, Edit_SAIN0);
DDV_MaxChars(pDX, Edit_SAIN0, 30);
DDX_Text(pDX, IDC_EDIT6, Edit_SAIN1);
DDV_MaxChars(pDX, Edit_SAIN1, 30);
DDX_Text(pDX, IDC_EDIT7, Edit_Arcsin0);
DDV_MaxChars(pDX, Edit_Arcsin0, 30);
DDX_Text(pDX, IDC_EDIT8, Edit_Arcsin1);
DDX_Control(pDX, IDC_BUTTON3, bt_setvalue);
}
BEGIN_MESSAGE_MAP(CMyLabJackDlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_BUTTON1, &CMyLabJackDlg::OnBnClickedButton1)
ON_WM_TIMER()
ON_BN_CLICKED(IDC_BUTTON2, &CMyLabJackDlg::OnBnClickedButton2)
ON_BN_CLICKED(IDC_BUTTON3, &CMyLabJackDlg::OnBnClickedButton3)
END_MESSAGE_MAP()
//This is our simple error handling function that is called after every UD
//function call. This function displays the errorcode and string description
//of the error. It also has a line number input that can be used with the
//macro __LINE__ to display the line number in source code that called the
//error handler. It also has an iteration input is useful when processing
//results in a loop (getfirst/getnext).
void CMyLabJackDlg::ErrorHandler (LJ_ERROR lngErrorcode, long lngLineNumber, long lngIteration)
{
char err[255];
if (lngErrorcode != LJE_NOERROR)
{
ErrorToString(lngErrorcode,err);
CString str;
str.Format("Error number = %d\nError string = %s\nSource line number = %d\nIteration = %d\n\n",lngErrorcode ,err ,lngLineNumber ,lngIteration);
MessageBox(str.GetString());
if(lngErrorcode > LJE_MIN_GROUP_ERROR)
{
exit(0);
}
}
}
// CMyLabJackDlg 消息处理程序
BOOL CMyLabJackDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 将“关于...”菜单项添加到系统菜单中。
// IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
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: 在此添加额外的初始化代码
double dblValue=0;
long lngValue=0;
LJ_HANDLE lngHandle=0;
setvalue=false;
timerstate=false;
CString tmp;
StartAIN0=2.482;
StartAIN1=2.472;
UpdateData(1);
tmp.Format("%f",StartAIN0);
Edit_SAIN0=tmp;
tmp.Format("%f",StartAIN1);
Edit_SAIN1=tmp;
UpdateData(0);
fstream out;
out.open("e:\\test.txt",ios::app|ios::in);
out.seekg(ios::beg);
if(out.rdbuf()->sgetc()==char_traits<char>::eof())
out<<"systemtime"<<'\t'<<"arcsin(AIN0)"<<'\t'<<"arcsin(AIN1)"<<endl;
out.close();
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CMyLabJackDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}
// 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。
void CMyLabJackDlg::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 CMyLabJackDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CMyLabJackDlg::OnBnClickedButton1() //开启定时器1
{
// TODO: 在此添加控件通知处理程序代码
if(timerstate==false)
{
SetTimer(1,60,NULL);//启动定时器1,定时时间是60ms
timerstate=true;
}
}
void CMyLabJackDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
//写入文件
ofstream out;
out.open("e:\\test.txt",ios::app);
CString strtime;
SYSTEMTIME st;
GetLocalTime(&st);
strtime.Format("%2d%2d%2d%3d",st.wHour,st.wMinute,st.wSecond,st.wMilliseconds);
out<<strtime<<'\t';
//Open the first found LabJack U3.
lngErrorcode = OpenLabJack (LJ_dtU3, LJ_ctUSB, "1", 1, &lngHandle);
ErrorHandler(lngErrorcode, __LINE__, 0);
//Start by using the pin_configuration_reset IOType so that all
//pin assignments are in the factory default condition.
lngErrorcode = ePut (lngHandle, LJ_ioPIN_CONFIGURATION_RESET, 0, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
CString ss;
UpdateData(1);
/*****************************************************************************/
//Take a single-ended measurement from AIN0.
lngBinary = 0;
lngErrorcode = eAIN (lngHandle, 0, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
ss.Format(TEXT("%f"),dblValue);
Edit_AIN0=ss;
//反正弦
dblValue=asin((dblValue-StartAIN0)/1.2);
if(dblValue>1)
{
dblValue=1;
}
else if(dblValue<-1)
{
dblValue=-1;
}
ss.Format(TEXT("%f"),dblValue);
Edit_Arcsin0=ss;
out<<ss<<'\t';
lngErrorcode = eAIN (lngHandle, 1, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
ss.Format(TEXT("%f"),dblValue);
Edit_AIN1=ss;
//反正弦
dblValue=asin((dblValue-StartAIN1)/1.2);
if(dblValue>1)
{
dblValue=1;
}
else if(dblValue<-1)
{
dblValue=-1;
}
ss.Format(TEXT("%f"),dblValue);
Edit_Arcsin1=ss;
out<<ss<<'\t'<<endl;
lngErrorcode = eAIN (lngHandle, 2, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
ss.Format(TEXT("%f"),dblValue);
Edit_AIN2=ss;
lngErrorcode = eAIN (lngHandle, 3, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
ss.Format(TEXT("%f"),dblValue);
Edit_AIN3=ss;
UpdateData(0);
/*****************************************************************************/
CDialogEx::OnTimer(nIDEvent);
out.close();
}
void CMyLabJackDlg::OnBnClickedButton2() //关闭定时器1。
{
// TODO: 在此添加控件通知处理程序代码
if(timerstate==true)
{
KillTimer(1); //关闭定时器1。
timerstate=false;
}
}
void CMyLabJackDlg::OnBnClickedButton3()//设置初值
{
// TODO: 在此添加控件通知处理程序代码
//Open the first found LabJack U3.
if(timerstate==true)
{
KillTimer(1); //关闭定时器1。
timerstate=false;
}
bt_start.EnableWindow(false);
bt_stop.EnableWindow(false);
bt_setvalue.EnableWindow(false);
bt_setvalue.SetWindowTextA("请等待10s...");
lngErrorcode = OpenLabJack (LJ_dtU3, LJ_ctUSB, "1", 1, &lngHandle);
ErrorHandler(lngErrorcode, __LINE__, 0);
double A0[10],A1[10];
for(int i=0;i<10;i++)
{
//Take a single-ended measurement from AIN0.
lngBinary = 0;
lngErrorcode = eAIN (lngHandle, 0, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
A0[i]=dblValue;
//Take a single-ended measurement from AIN1.
lngErrorcode = eAIN (lngHandle, 1, 31, &dblValue, -1, -1, -1, lngBinary, 0, 0);
ErrorHandler(lngErrorcode, __LINE__, 0);
A1[i]=dblValue;
Sleep(1000);
}
for(int i=0;i<10;i++)
{
StartAIN0+=A0[i];
StartAIN1+=A1[i];
}
StartAIN0 /= 10.0;
StartAIN1 /= 10.0;
setvalue=true;
CString tmp;
UpdateData(1);
tmp.Format("%f",StartAIN0);
Edit_SAIN0=tmp;
tmp.Format("%f",StartAIN1);
Edit_SAIN1=tmp;
UpdateData(0);
bt_start.EnableWindow(true);
bt_stop.EnableWindow(true);
bt_setvalue.EnableWindow(true);
bt_setvalue.SetWindowTextA("重设初值(10s)");
}
结果: