SETFONT

Updated December 2009

//SETFONT, height, face, pitch-family, {charset, weight, style, rotation, width}

SETFONT is used to select the printer font. If not used, the font will be determined by the FONT parameter within the printer initialization file. The last four parameters are optional, or may be specified as zero for defaults. Note that the color of the font will be black characters on a white transparent background, unless overridden by a SETTEXTCOLOR directive. See the topic Parameters: Symbols vs. Values if you have questions about which to use.

Also see the "Update Note" section at the bottom of this page.

TIP: To change font in the middle of a line of text, use the backslash (\) line terminator on the line prior to the font change in order to suppress the automatic line feed. For this and other tips, pointers and relevant information about writing GDI printing directives, please see Writing GDI Print Directives.

Parameters

height

Height of the font in tenths of points. For example, use 120 to select a 12 point font.

face

Face name of the font. These are the names that appear in the typical Windows font selection dialogs. Typical face names are Courier New, Helvetica, Fixed Sys, Times Roman, etc.

pitch-and-family

Formed as the sum of the following:

Symbol

Value

Description

DEFAULT_PITCH

0

Default pitch, don't care about family.

FIXED_PITCH

1

Fixed pitch (monospace).

VARIABLE_PITCH 

2

Variable pitch (proportional space).

 

Symbol

Value

Description

FF_DONTCARE

&h000

Don't care.

FF_ROMAN

&h010

Roman family (serifs, variable pitch.) Example: Times Roman.

FF_SWISS

&h020

Swiss family (sans serifs, variable pitch.) Example: MS Sans Serif.

FF_MODERN

&h030

Modern family (fixed pitch, serif or sans serif.) Examples: Courier, Pica, Elite.

FF_SCRIPT

&h040

Script family (fonts that look like handwriting.) Examples: Script, Cursive

FF_DECORATIVE

&h050

Decorative family (novelty fonts.) Example: Old English.

 

charset

Specifies the desired character set, from the following values:

Symbol

Value

Description

ANSI_CHARSET

0

ANSI

DEFAULT_CHARSET

1

Don't care

SYMBOL_CHARSET

2

Symbols

OEM_CHARSET

255

OEM (system dependent)

 

weight

Specifies the desired boldness of stroke, from the following choices. Note that most of these are not supported but are mapped to the nearest supported choice.

Symbol

Value

Description

FW_DONTCARE

0

Don't care

FW_THIN

100

Thin

FW_EXTRALIGHT

200

Extra Light

FW_LIGHT

300

Light

FW_NORMAL

400

Normal

FW_MEDIUM

500

Medium

FW_SEMIBOLD

600

Semibold, demibold

FW_BOLD

700

Bold

FW_EXTRABOLD

800

Extrabold, ultrabold

FW_HEAVY

900

Heavy

caution: this table (above) is duplicated in XCALL Ref / AUI Control / fontattr

 

style

Specifies font style options.

Symbol

Value

Description

FS_UPRIGHT

&h00

Normal upright

FS_ITALIC

&h01

Italic

FS_UNDERLINE

&h02

Underline

FS_STRIKEOUT

&h04

Strikeout

 

rotation

The default is zero. Rotation is specified in degrees, with positive numbers being rotated clockwise.

width

This option allows you to stretch or squeeze the width of the font independent of the height. The units of width are equivalent to that of height (tenths of points). Beginning in A-Shell build 1168 of 11 December 2009, you may also use width to specify the character width in terms of the number of characters that would fit on a line, by setting it to the negative of that value. For example, to select a font that would fit 90 characters across the page, set width to -90.

Examples

//SETFONT,120,Arial

This is 12 point Arial, standard options

 

//SETFONT,100,Times Roman,0,0,200,1

This is 10 point Times Roman, extra light weight, italic

 

//SETFONT,120,Courier,FIXED_PITCH,ANSI_CHARSET,FW_EXTRABOLD,FS_UPRIGHT

This is 12 point Courier (or something similar in fixed pitch), extra bold, upright

 

Comments

In the context of fixed-pitch (mono-spaced) fonts, the terms "pitch" and "point" are sometimes confused or at least conflated by the traditional typewriter-era rule-of-thumb that a 12 point font (e.g. Courier, Pica) was equivalent to 10 pitch (10 CPI or characters per inch horizontal), while a 10 point font (e.g. Elite) was equivalent to 12 pitch. In the digital era, that rule-of-thumb falls apart, especially with proportional fonts, where the relationship between height in points and number of characters per inch is completely unpredictable, but even with fixed-pitch fonts, due to the fact that the characters can be made wider or thinner without changing the height. If it is important to select a font with a certain pitch (CPI), use the width parameter to specify it explicitly.

Also note that while there is a natural relationship between the vertical line spacing (LPI or lines per inch vertical) and the font height (i.e. point size), changing the font does not automatically change the line spacing. See the GDI printing directive RESETFONT.

Update Note: A-Shell build 1149 of 16 May 09

GDI printing bug fix/refinement: The width parameter in the SETFONT statement now works more precisely and reliably with fixed pitch fonts, across all font families, printers and resolutions. Previously, certain fonts (most notoriously Courier) didn't "behave" very well. And in addition, since the individual cell width was being rounded to the nearest integer number of pixels, small adjustments to the width were often not having the desired effect with lower printer device resolutions. Now, the cell width is interpolated to 1/8 of a pixel, resulting in fine control even with 100 DPI (e.g. fax) devices.

COMPATIBILITY WARNING: This "fix" could possibly result in a small change in the horizontal character spacing of existing printouts. The change will probably be small, and will always represent a correction, but it is possible that having worked out precise spacing by trial-and-error, you may need to make adjustments after this fix. (After considerable soul-searching and public comment, we decided that since width is a relatively new parameter, rarely used, that the likelihood of this fix actually improving the spacing of existing reports was many times greater than the chance of it making a report worse. But if you use the width parameter to fine tune the fixed pitch spacing of a very precise form, and especially if you used trial-and-error rather than math to figure out the ideal width, you may need to take another look. (The upside is, anyone affected by this would have been at risk of their reports looking different on different printers; so even if you have to make an adjustment, the report will now print consistently across devices.)

A more detailed discussion is available on the A-Shell forum.