Provided by: tk8.6-doc_8.6.13-2_all bug

NAME

       font - Create and inspect fonts.

SYNOPSIS

       font option ?arg arg ...?
_________________________________________________________________________________________________

DESCRIPTION

       The  font  command  provides  several  facilities for dealing with fonts, such as defining
       named fonts and inspecting the actual attributes of  a  font.   The  command  has  several
       different  forms,  determined  by  the  first argument.  The following forms are currently
       supported:

       font actual font ?-displayof window? ?option? ?--? ?char?
              Returns information about the actual attributes that are obtained when font is used
              on  window's display; the actual attributes obtained may differ from the attributes
              requested due to platform-dependent limitations, such as the availability  of  font
              families and point sizes.  font is a font description; see FONT DESCRIPTIONS below.
              If the window argument is omitted, it defaults to the main window.   If  option  is
              specified,  returns the value of that attribute; if it is omitted, the return value
              is a list of all the attributes and their values.  See FONT  OPTIONS  below  for  a
              list  of  the  possible attributes.  If the char argument is supplied, it must be a
              single character. The font attributes returned will be those of the  specific  font
              used  to  render  that character, which will be different from the base font if the
              base font does not contain the given character.  If char may be a hyphen, it should
              be preceded by -- to distinguish it from a misspelled option.

       font configure fontname ?option? ?value option value ...?
              Query  or  modify the desired attributes for the named font called fontname.  If no
              option is specified, returns a list describing all the options and their values for
              fontname.   If a single option is specified with no value, then returns the current
              value of that attribute.  If one or more option-value pairs are specified, then the
              command  modifies  the given named font to have the given values; in this case, all
              widgets using that font will redisplay themselves using the new attributes for  the
              font.  See FONT OPTIONS below for a list of the possible attributes.

              Note  that  on  Aqua/Mac OS X, the system fonts (see PLATFORM SPECIFIC FONTS below)
              may not be actually altered because they are implemented by the  system  theme.  To
              achieve  the effect of modification, use font actual to get their configuration and
              font create to synthesize a copy of the font which can be modified.

       font create ?fontname? ?option value ...?
              Creates a new named font and returns its name.  fontname specifies the name for the
              font;  if it is omitted, then Tk generates a new name of the form fontx, where x is
              an integer.  There may be any number  of  option-value  pairs,  which  provide  the
              desired  attributes  for  the new named font.  See FONT OPTIONS below for a list of
              the possible attributes.

       font delete fontname ?fontname ...?
              Delete the specified named fonts.  If there are widgets using the named  font,  the
              named  font  will  not  actually  be  deleted until all the instances are released.
              Those widgets will continue to display using the last known values  for  the  named
              font.   If a deleted named font is subsequently recreated with another call to font
              create, the widgets will use the new named font and redisplay themselves using  the
              new attributes of that font.

       font families ?-displayof window?
              The  return value is a list of the case-insensitive names of all font families that
              exist on window's display.  If the window argument is omitted, it defaults  to  the
              main window.

       font measure font ?-displayof window? text
              Measures  the  amount  of  space  the  string text would use in the given font when
              displayed in window.  font is a font description; see FONT DESCRIPTIONS below.   If
              the  window  argument is omitted, it defaults to the main window.  The return value
              is the total width in pixels of text, not including the extra pixels used by highly
              exaggerated  characters  such  as  cursive “f”.  If the string contains newlines or
              tabs, those characters are not expanded or treated  specially  when  measuring  the
              string.

       font metrics font ?-displayof window? ?option?
              Returns information about the metrics (the font-specific data), for font when it is
              used on window's display.  font is a font description; see FONT DESCRIPTIONS below.
              If  the  window  argument is omitted, it defaults to the main window.  If option is
              specified, returns the value of that metric; if it is omitted, the return value  is
              a  list  of all the metrics and their values.  See FONT METRICS below for a list of
              the possible metrics.

       font names
              The return value is a list of all the named fonts that are currently defined.

FONT DESCRIPTIONS

       The following formats are accepted as a font description anywhere font is specified as  an
       argument  above;  these same forms are also permitted when specifying the -font option for
       widgets.

       [1] fontname
              The name of a named font, created using the font create  command.   When  a  widget
              uses a named font, it is guaranteed that this will never cause an error, as long as
              the named font exists, no matter what potentially invalid  or  meaningless  set  of
              attributes  the named font has.  If the named font cannot be displayed with exactly
              the specified attributes, some other close font will be substituted automatically.

       [2] systemfont
              The platform-specific name of a font, interpreted by  the  graphics  server.   This
              also includes, under X, an XLFD (see [4]) for which a single “*” character was used
              to elide more than one field in the middle of  the  name.   See  PLATFORM  SPECIFIC
              FONTS for a list of the system fonts.

       [3] family ?size? ?style? ?style ...?
              A  properly  formed  list  whose first element is the desired font family and whose
              optional second element is the  desired  size.   The  interpretation  of  the  size
              attribute  follows  the  same rules described for -size in FONT OPTIONS below.  Any
              additional optional arguments following the size are font styles.  Possible  values
              for the style arguments are as follows:

                     normal      bold        roman      italic
                     underline   overstrike

       [4] X-font names (XLFD)
              A         Unix-centric         font         name         of         the        form
              -foundry-family-weight-slant-setwidth-addstyle-pixel-point-resx-resy-spacing-width-charset-encoding.
              The “*” character may be used to skip individual fields that the user does not care
              about.  There must be exactly one “*” for each field skipped, except that a “*”  at
              the  end  of the XLFD skips any remaining fields; the shortest valid XLFD is simply
              “*”, signifying all fields as defaults.  Any fields that  were  skipped  are  given
              default  values.  For compatibility, an XLFD always chooses a font of the specified
              pixel size (not point size); although this interpretation is not strictly  correct,
              all  existing  applications  using  XLFDs  assumed that one “point” was in fact one
              pixel and would display incorrectly (generally larger) if  the  correct  size  font
              were actually used.

       [5] option value ?option value ...?
              A properly formed list of option-value pairs that specify the desired attributes of
              the font, in the same format used when defining a  named  font;  see  FONT  OPTIONS
              below.

       When font description font is used, the system attempts to parse the description according
       to each of the above five rules, in the order specified.  Cases [1] and [2] must match the
       name  of an existing named font or of a system font.  Cases [3], [4], and [5] are accepted
       on all platforms and the closest available font will be used.  In some situations  it  may
       not  be  possible  to  find any close font (e.g., the font family was a garbage value); in
       that case, some system-dependent default font is chosen.  If the font description does not
       match any of the above patterns, an error is generated.

FONT METRICS

       The  following  options  are  used by the font metrics command to query font-specific data
       determined when the font was created.  These properties are for the whole font itself  and
       not  for  individual  characters  drawn  in  that font.  In the following definitions, the
       “baseline” of a font is the horizontal line where the bottom  of  most  letters  line  up;
       certain letters, such as lower-case “g” stick below the baseline.

       -ascent
              The  amount  in  pixels that the tallest letter sticks up above the baseline of the
              font, plus any extra blank space added by the designer of the font.

       -descent
              The largest amount in pixels that any letter sticks down below the baseline of  the
              font, plus any extra blank space added by the designer of the font.

       -linespace
              Returns  how  far  apart vertically in pixels two lines of text using the same font
              should be placed so that none of the characters in one  line  overlap  any  of  the
              characters  in  the  other line.  This is generally the sum of the ascent above the
              baseline line plus the descent below the baseline.

       -fixed
              Returns a boolean flag that is “1” if this is a fixed-width font, where each normal
              character  is  the  same  width as all the other characters, or is “0” if this is a
              proportionally-spaced font, where individual characters have different widths.  The
              widths of control characters, tab characters, and other non-printing characters are
              not included when calculating this value.

FONT OPTIONS

       The following options are supported on all platforms, and are  used  when  constructing  a
       named font or when specifying a font using style [5] as above:

       -family name
              The  case-insensitive font family name.  Tk guarantees to support the font families
              named Courier (a monospaced “typewriter” font), Times (a serifed “newspaper” font),
              and  Helvetica  (a  sans-serif  “European” font).  The most closely matching native
              font family will automatically be substituted when one of the above  font  families
              is used.  The name may also be the name of a native, platform-specific font family;
              in that case it will work as desired on one platform but may not display  correctly
              on  other  platforms.   If  the  family is unspecified or unrecognized, a platform-
              specific default font will be chosen.

       -size size
              The desired size of the font.  If the size argument is a  positive  number,  it  is
              interpreted  as a size in points.  If size is a negative number, its absolute value
              is interpreted as a size in pixels.  If a font cannot be displayed at the specified
              size,  a  nearby  size will be chosen.  If size is unspecified or zero, a platform-
              dependent default size will be chosen.

              Sizes should normally be specified in points so the  application  will  remain  the
              same  ruler  size  on  the  screen, even when changing screen resolutions or moving
              scripts  across  platforms.   However,  specifying  pixels  is  useful  in  certain
              circumstances  such  as  when a piece of text must line up with respect to a fixed-
              size bitmap.  The mapping between points and pixels is  set  when  the  application
              starts,  based  on properties of the installed monitor, but it can be overridden by
              calling the tk scaling command.

       -weight weight
              The nominal thickness of the characters in the font.  The value normal specifies  a
              normal weight font, while bold specifies a bold font.  The closest available weight
              to the one specified will be chosen.  The default weight is normal.

       -slant slant
              The amount the characters in the font are slanted away from  the  vertical.   Valid
              values  for  slant  are  roman  and  italic.   A  roman font is the normal, upright
              appearance of a font, while an italic font is one that is  tilted  some  number  of
              degrees  from  upright.   The  closest available slant to the one specified will be
              chosen.  The default slant is roman.

       -underline boolean
              The value is a boolean flag that specifies whether characters in this  font  should
              be underlined.  The default value for underline is false.

       -overstrike boolean
              The  value  is  a  boolean  flag that specifies whether a horizontal line should be
              drawn through the middle of  characters  in  this  font.   The  default  value  for
              overstrike is false.

STANDARD FONTS

       The  following  named fonts are supported on all systems, and default to values that match
       appropriate system defaults.

       TkDefaultFont
              This font is the default for all GUI items not otherwise specified.

       TkTextFont
              This font should be used for user text in entry widgets, listboxes etc.

       TkFixedFont
              This font is the standard fixed-width font.

       TkMenuFont
              This font is used for menu items.

       TkHeadingFont
              This font should be used for column headings in lists and tables.

       TkCaptionFont
              This font should be used for window and dialog caption bars.

       TkSmallCaptionFont
              This font should be used for captions on contained windows or tool dialogs.

       TkIconFont
              This font should be used for icon captions.

       TkTooltipFont
              This font should be used for tooltip windows (transient information windows).

       It is not advised to change these fonts, as they may be modified by Tk itself in  response
       to system changes. Instead, make a copy of the font and modify that.

PLATFORM SPECIFIC FONTS

       The following system fonts are supported:

       X Windows
              All valid X font names, including those listed by xlsfonts(1), are available.

       MS Windows
              The following fonts are supported, and are mapped to the user's style defaults.

                     system      ansi        device
                     systemfixed ansifixed   oemfixed

       Mac OS X
              The following fonts are supported, and are mapped to the user's style defaults.

                     system      application menu

              Additionally, the following named fonts provide access to the Aqua theme fonts:

                     systemSystemFont    systemEmphasizedSystemFont
                     systemSmallSystemFontsystemSmallEmphasizedSystemFont
                     systemApplicationFontsystemLabelFont
                     systemViewsFont     systemMenuTitleFont
                     systemMenuItemFont  systemMenuItemMarkFont
                     systemMenuItemCmdKeyFontsystemWindowTitleFont
                     systemPushButtonFontsystemUtilityWindowTitleFont
                     systemAlertHeaderFontsystemToolbarFont
                     systemMiniSystemFontsystemDetailSystemFont
                     systemDetailEmphasizedSystemFont

EXAMPLE

       Fill a text widget with lots of font demonstrators, one for every font family installed on
       your system:
              pack [text .t -wrap none] -fill both -expand 1
              set count 0
              set tabwidth 0
              foreach family [lsort -dictionary [font families]] {
                  .t tag configure f[incr count] -font [list $family 10]
                  .t insert end ${family}:\t {} \
                          "This is a simple sampler\n" f$count
                  set w [font measure [.t cget -font] ${family}:]
                  if {$w+5 > $tabwidth} {
                      set tabwidth [expr {$w+5}]
                      .t configure -tabs $tabwidth
                  }
              }

SEE ALSO

       options(3tk)

KEYWORDS

       font