From ArchWiki
Revision as of 02:05, 11 September 2009 by Thisoldman (Talk | contribs)

Jump to: navigation, search

Java (Sun) Fonts

Users may find the default Java fonts and their display in Java applications unpleasant. Several methods to improve font display in the Sun Java Runtime Environment (JRE)[1] are available. The methods may be used separately, but many users will find better results by combining them.


Anti-aliasing[2] of fonts is available with Sun Java 1.6 on Linux. To do this on a per user basis, add the following line to the user's ~/.bashrc.

export _JAVA_OPTIONS='-Dawt.useSystemAAFontSettings=gasp'

The value, gasp, is one of seven possible settings for -Dawt.useSystemAAFontSettings.[3] These settings are:

The gasp and lcd settings work well in many instances.

For the above change to take effect, ~/.bashrc must be sourced as the normal user.

$ source ~/.bashrc

Open a new instance of a Java application to test the changes made.

Font Selection

The Lucida fonts[4] distributed with the Sun JRE are used by many Java applications by default. These fonts were designed for low resolution CRT displays and printers.[5] Many users will wish to use other fonts. TrueType fonts appear to be the best supported format in Java.

Java applications that are coded to use a specific TrueType font must be given the path to that font. TrueType fonts are located in the directory /usr/share/fonts/TTF. Add the following line to ~/.bashrc to enable these fonts.

export JAVA_FONTS=/usr/share/fonts/TTF

Source ~/.bashrc as the normal user for the change to take effect.

$ source ~/.bashrc

Java applications that don't specify a font will use the default Lucida fonts. This default can be changed to a different installed font, on a system-wide basis, by the creation or editing of a file named /opt/java/jre/lib/

As root, change directory to /opt/java/jre/lib and copy to and then, still as root, open in an editor.

# cd /opt/java/jre/lib
# cp
# nano      ## Editor is the user's choice.
Note: Encodings other than Latin-1, or ISO 8859-1,[6] are shown in the RedHat,[7] SuSE,[8] Sun[9] and Turbo[10]*.src files. Some users will find these files to be better sources for editing than the simple file used in this article. In all cases the edited file should be saved as

The font names used by Java applications are in the form of, for example,"Template:Codeline". These generic fonts are mapped to installed fonts using names in the format specified by the X Logical Font Description (XLFD)[11] convention. This convention names a font using fourteen descriptors, in this manner: -foundry-family-weight-slant-setWidth-additionalStyle-


The Java fonts are mapped to TrueType fonts using X Logical Font Description (XLFD)[12] conventions. The %d is used as a placeholder in the font description for the point size. The Java application will replace %d at runtime.

You may find the utility, xfontsel, useful to display fonts and to discover their XLFD name. Xfontsel is part of the xorg-utils package.

Below are portions of a file after modifications have been completed. All the Lucida fonts have been replaced by variations of DejaVu[13] fonts. Because the DejaVu fonts don't have italic versions, the oblique versions were substituted for them; -o- replaces -i- in the XLFD.

# Version -- a version number is required.
# IMPORTANT -- Do not delete the next line. Ever.

# Component Font Mappings
#       -fndry-fmly-wght-slant-sWdth-adstyle-pxlsz-ptSz-resx-resy-spc-avgWdth-rgstry-encdng

serif.plain.latin-1=-misc-dejavu serif-medium-r-normal-*-*-%d-*-*-p-*-iso8859-1
serif.bold.latin-1=-misc-dejavu serif-bold-r-normal-*-*-%d-*-*-p-*-iso8859-1
serif.italic.latin-1=-misc-dejavu serif-medium-i-normal-*-*-%d-*-*-p-*-iso8859-1
serif.bolditalic.latin-1=-misc-dejavu serif-bold-i-normal-*-*-%d-*-*-p-*-iso8859-1

sansserif.plain.latin-1=-misc-dejavu sans-medium-r-normal-*-*-%d-*-*-p-*-iso8859-1

--- [Omitted] ---

dialoginput.italic.latin-1=-misc-dejavu sans mono-medium-o-normal-*-*-%d-*-*-m-*-iso8859-1
dialoginput.bolditalic.latin-1=-misc-dejavu sans mono-bold-o-normal-*-*-%d-*-*-m-*-iso8859-1

After the changes have been saved to, the editor may be closed and the user should drop root privileges. Open a new instance of a Java application to test the changes.