Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

247 lines
6.5 KiB

#include "stdafx.h"
#include "hpscl.h"
#include "datadump.h"
CHPSCL::CHPSCL(PDEVCTRL pDeviceControl)
{
m_pDeviceControl = pDeviceControl;
}
CHPSCL::~CHPSCL()
{
}
BOOL CHPSCL::SetXRes(LONG xRes)
{
m_xres = xRes;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
sprintf(pbuffer,"\x1B*a%dR",xRes);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetYRes(LONG yRes)
{
m_yres = yRes;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
sprintf(pbuffer,"\x1B*a%dS",yRes);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetXPos(LONG xPos)
{
m_xpos = xPos;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
LONG OpticalValue = xPos;
OpticalValue = ((OpticalValue * 300) / m_xres);
sprintf(pbuffer,"\x1B*f%dX",OpticalValue);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetYPos(LONG yPos)
{
m_ypos = yPos;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
LONG OpticalValue = yPos;
OpticalValue = ((OpticalValue * 300) / m_yres);
sprintf(pbuffer,"\x1B*f%dY",OpticalValue);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetXExt(LONG xExt)
{
m_xext = xExt;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
LONG OpticalValue = xExt;
OpticalValue = ((OpticalValue * 300) / m_xres);
sprintf(pbuffer,"\x1B*f%dP",OpticalValue);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetYExt(LONG yExt)
{
m_yext = yExt;
CHAR pbuffer[64];
memset(pbuffer,0,sizeof(pbuffer));
LONG OpticalValue = yExt;
OpticalValue = ((OpticalValue * 300) / m_yres);
sprintf(pbuffer,"\x1B*f%dQ",OpticalValue);
return RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)pbuffer,lstrlenA(pbuffer),0);
}
BOOL CHPSCL::SetDataType(LONG DataType)
{
m_datatype = DataType;
BOOL bSuccess = TRUE;
switch(m_datatype){
case 0: // WIA_DATA_THRESHOLD
bSuccess = RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a0T",5,0);
if(bSuccess){
return RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a1G",5,0);
}
break;
case 1: // WIA_DATA_GRAYSCALE
bSuccess = RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a4T",5,0);
if(bSuccess){
return RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a8G",5,0);
}
break;
case 2: // WIA_DATA_COLOR
bSuccess = RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a5T",5,0);
if(bSuccess){
return RawWrite(m_pDeviceControl->BulkInPipeIndex,
(PBYTE)"\x1B*a24G",6,0);
}
break;
default:
break;
}
return FALSE;
}
BOOL CHPSCL::Scan()
{
LONG lBytesRead = 1;
DWORD dwTotalImageSize = 0;
DWORD dwbpp = 0;
DWORD BytesPerLine = 0;
switch(m_datatype){
case 0:
dwbpp = 1;
BytesPerLine = ((m_xext +7)/8);
dwTotalImageSize = (BytesPerLine * m_yext);
break;
case 1:
dwbpp = 8;
BytesPerLine = m_xext;
dwTotalImageSize = (m_xext * m_yext);
break;
case 2:
dwbpp = 24;
BytesPerLine = (m_xext * 3);
dwTotalImageSize = ((m_xext * m_yext) * 3);
break;
default:
return FALSE;
break;
}
//
// setup data dumper, so we can see if the image needs
// work.
//
DATA_DESCRIPTION DataDesc;
DataDesc.dwbpp = dwbpp;
DataDesc.dwDataSize = dwTotalImageSize;
DataDesc.dwHeight = m_yext;
DataDesc.dwWidth = m_xext;
DataDesc.pRawData = (PBYTE)LocalAlloc(LPTR,DataDesc.dwDataSize + 1024);
PBYTE pbuffer = DataDesc.pRawData;
Trace(TEXT("Total bytes to Read: = %d"),dwTotalImageSize);
//
// start scan
//
if(!RawWrite(m_pDeviceControl->BulkInPipeIndex,(PBYTE)"\x1B*f0S",5,0)){
MessageBox(NULL,TEXT("Starting Scan failed.."),TEXT(""),MB_OK);
return FALSE;
}
//
// read scanned data
//
if(!RawRead(m_pDeviceControl->BulkOutPipeIndex,pbuffer,(dwTotalImageSize),&lBytesRead,0)){
MessageBox(NULL,TEXT("Reading first band failed"),TEXT(""),MB_OK);
return FALSE;
}
Trace(TEXT("Total Bytes Read: = %d"),lBytesRead);
/*
pbuffer+=lBytesRead;
dwTotalImageSize -=lBytesRead;
Trace(TEXT("Bytes left to read: = %d"),dwTotalImageSize);
while(dwTotalImageSize > 0){
lBytesRead = 0;
//
// read scanned data (continued..)
//
if(!RawRead(m_pDeviceControl->BulkOutPipeIndex,pbuffer,(dwTotalImageSize),&lBytesRead,0)){
MessageBox(NULL,TEXT("Reading band failed"),TEXT(""),MB_OK);
dwTotalImageSize = 0;
}
pbuffer+=lBytesRead;
dwTotalImageSize -=lBytesRead;
Trace(TEXT("Bytes left to read: = %d"),dwTotalImageSize);
}
*/
CDATADUMP Data;
Data.DumpDataToBitmap(TEXT("HPSCL.BMP"),&DataDesc);
if(NULL != DataDesc.pRawData)
LocalFree(DataDesc.pRawData);
return TRUE;
}
BOOL CHPSCL::RawWrite(LONG lPipeNum,BYTE *pbuffer,LONG lbuffersize,LONG lTimeout)
{
DWORD dwBytesWritten = 0;
BOOL bSuccess = TRUE;
bSuccess = WriteFile(m_pDeviceControl->DeviceIOHandles[lPipeNum],
pbuffer,
lbuffersize,
&dwBytesWritten,
NULL);
if(dwBytesWritten < (ULONG)lbuffersize)
return FALSE;
return bSuccess;
}
BOOL CHPSCL::RawRead(LONG lPipeNum,BYTE *pbuffer,LONG lbuffersize,LONG *plbytesread,LONG lTimeout)
{
DWORD dwBytesRead = 0;
BOOL bSuccess = ReadFile(m_pDeviceControl->DeviceIOHandles[lPipeNum],
pbuffer,
lbuffersize,
&dwBytesRead,
NULL);
*plbytesread = dwBytesRead;
return bSuccess;
}
VOID CHPSCL::Trace(LPCTSTR format,...)
{
TCHAR Buffer[1024];
va_list arglist;
va_start(arglist, format);
wvsprintf(Buffer, format, arglist);
va_end(arglist);
OutputDebugString(Buffer);
OutputDebugString(TEXT("\n"));
}