HPGLWrap/HPGLWrap.py

90 lines
2.8 KiB
Python
Raw Normal View History

2018-06-10 23:13:29 -04:00
#!/usr/bin/env python3
import os
2018-06-11 21:25:19 -04:00
import re
2018-06-10 23:13:29 -04:00
import sys
2018-06-11 21:25:43 -04:00
# Based off of notes from
# https://github.com/fellesverkstedet/gcc-laserpro-driver
# and http://www.wiki.cl.cam.ac.uk/rowiki/CompArch/HardwareLab/LaserCutter
# and src/core/path_gcc.c from
# https://github.com/fellesverkstedet/fabmodules
2018-06-10 23:13:29 -04:00
def write_pen_values(values, char):
return "!v64" + char + "".join(["{:04d}".format(value) for value in values])
2018-06-11 21:25:19 -04:00
def pre_content(filename, power, speed, rate, pen_settings):
2018-06-10 23:13:29 -04:00
jobName = os.path.basename(filename)[:80]
# Start
outString = "@PJL JOB NAME={}\r\n".format(jobName)
outString += "E@PJL ENTER LANGUAGE=PCL\r\n%-12345X"
# Reset
outString += "E"
# Unit
outString += "&u254D"
# Cursor
outString += "*p100X"
outString += "*p100Y"
# Set filename
outString += "!m{:d}N".format(len(jobName)) + jobName
# Set raster power+velocity. Only affects raster. Shows in display before start
outString += "!r{:d}I".format(speed * 10)
outString += "!r{:d}P".format(power * 10);
# Select first (and only) pen (commented out in original source)
# outString += "!v1D"
2018-06-11 21:25:43 -04:00
# outString += "!m2A" # triggers autofocus
2018-06-10 23:13:29 -04:00
# Use same value for all 16 pens
# doesn't seem to affect vector settings
2018-06-11 21:25:19 -04:00
# TODO: try unsetting values in HPGL and see if these take over
outString += write_pen_values(pen_settings['power'], 'P') # Power, 1000=100%
outString += write_pen_values(pen_settings['speed'], 'V') # Velocity, 1000=100%
outString += write_pen_values(pen_settings['rate'], 'I') # PPI, does affect vector
# Enter HPGL vector mode
2018-06-10 23:13:29 -04:00
outString += "%1B"
return outString
2018-06-11 21:25:19 -04:00
def set_vector_pens(content, pen_settings):
settings = "".join(
["FS{power:d},{penNum:d};VS{speed:d},{penNum:d};".format(
power=pen_settings['power'][num],
speed=pen_settings['speed'][num],
penNum=num+1) for num in range(0, 16)])
2018-06-11 21:25:43 -04:00
# TODO: find out why slow movement in PU (pen up) until first PD (pen down)
2018-06-11 21:25:19 -04:00
content = re.sub(
"FS\d{1,4};VS\d{1,4};SP1;",
settings + "SP1;",
content, count=1)
return content
2018-06-10 23:13:29 -04:00
def post_content():
outString = "%1A" # Leave HPGL vector mode
outString += "E" # Reset
outString += "%-12345X@PJL EOJ \r\n" # End
return outString
def main(infile, outfile, power=50, speed=50, rate=100):
2018-06-11 21:25:19 -04:00
# set all pens the same
pen_settings = {'power': [int(power) * 10] * 16,
'speed': [int(speed) * 10] * 16,
'rate': [int(rate)] * 16}
2018-06-10 23:13:29 -04:00
with open(outfile, 'w') as f:
2018-06-11 21:25:19 -04:00
f.write(pre_content(
outfile, int(power), int(speed), int(rate), pen_settings))
with open(infile, 'r') as input_f:
f.write(set_vector_pens(input_f.read(), pen_settings))
2018-06-10 23:13:29 -04:00
f.write(post_content())
if __name__ == '__main__':
print(sys.argv)
main(*sys.argv[1:])