tahoma2d/toonz/sources/tnzbase/tscanner/tscannerepson.h
Shinya Kitaoka 6526c73583 Fix t32bitsrv build conflicts (#211)
add #include <memory>, fix QT_PATH

* add #include <memory>

* fix QT_PATH
2016-04-27 15:04:18 +09:00

68 lines
2.1 KiB
C++

#ifndef TSCANNER_EPSON_INCLUDED
#define TSCANNER_EPSON_INCLUDED
#include "tscanner.h"
#include "TScannerIO/TScannerIO.h"
#include <memory>
/*
PLEASE DO NOT REMOVE unreferenced methods... they are useful for debugging :)
max
*/
class TScannerEpson : public TScanner
{
enum SettingsMode {
OLD_STYLE,
NEW_STYLE
};
TScannerIO *m_scannerIO;
bool m_hasADF;
bool m_isOpened;
SettingsMode m_settingsMode;
public:
TScannerEpson();
~TScannerEpson();
void selectDevice();
bool isDeviceAvailable();
bool isDeviceSelected();
void updateParameters(TScannerParameters &param); // vedi TScanner
void acquire(const TScannerParameters &params, int paperCount);
bool isAreaSupported();
void closeIO();
private:
void doSettings(const TScannerParameters &params, bool isFirstSheet);
void collectInformation(char *lev0, char *lev1, unsigned short *lowRes, unsigned short *hiRes, unsigned short *hMax, unsigned short *vMax);
bool resetScanner();
void reportError(std::string errMsg); // debug only
char *ESCI_inquiry(char cmd); /* returns 0 if failed */
bool ESCI_command(char cmd, bool checkACK);
bool ESCI_command_1b(char cmd, unsigned char p0, bool checkACK);
bool ESCI_command_2b(char cmd, unsigned char p0, unsigned char p1, bool checkACK);
bool ESCI_command_2w(char cmd, unsigned short p0, unsigned short p1, bool checkACK);
bool ESCI_command_4w(char cmd, unsigned short p0, unsigned short p1, unsigned short p2, unsigned short p3, bool checkACK);
std::unique_ptr<unsigned char[]> ESCI_read_data2(unsigned long &size);
void ESCI_readLineData(unsigned char &stx, unsigned char &status, unsigned short &counter, unsigned short &lines, bool &areaEnd);
void ESCI_readLineData2(unsigned char &stx, unsigned char &status, unsigned short &counter);
int receive(unsigned char *buffer, int size);
int send(unsigned char *buffer, int size);
bool ESCI_doADF(bool on);
int sendACK();
bool expectACK();
void scanArea2pix(const TScannerParameters &params, unsigned short &offsetx, unsigned short &offsety,
unsigned short &dimlx, unsigned short &dimly, const TRectD &scanArea);
};
#endif