mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
662 lines
16 KiB
662 lines
16 KiB
// WIATest.cpp : Defines the class behaviors for the application.
|
|
//
|
|
|
|
#include "stdafx.h"
|
|
#include "WIATest.h"
|
|
|
|
#include "MainFrm.h"
|
|
#include "WIATestDoc.h"
|
|
#include "WIATestView.h"
|
|
|
|
//
|
|
// enable/disable MessageBox Error reporting
|
|
//
|
|
#define _MESSAGEBOX_DEBUG
|
|
#define MIN_PROPID 2
|
|
|
|
#ifdef _DEBUG
|
|
#define new DEBUG_NEW
|
|
#undef THIS_FILE
|
|
static char THIS_FILE[] = __FILE__;
|
|
#endif
|
|
|
|
class CWiaTestCmdLineInfo : public CCommandLineInfo {
|
|
public:
|
|
virtual void ParseParam(const char* pszParam, BOOL bFlag, BOOL bLast);
|
|
};
|
|
|
|
void CWiaTestCmdLineInfo::ParseParam(const char* pszParam, BOOL bFlag, BOOL bLast)
|
|
{
|
|
TRACE("CWiaTestCmdLineInfo::ParseParam(%s)\n",pszParam);
|
|
}
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CWIATestApp
|
|
|
|
BEGIN_MESSAGE_MAP(CWIATestApp, CWinApp)
|
|
//{{AFX_MSG_MAP(CWIATestApp)
|
|
ON_COMMAND(ID_APP_ABOUT, OnAppAbout)
|
|
// NOTE - the ClassWizard will add and remove mapping macros here.
|
|
// DO NOT EDIT what you see in these blocks of generated code!
|
|
//}}AFX_MSG_MAP
|
|
// Standard file based document commands
|
|
ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew)
|
|
ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen)
|
|
END_MESSAGE_MAP()
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CWIATestApp construction
|
|
|
|
CWIATestApp::CWIATestApp()
|
|
{
|
|
// TODO: add construction code here,
|
|
// Place all significant initialization in InitInstance
|
|
}
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// The one and only CWIATestApp object
|
|
|
|
CWIATestApp theApp;
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CWIATestApp initialization
|
|
/**************************************************************************\
|
|
* CWIATestApp::InitInstance()
|
|
*
|
|
* Initializes Instance of the WIATEST application
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* none
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
BOOL CWIATestApp::InitInstance()
|
|
{
|
|
AfxEnableControlContainer();
|
|
|
|
// Standard initialization
|
|
|
|
#ifdef _AFXDLL
|
|
Enable3dControls(); // Call this when using MFC in a shared DLL
|
|
#else
|
|
Enable3dControlsStatic(); // Call this when linking to MFC statically
|
|
#endif
|
|
|
|
//SetRegistryKey(_T("WIATest"));
|
|
|
|
//LoadStdProfileSettings(0); // Load standard INI file options (including MRU)
|
|
|
|
// Register the application's document templates. Document templates
|
|
// serve as the connection between documents, frame windows and views.
|
|
|
|
//
|
|
// Save Command line
|
|
//
|
|
m_CmdLine = m_lpCmdLine;
|
|
|
|
CSingleDocTemplate* pDocTemplate;
|
|
pDocTemplate = new CSingleDocTemplate(
|
|
IDR_MAINFRAME,
|
|
RUNTIME_CLASS(CWIATestDoc),
|
|
RUNTIME_CLASS(CMainFrame), // main SDI frame window
|
|
RUNTIME_CLASS(CWIATestView));
|
|
AddDocTemplate(pDocTemplate);
|
|
|
|
// Parse command line for standard shell commands, DDE, file open
|
|
CWiaTestCmdLineInfo cmdInfo;
|
|
ParseCommandLine(cmdInfo);
|
|
|
|
// Dispatch commands specified on the command line
|
|
if (!ProcessShellCommand(cmdInfo))
|
|
return FALSE;
|
|
|
|
// The one and only window has been initialized, so show and update it.
|
|
m_pMainWnd->ShowWindow(SW_SHOW);
|
|
m_pMainWnd->UpdateWindow();
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
/**************************************************************************\
|
|
* CWIATestApp::ExitInstance()
|
|
*
|
|
* Exit routine for cleanup on WIATEST application
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* none
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
int CWIATestApp::ExitInstance()
|
|
{
|
|
return CWinApp::ExitInstance();
|
|
}
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CWIATestApp message handlers
|
|
|
|
/**************************************************************************\
|
|
* CWIATestApp::GetDeviceIDCommandLine()
|
|
*
|
|
* Retrieves Command line
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* none
|
|
*
|
|
* Return Value:
|
|
*
|
|
* CString - Command line
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
CString CWIATestApp::GetDeviceIDCommandLine()
|
|
{
|
|
return m_CmdLine;
|
|
}
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CAboutDlg dialog used for App About
|
|
|
|
class CAboutDlg : public CDialog {
|
|
public:
|
|
CAboutDlg();
|
|
|
|
// Dialog Data
|
|
//{{AFX_DATA(CAboutDlg)
|
|
enum {IDD = IDD_ABOUTBOX};
|
|
//}}AFX_DATA
|
|
|
|
// ClassWizard generated virtual function overrides
|
|
//{{AFX_VIRTUAL(CAboutDlg)
|
|
protected:
|
|
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
|
|
//}}AFX_VIRTUAL
|
|
|
|
// Implementation
|
|
protected:
|
|
//{{AFX_MSG(CAboutDlg)
|
|
// No message handlers
|
|
//}}AFX_MSG
|
|
DECLARE_MESSAGE_MAP()
|
|
};
|
|
|
|
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
|
|
{
|
|
//{{AFX_DATA_INIT(CAboutDlg)
|
|
//}}AFX_DATA_INIT
|
|
}
|
|
|
|
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
|
|
{
|
|
CDialog::DoDataExchange(pDX);
|
|
//{{AFX_DATA_MAP(CAboutDlg)
|
|
//}}AFX_DATA_MAP
|
|
}
|
|
|
|
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
|
|
//{{AFX_MSG_MAP(CAboutDlg)
|
|
// No message handlers
|
|
//}}AFX_MSG_MAP
|
|
END_MESSAGE_MAP()
|
|
|
|
/**************************************************************************\
|
|
* CWIATestApp::OnAppAbout()
|
|
*
|
|
* Activates the About Dialog!
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* none
|
|
*
|
|
* Return Value:
|
|
*
|
|
* none
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
void CWIATestApp::OnAppAbout()
|
|
{
|
|
CAboutDlg aboutDlg;
|
|
aboutDlg.DoModal();
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
/////////////////////////////////// UTILS SECTION ////////////////////////////////////////
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
/**************************************************************************\
|
|
* ::ReadPropStr
|
|
*
|
|
* Reads a BSTR value of a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* pbstr - returned BSTR read from property
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT ReadPropStr(PROPID propid,IWiaPropertyStorage *pIWiaPropStg,BSTR *pbstr)
|
|
{
|
|
HRESULT hResult = S_OK;
|
|
PROPSPEC PropSpec[1];
|
|
PROPVARIANT PropVar[1];
|
|
UINT cbSize = 0;
|
|
|
|
*pbstr = NULL;
|
|
memset(PropVar, 0, sizeof(PropVar));
|
|
PropSpec[0].ulKind = PRSPEC_PROPID;
|
|
PropSpec[0].propid = propid;
|
|
hResult = pIWiaPropStg->ReadMultiple(1, PropSpec, PropVar);
|
|
if (SUCCEEDED(hResult)) {
|
|
if (PropVar[0].pwszVal) {
|
|
*pbstr = SysAllocString(PropVar[0].pwszVal);
|
|
} else {
|
|
*pbstr = SysAllocString(L"");
|
|
}
|
|
if (*pbstr == NULL) {
|
|
//StressStatus("* ReadPropStr, SysAllocString failed");
|
|
hResult = E_OUTOFMEMORY;
|
|
}
|
|
PropVariantClear(PropVar);
|
|
} else {
|
|
//CString msg;
|
|
//msg.Format("* ReadPropStr, ReadMultiple of propid: %d, Failed", propid);
|
|
//StressStatus(msg);
|
|
}
|
|
return hResult;
|
|
}
|
|
/**************************************************************************\
|
|
* ::WritePropStr
|
|
*
|
|
* Writes a BSTR value to a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* pbstr - BSTR to write to target property
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT WritePropStr(PROPID propid, IWiaPropertyStorage *pIWiaPropStg, BSTR bstr)
|
|
{
|
|
HRESULT hResult = S_OK;
|
|
PROPSPEC propspec[1];
|
|
PROPVARIANT propvar[1];
|
|
|
|
propspec[0].ulKind = PRSPEC_PROPID;
|
|
propspec[0].propid = propid;
|
|
|
|
propvar[0].vt = VT_BSTR;
|
|
propvar[0].pwszVal = bstr;
|
|
|
|
hResult = pIWiaPropStg->WriteMultiple(1, propspec, propvar, MIN_PROPID);
|
|
return hResult;
|
|
}
|
|
|
|
/**************************************************************************\
|
|
* ::WritePropLong
|
|
*
|
|
* Writes a LONG value of a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* lVal - LONG to be written to target property
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT WritePropLong(PROPID propid, IWiaPropertyStorage *pIWiaPropStg, LONG lVal)
|
|
{
|
|
HRESULT hResult;
|
|
PROPSPEC propspec[1];
|
|
PROPVARIANT propvar[1];
|
|
|
|
propspec[0].ulKind = PRSPEC_PROPID;
|
|
propspec[0].propid = propid;
|
|
|
|
propvar[0].vt = VT_I4;
|
|
propvar[0].lVal = lVal;
|
|
|
|
hResult = pIWiaPropStg->WriteMultiple(1, propspec, propvar, MIN_PROPID);
|
|
return hResult;
|
|
}
|
|
|
|
/**************************************************************************\
|
|
* ::WritePropGUID
|
|
*
|
|
* Writes a GUID value of a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* guidVal - GUID to be written to target property
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT WritePropGUID(PROPID propid, IWiaPropertyStorage *pIWiaPropStg, GUID guidVal)
|
|
{
|
|
HRESULT hResult;
|
|
PROPSPEC propspec[1];
|
|
PROPVARIANT propvar[1];
|
|
|
|
propspec[0].ulKind = PRSPEC_PROPID;
|
|
propspec[0].propid = propid;
|
|
|
|
propvar[0].vt = VT_CLSID;
|
|
propvar[0].puuid = &guidVal;
|
|
|
|
hResult = pIWiaPropStg->WriteMultiple(1, propspec, propvar, MIN_PROPID);
|
|
return hResult;
|
|
}
|
|
|
|
/**************************************************************************\
|
|
* ::WriteProp
|
|
*
|
|
* Writes a value of a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* VarType - Varient Type
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* pVal - value to be written to target property (in string form)
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT WriteProp(unsigned int VarType,PROPID propid, IWiaPropertyStorage *pIWiaPropStg, LPCTSTR pVal)
|
|
{
|
|
HRESULT hResult;
|
|
WCHAR wsbuffer[MAX_PATH];
|
|
PROPSPEC propspec[1];
|
|
PROPVARIANT propvar[1];
|
|
propspec[0].ulKind = PRSPEC_PROPID;
|
|
propspec[0].propid = propid;
|
|
propvar[0].vt = (VARTYPE)VarType;
|
|
propvar[0].puuid = (GUID *)& GUID_NULL;
|
|
|
|
switch (VarType) {
|
|
case VT_I1:
|
|
sscanf(pVal,"%li",&propvar[0].cVal);
|
|
break;
|
|
case VT_I2:
|
|
sscanf(pVal,"%li",&propvar[0].bVal);
|
|
break;
|
|
case VT_I4:
|
|
sscanf(pVal,"%li",&propvar[0].lVal);
|
|
break;
|
|
case VT_I8:
|
|
sscanf(pVal,"%li",&propvar[0].hVal);
|
|
break;
|
|
case VT_UI1:
|
|
sscanf(pVal,"%li",&propvar[0].bVal);
|
|
break;
|
|
case VT_UI2:
|
|
sscanf(pVal,"%li",&propvar[0].uiVal);
|
|
break;
|
|
case VT_UI4:
|
|
sscanf(pVal,"%li",&propvar[0].ulVal);
|
|
break;
|
|
case VT_UI8:
|
|
sscanf(pVal,"%li",&propvar[0].lVal);
|
|
break;
|
|
case VT_INT:
|
|
sscanf(pVal,"%li",&propvar[0].intVal);
|
|
break;
|
|
case VT_R4:
|
|
sscanf(pVal,"%f",&propvar[0].fltVal);
|
|
break;
|
|
case VT_R8:
|
|
sscanf(pVal,"%f",&propvar[0].fltVal);
|
|
break;
|
|
case VT_BSTR:
|
|
MultiByteToWideChar(CP_ACP, 0,pVal,-1,wsbuffer,MAX_PATH);
|
|
propvar[0].bstrVal = SysAllocString(wsbuffer);
|
|
break;
|
|
case VT_CLSID:
|
|
UuidFromString((UCHAR*)pVal,propvar[0].puuid);
|
|
break;
|
|
case VT_UINT:
|
|
sscanf(pVal,"%li",&propvar[0].uintVal);
|
|
break;
|
|
default:
|
|
sscanf(pVal,"%li",&propvar[0].lVal);
|
|
break;
|
|
}
|
|
|
|
hResult = pIWiaPropStg->WriteMultiple(1, propspec, propvar, MIN_PROPID);
|
|
|
|
return hResult;
|
|
}
|
|
|
|
/**************************************************************************\
|
|
* ::ReadPropLong
|
|
*
|
|
* Reads a long value from a target property
|
|
*
|
|
*
|
|
* Arguments:
|
|
*
|
|
* propid - property ID
|
|
* pIWiaPropStg - property storage
|
|
* plval - returned long read from property
|
|
*
|
|
* Return Value:
|
|
*
|
|
* status
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
HRESULT ReadPropLong(PROPID propid, IWiaPropertyStorage *pIWiaPropStg, LONG *plval)
|
|
{
|
|
HRESULT hResult = S_OK;
|
|
PROPSPEC PropSpec[1];
|
|
PROPVARIANT PropVar[1];
|
|
UINT cbSize = 0;
|
|
|
|
memset(PropVar, 0, sizeof(PropVar));
|
|
PropSpec[0].ulKind = PRSPEC_PROPID;
|
|
PropSpec[0].propid = propid;
|
|
hResult = pIWiaPropStg->ReadMultiple(1, PropSpec, PropVar);
|
|
if (SUCCEEDED(hResult)) {
|
|
*plval = PropVar[0].lVal;
|
|
}
|
|
return hResult;
|
|
}
|
|
|
|
|
|
/**************************************************************************\
|
|
* ::StressStatus
|
|
*
|
|
* Reports status to user via status list box
|
|
*
|
|
* Arguments:
|
|
*
|
|
* status - CString value to be displayed in the list box
|
|
*
|
|
* Return Value:
|
|
*
|
|
* void
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
void StressStatus(CString status)
|
|
{
|
|
/*
|
|
int iLine = m_StressStatusListBox.AddString(status);
|
|
m_StressStatusListBox.SetTopIndex(iLine);
|
|
if(m_bLoggingEnabled)
|
|
{
|
|
if(m_LogFile)
|
|
{
|
|
m_LogFile.Write(status.GetBuffer(256),status.GetLength());
|
|
m_LogFile.Write("\r\n",2);
|
|
}
|
|
|
|
}
|
|
*/
|
|
OutputDebugString(status + "\n");
|
|
#ifdef _DEBUG
|
|
//OutputDebugString(status + "\n");
|
|
#endif
|
|
}
|
|
/**************************************************************************\
|
|
* ::StressStatus
|
|
*
|
|
* Reports status, and hResult to user via status list box
|
|
*
|
|
* Arguments:
|
|
*
|
|
* status - CString value to be displayed in the list box
|
|
* hResult - hResult to be translated
|
|
*
|
|
* Return Value:
|
|
*
|
|
* void
|
|
*
|
|
* History:
|
|
*
|
|
* 2/14/1999 Original Version
|
|
*
|
|
\**************************************************************************/
|
|
void StressStatus(CString status, HRESULT hResult)
|
|
{
|
|
CString msg;
|
|
ULONG ulLen = MAX_PATH;
|
|
LPTSTR pMsgBuf = (char*)LocalAlloc(LPTR,MAX_PATH);
|
|
|
|
//
|
|
// attempt to handle WIA custom errors first
|
|
//
|
|
|
|
switch (hResult) {
|
|
case WIA_ERROR_GENERAL_ERROR:
|
|
sprintf(pMsgBuf,"There was a general device failure.");
|
|
break;
|
|
case WIA_ERROR_PAPER_JAM:
|
|
sprintf(pMsgBuf,"The paper path is jammed.");
|
|
break;
|
|
case WIA_ERROR_PAPER_EMPTY:
|
|
sprintf(pMsgBuf,"There are no documents in the input tray to scan.");
|
|
break;
|
|
case WIA_ERROR_PAPER_PROBLEM:
|
|
sprintf(pMsgBuf,"There is a general problem with an input document.");
|
|
break;
|
|
case WIA_ERROR_OFFLINE:
|
|
sprintf(pMsgBuf,"The device is offline.");
|
|
break;
|
|
case WIA_ERROR_BUSY:
|
|
sprintf(pMsgBuf,"The device is busy.");
|
|
break;
|
|
case WIA_ERROR_WARMING_UP:
|
|
sprintf(pMsgBuf,"The device is warming up.");
|
|
break;
|
|
case WIA_ERROR_USER_INTERVENTION:
|
|
sprintf(pMsgBuf,"The user has paused or stopped the device.");
|
|
break;
|
|
default:
|
|
|
|
//
|
|
// free temp buffer, because FormatMessage() will allocate it for me
|
|
//
|
|
|
|
LocalFree(pMsgBuf);
|
|
ulLen = 0;
|
|
ulLen = ::FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM,
|
|
NULL, hResult, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
|
|
(LPTSTR)&pMsgBuf, 0, NULL);
|
|
break;
|
|
}
|
|
|
|
if (ulLen) {
|
|
msg = pMsgBuf;
|
|
msg.TrimRight();
|
|
LocalFree(pMsgBuf);
|
|
} else {
|
|
// use sprintf to write to buffer instead of .Format member of
|
|
// CString. This conversion works better for HEX
|
|
char buffer[255];
|
|
sprintf(buffer,"hResult = 0x%08X",hResult);
|
|
msg = buffer;
|
|
}
|
|
StressStatus(status + ", " + msg);
|
|
|
|
#ifdef _MESSAGEBOX_DEBUG
|
|
MessageBox(NULL,status+ ", " + msg,"WIATest Debug Report",MB_OK|MB_ICONERROR);
|
|
#endif
|
|
}
|