HP-GL

HP-GL (Hewlett-Packard Graphics Language; often written as HPGL) is a printer control language created by Hewlett-Packard (HP). HP-GL was the primary printer control language used by HP plotters.[1] It later became a standard for almost all plotters. Hewlett-Packard's printers also usually support HP-GL/2 in addition to PCL.[2]

Design

The language is formed from a series of two letter codes, followed by optional parameters. For instance an arc can be drawn on a page by sending the string:

AA100,100,50;

This means Arc Absolute, and the parameters place the center of the arc at absolute coordinates 100,100 on the page, with a starting angle of 50 degrees measured counter-clockwise. A fourth optional parameter (not used here) specifies how far the arc continues, and defaults to 5 degrees.

When first introduced, HP-GL contained the following commands:

Command Meaning
Vector Group
PA x,y{,x,y{...}}Plot absolute [i]
PR x,y{,x,y{....}}Plot relative [i]
PDPen down
PUPen up
Character Group
CA nDesignate alternate character set n [i]
CP spaces, linesCharacter plot [d]
CS mDesignate standard set m [i]
DI run, riseAbsolute direction [d]
DR run, riseRelative direction [d]
LB c, ..., cLabel ASCII string [c]
SASelect alternate character set
SI wide, highAbsolute character size [d]
SL tan θAbsolute character slant (from vertical) [d]
SR wide, highRelative character size [d]
SSSelect standard character set
UC x, y, pen{, ...}User defined character [i]
Line Type Group
LT t{,l}Designate line type t and length l [d]
SM cSymbol mode [c]
SP nSelect pen [i]
VAAdaptive velocity
VNNormal velocity
VS v{,n}Select velocity v for pen n [i]
Digitize Group
DCDigitize clear
DPDigitize point
OCOutput current position and pen status
ODOutput digitized point and pen status
Axes
TL tp{,tn}Tick length [d]
XTX axis tick
YTY axis tick
Set-Up Group
IP p1x,p1y,p2x,p2yInput p1 and p2 [i]
IW xlo,ylo,xhi,yhiInput window [i]
OPOutput p1 and p2 [i]
Configuration Status
APAutomatic pen pickup [i]
DFSet default values
IM e{,s{,p}}Input e, s and p masks [i]
INInitialize
OEOutput error [i]
OSOutput status [i]

Formats:

  • [i]: integer formats between -32767 and 32768. No decimal point.
  • [d]: decimal format between +/- 127.9999. Optional decimal point.
  • [c]: ASCII character

Examples

Typical HP-GL files start with a few setup commands, followed by a long string of graphics commands. The file was in ASCII (text file) format, for instance:

An example HP-GL file
Command Meaning
IN;initialize, start a plotting job
IP; set the scaling points (P1 and P2) to their default positions
SP1;select pen 1
PU0,0; lift Pen Up and move to starting point for next action
PD100,0,100,100,0,100,0,0; put Pen Down and move to the following locations (draw a box around the page)
PU50,50;Pen Up and move to X,Y coordinates 50,50
CI25;draw a circle with radius 25
SS;select the standard character set
DT*,1; set the text delimiter to the asterisk, and do not print them (the 1, meaning "true")
PU20,80;lift the pen and move to 20,80
LBHello World*;draw a label
LTlinetype,lengthset line type and its repetition length
CSxxset character set (e.g. 33 is German)
DIx,yset direction of text given as the catheti
SIww,hhset character width and height

The coordinate system was based on the smallest units one of the HP plotters could support, and was set to 25 µm (i.e. 40 units per millimeter, 1016 per inch). The coordinate space was positive or negative floating point numbers, specifically ±230.

HP-GL/2

The original HP-GL language did not support definition of line width, as this parameter was determined by the pens loaded into the plotter. With the advent of the first inkjet plotters, line width for the "pens" specified within the HP-GL files had to be set at the printer so it would know what line width to print for each pen, a cumbersome and error-prone process. With Hewlett-Packard Graphics Language/2 aka HP-GL/2, definition of line width was introduced into the language and allowed for elimination of this step. Also, among other improvements a binary file format was defined that allowed for smaller files and shorter file transfer times, and the minimal resolution was reduced.

Examples of HP-GL/2 commands
Command Meaning
NPxnumber of pens; x=1..256
PCx,r,g,bpen color; x=pen, r=red, g=gree, b=blue, 0..255
PWw,xpen width; w=pin width in mm with decimal point, x=pen

AGL

HP-GL is related to AGL (A Graphics Language), an extension of the BASIC programming language. AGL was implemented on Hewlett-Packard minicomputers to simplify controlling a plotter. AGL commands describe the desired graphics plotting function, which the computer relays as several HP-GL instructions to the plotter.

See also

  • DMPL, another plotter language by Houston Instruments
  • ShareCAD, a free online HP-GL/PLT viewer

References

  1. Daniels, Thomas H.; Hennessee, Larry W. (September 1977). "Easy-to-Use Interface Language Controls HP-IB Plotter" (PDF). Hewlett-Packard Journal. 29 (1): 5. Archived (PDF) from the original on 2017-02-27. Retrieved 2016-09-12.
  2. PCL 5 Printer Language Technical Reference Manual (1st ed.). Hewlett-Packard Company. September 1990. HP Part No. 33459-90903. (NB. Chapter 15-21 also contain a description of HP-GL/2.)

Further reading

  • Hewlett-Packard Company, Barcelona Division (September 1996) [1990]. The HP-GL/2 and HP RTL Reference Guide - A handbook for Program Developers - Hewlett-Packard Graphics Language/2 - Hewlett-Packard Raster Transfer Language (draft 2, second ed.). Barcelona, Spain: Addison-Wesley Publishing Company. ISBN 0-201-63325-6. HP Part No. 5961-3526, 5959-9733. Archived from the original on 2017-02-27. Retrieved 2017-02-28.
  • "Hewlett-Packard Graphics Language Commands". Archived from the original on 2017-02-27.
  • "HP-GL Overview".
  • "Chiplotle". Archived from the original on 2017-02-27. (NB. A Python-based HP-GL plotter control library for using vintage pen plotters with contemporary operating systems.)
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.