/*****************************************************************************/ /* */ /* pen.h */ /* */ /* Lightpen API */ /* */ /* */ /* This software is provided "as-is", without any expressed or implied */ /* warranty. In no event will the authors be held liable for any damages */ /* arising from the use of this software. */ /* */ /* Permission is granted to anyone to use this software for any purpose, */ /* including commercial applications, and to alter it and redistribute it */ /* freely, subject to the following restrictions: */ /* */ /* 1. The origin of this software must not be misrepresented; you must not */ /* claim that you wrote the original software. If you use this software */ /* in a product, an acknowledgment in the product documentation would be */ /* appreciated, but is not required. */ /* 2. Altered source versions must be marked plainly as such; and, must not */ /* be misrepresented as being the original software. */ /* 3. This notice may not be removed or altered from any source */ /* distribution. */ /* */ /*****************************************************************************/ #ifndef _PEN_H #define _PEN_H /*****************************************************************************/ /* Declarations */ /*****************************************************************************/ /* A program optionally can set this pointer to a function that gives ** a calibration value to a driver. If this pointer isn't NULL, ** then a driver that wants a value can call that function. ** pen_adjuster must be set before the driver is installed. */ extern void __fastcall__ (*pen_adjuster) (unsigned char *pValue); /*****************************************************************************/ /* Functions */ /*****************************************************************************/ void __fastcall__ pen_calibrate (unsigned char *XOffset); /* Ask the user to help to calibrate a lightpen. Changes the screen! ** A pointer to this function can be put into pen_adjuster. */ void __fastcall__ pen_adjust (const char *filename); /* Get a lightpen calibration value from a file if it exists. Otherwise, call ** pen_calibrate() to create a value; then, write it into a file, so that it ** will be available at the next time that the lightpen is used. ** Might change the screen. ** pen_adjust() is optional; if you want to use its feature, ** then it must be called before a driver is installed. ** Note: This function merely saves the file-name pointer, and sets ** the pen_adjuster pointer. The file will be read only when a driver ** is installed, and only if that driver wants to be calibrated. */ /* End of pen.h */ #endif