2021-01-29 12:31:58 +01:00
|
|
|
//
|
|
|
|
// FILE: ParallelPrinter.cpp
|
|
|
|
// AUTHOR: Rob Tillaart
|
2022-11-19 15:28:46 +01:00
|
|
|
// VERSION: 0.2.5
|
2021-01-29 12:31:58 +01:00
|
|
|
// PURPOSE: parallel printer class that implements the Print interface
|
|
|
|
// DATE: 2013-09-30
|
|
|
|
// URL: https://github.com/RobTillaart/ParallelPrinter
|
2022-11-19 15:28:46 +01:00
|
|
|
|
2021-11-11 13:38:49 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
#include "ParallelPrinter.h"
|
|
|
|
|
|
|
|
|
|
|
|
ParallelPrinter::ParallelPrinter()
|
|
|
|
{
|
|
|
|
uint8_t dataPins[] = {3, 4, 5, 6, 7, 8, 9, 10};
|
|
|
|
ParallelPrinter(13, 2, 12, dataPins );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParallelPrinter::ParallelPrinter(uint8_t STROBE, uint8_t BUSY, uint8_t OOP, uint8_t * p )
|
|
|
|
{
|
2022-11-19 15:28:46 +01:00
|
|
|
// CONTROL LINES
|
2021-01-29 12:31:58 +01:00
|
|
|
_strobePin = STROBE;
|
|
|
|
_busyPin = BUSY;
|
|
|
|
_oopPin = OOP;
|
|
|
|
pinMode(_oopPin, INPUT);
|
|
|
|
pinMode(_busyPin, INPUT);
|
|
|
|
pinMode(_strobePin, OUTPUT);
|
2021-12-23 10:08:01 +01:00
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// DATA LINES
|
2021-01-29 12:31:58 +01:00
|
|
|
for (uint8_t i = 0; i < 8; i++)
|
|
|
|
{
|
|
|
|
_pin[i] = p[i];
|
|
|
|
pinMode(_pin[i], OUTPUT);
|
|
|
|
}
|
|
|
|
setLineLength(80);
|
|
|
|
setPageLength(60);
|
|
|
|
reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ParallelPrinter::begin(uint8_t lineLength, uint8_t pageLength)
|
|
|
|
{
|
|
|
|
setLineLength(lineLength);
|
|
|
|
setPageLength(pageLength);
|
|
|
|
reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ParallelPrinter::reset()
|
|
|
|
{
|
|
|
|
_pos = 0;
|
|
|
|
_lineNr = 0;
|
|
|
|
_pageNr = 0;
|
|
|
|
_tabSize = 2;
|
|
|
|
_lineFeed = 1;
|
|
|
|
_strobeDelay = 2000;
|
|
|
|
_printLineNumber = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// write() implements the virtual write of the Print class
|
2021-01-29 12:31:58 +01:00
|
|
|
size_t ParallelPrinter::write(uint8_t c)
|
|
|
|
{
|
2022-11-19 15:28:46 +01:00
|
|
|
if (c == '\t') // TAB
|
2021-01-29 12:31:58 +01:00
|
|
|
{
|
|
|
|
uint8_t spaces = _tabSize - _pos % _tabSize;
|
|
|
|
for (uint8_t i = 0; i < spaces; i++) processSingleChar(' ');
|
|
|
|
return spaces;
|
|
|
|
}
|
2022-11-19 15:28:46 +01:00
|
|
|
if (c == '\n') // LINEFEED
|
2021-01-29 12:31:58 +01:00
|
|
|
{
|
|
|
|
for (uint8_t i = 0; i < _lineFeed; i++)
|
|
|
|
{
|
|
|
|
processSingleChar(c);
|
|
|
|
_pos = 0;
|
|
|
|
_lineNr++;
|
|
|
|
}
|
|
|
|
return _lineFeed;
|
|
|
|
}
|
|
|
|
processSingleChar(c);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ParallelPrinter::processSingleChar(uint8_t c)
|
|
|
|
{
|
|
|
|
_pos++;
|
|
|
|
if ((_pos == 1) && _printLineNumber)
|
|
|
|
{
|
2022-11-19 15:28:46 +01:00
|
|
|
// not nice - implicit recursion...
|
2021-01-29 12:31:58 +01:00
|
|
|
print(_lineNr);
|
|
|
|
print('\t');
|
|
|
|
}
|
|
|
|
if (c == FORMFEED)
|
|
|
|
{
|
|
|
|
sendByte(c);
|
|
|
|
sendByte('\n');
|
|
|
|
_pos = 0;
|
|
|
|
_lineNr = 0;
|
|
|
|
_pageNr++;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sendByte(c);
|
|
|
|
}
|
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// HANDLE FULL LINE
|
2021-01-29 12:31:58 +01:00
|
|
|
if (_pos > _lineLength)
|
|
|
|
{
|
|
|
|
_pos = 0;
|
|
|
|
for (uint8_t i = 0; i < _lineFeed; i++)
|
|
|
|
{
|
|
|
|
sendByte('\n');
|
|
|
|
_lineNr++;
|
|
|
|
}
|
|
|
|
}
|
2022-11-19 15:28:46 +01:00
|
|
|
// HANDLE FULL PAGE
|
2021-01-29 12:31:58 +01:00
|
|
|
if (_lineNr > _pageLength)
|
|
|
|
{
|
|
|
|
sendByte(FORMFEED);
|
|
|
|
sendByte('\n');
|
|
|
|
_pos = 0;
|
|
|
|
_lineNr = 0;
|
|
|
|
_lineNr = 0;
|
|
|
|
_pageNr++;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// lowest level communication
|
2021-01-29 12:31:58 +01:00
|
|
|
void ParallelPrinter::sendByte(uint8_t c)
|
|
|
|
{
|
2022-11-19 15:28:46 +01:00
|
|
|
// BLOCK WHEN OUT OF PAPER TODO
|
|
|
|
// while (digitalRead(_oopPin) == LOW) yield();
|
|
|
|
// indication in hardware?
|
2021-12-23 10:08:01 +01:00
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
Serial.write(c); // debugging
|
2021-01-29 12:31:58 +01:00
|
|
|
return;
|
|
|
|
|
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// wait until printer is ready.
|
2021-01-29 12:31:58 +01:00
|
|
|
while (digitalRead(_busyPin) == HIGH) yield();
|
|
|
|
|
|
|
|
uint8_t mask = 0x80;
|
|
|
|
for (uint8_t i = 0; i < 8; i++)
|
|
|
|
{
|
|
|
|
digitalWrite(_pin[i], c & mask );
|
|
|
|
mask >>= 1;
|
|
|
|
}
|
|
|
|
digitalWrite(_strobePin, LOW);
|
2022-11-19 15:28:46 +01:00
|
|
|
// time consuming part
|
2021-01-29 12:31:58 +01:00
|
|
|
if (_strobeDelay) delayMicroseconds(_strobeDelay);
|
|
|
|
digitalWrite(_strobePin, HIGH);
|
|
|
|
|
2022-11-19 15:28:46 +01:00
|
|
|
// wait till data is read by printer.
|
2021-01-29 12:31:58 +01:00
|
|
|
while (digitalRead(_busyPin) == LOW) yield();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// -- END OF FILE --
|
2021-12-23 10:08:01 +01:00
|
|
|
|