| 
 | JavaTM 2 Platform Standard Ed. 5.0 | |||||||||
| 上一个类 下一个类 | 框架 无框架 | |||||||||
| 摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 | |||||||||
java.lang.Objectjava.awt.Font
public class Font
Font 类表示字体,用来以可见方式呈现文本。字体提供将字符 序列映射到字形 序列所需要的信息,以便在 Graphics 对象和 Component 对象上呈现字形序列。
 
'g'、LATIN SMALL LETTER G 是字符。
 字形 是用来呈现字符或字符序列的一种形状。在简单的书写系统(如拉丁文)中,通常一个字形就表示一个字符。但是,通常字符和字形并没有一对一的对应关系。例如,字符 'á' LATIN SMALL LETTER A WITH ACUTE 可以由两个字形表示:一个是 'a',一个是 '´'。另一方面,两字符的字符串 "fi" 可以由单个字形 "fi" 连字表示。在复杂的书写系统(如阿拉伯语或南亚和东南亚语言)中,字符与字形之间的关系可能更复杂,涉及到依赖于上下文的字形选择以及字形重排序。 字体封装了呈现所选择的字符集所需的字形集,还封装了将字符序列映射到相应的字形序列所需的表。
物理 字体是实际的字体库,包含字形数据和表,这些数据和表使用字体技术(如 TrueType 或 PostScript Type 1)将字符序列映射到字形序列。Java 2 平台的所有实现都支持 TrueType 字体;对其他字体技术的支持是与实现相关的。物理字体可以使用字体名称,如 Helvetica、Palatino、HonMincho 或任意数量的其他字体名称。通常,每种物理字体只支持有限的书写系统集合,例如,只支持拉丁文字符或只支持日文和基本拉丁文。可用的物理字体集合随配置的不同而不同。要求特定字体的应用程序可以使用 createFont 方法来捆绑这些字体,并对其进行实例化。
 
逻辑 字体是由必须受所有 Java 运行时环境支持的 Java 平台所定义的五种字体系列:Serif、SansSerif、Monospaced、Dialog 和 DialogInput。这些逻辑字体不是实际的字体库。而是由 Java 运行时环境将逻辑字体名称映射到物理字体。映射关系与实现和通常语言环境相关,因此它们提供的外观和规格各不相同。通常,为了覆盖庞大的字符范围,每种逻辑字体名称都映射到几种物理字体。
同级的 AWT 组件(如 Label 和 TextField)只可以使用逻辑字体。
 
有关使用物理字体或逻辑字体的相对优势和劣势的讨论,请参阅 Internationalization FAQ 文档。
Font 可以有多个外观,如 heavy、medium、oblique、gothic 和 regular。所有这些外观都有相似的排字设计。
 
可以从 Font 对象获得三种不同的名称。逻辑字体名称 只是用来构造字体的名称。字体外观名称,或外观名称 是特定字体外观的名称,如 Helvetica Bold。系列名 是字体系列的名称,用来确定多种外观(如 Helvetica)的排字设计。
 
Font 类表示字体外观集合中字体外观的实例,字体外观集合位于主机系统的系统资源中。例如,Arial Bold 和 Courier Bold Italic 是字体外观。有几个 Font 对象与字体外观相关,每个对象在大小、样式、变换和字体特征上都有所不同。GraphicsEnvironment 类的 getAllFonts 方法返回系统中所有可用字体外观的数组。这些字体外观作为 Font 对象返回,对象的大小为 1,具有恒等变换和默认字体特征。这些基本字体可以用来派生新的 Font 对象,使之具有变化的大小、样式、变换和字体特征,这通过此类中的 deriveFont 方法实现。
| 字段摘要 | |
|---|---|
| static int | BOLD粗体样式常量。 | 
| static int | CENTER_BASELINE布置文本时,在表意文字的脚本(如中文、日文和韩文)中使用的基线。 | 
| static int | HANGING_BASELINE布置文本时,在 Devanigiri 和类似脚本中使用的基线。 | 
| static int | ITALIC斜体样式常量。 | 
| static int | LAYOUT_LEFT_TO_RIGHTlayoutGlyphVector 的标志,指示文本是从左到右的,这由 Bidi 分析确定。 | 
| static int | LAYOUT_NO_LIMIT_CONTEXTlayoutGlyphVector 的标志,指示不应该检查指定 limit 之后的 char 数组中的文本。 | 
| static int | LAYOUT_NO_START_CONTEXTlayoutGlyphVector 的标志,指示不应该检查指定 start 之前的 char 数组中的文本。 | 
| static int | LAYOUT_RIGHT_TO_LEFTlayoutGlyphVector 的标志,指示文本是从右到左的,这由 Bidi 分析确定。 | 
| protected  String | nameFont的逻辑名称,它被传递到构造方法中。 | 
| static int | PLAIN普通样式常量。 | 
| protected  float | pointSize以 float形式表示的Font的点大小。 | 
| static int | ROMAN_BASELINE布置文本时,在大多数 Roman 脚本中使用的基线。 | 
| protected  int | sizeFont的点大小,舍入为整数。 | 
| protected  int | styleFont的样式,它被传递到构造方法中。 | 
| static int | TRUETYPE_FONT标识 TRUETYPE 类型的字体资源。 | 
| static int | TYPE1_FONT标识 TYPE1 类型的字体资源。 | 
| 构造方法摘要 | |
|---|---|
| Font(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)创建一个具有指定属性的新 Font。 | |
| Font(String name,
     int style,
     int size)根据指定名称、样式和点大小,创建一个新 Font。 | |
| 方法摘要 | |
|---|---|
|  boolean | canDisplay(char c)检查此 Font是否具有指定字符的字形。 | 
|  boolean | canDisplay(int codePoint)检查此 Font是否具有指定字符的字形。 | 
|  int | canDisplayUpTo(char[] text,
               int start,
               int limit)指示此 Font是否可以显示指定text中从start开始至limit结束的所有字符。 | 
|  int | canDisplayUpTo(CharacterIterator iter,
               int start,
               int limit)指示此 Font是否可以显示由iter指定的文本(从start开始至limit结束)。 | 
|  int | canDisplayUpTo(String str)指示此 Font是否可以显示指定的String。 | 
| static Font | createFont(int fontFormat,
           File fontFile)返回一个使用指定字体类型和指定字体文件的新 Font。 | 
| static Font | createFont(int fontFormat,
           InputStream fontStream)返回一个使用指定字体类型和输入数据的新 Font。 | 
|  GlyphVector | createGlyphVector(FontRenderContext frc,
                  char[] chars)根据此 Font中的 Unicode cmap 将字符一一映射到字形,从而创建一个GlyphVector。 | 
|  GlyphVector | createGlyphVector(FontRenderContext frc,
                  CharacterIterator ci)根据此 Font中的 Unicode cmap 将指定字符一一映射到字形,从而创建一个GlyphVector。 | 
|  GlyphVector | createGlyphVector(FontRenderContext frc,
                  int[] glyphCodes)根据此 Font中的 Unicode cmap 将字符一一映射到字形,从而创建一个GlyphVector。 | 
|  GlyphVector | createGlyphVector(FontRenderContext frc,
                  String str)根据此 Font中的 Unicode cmap 将字符一一映射到字形,从而创建一个GlyphVector。 | 
| static Font | decode(String str)返回 str参数所描述的Font。 | 
|  Font | deriveFont(AffineTransform trans)通过复制当前 Font对象并应用新的变换,创建一个新Font对象。 | 
|  Font | deriveFont(float size)通过复制当前 Font对象并应用新的大小,创建一个新Font对象。 | 
|  Font | deriveFont(int style)通过复制当前的 Font对象,并应用新的样式,创建一个新Font对象。 | 
|  Font | deriveFont(int style,
           AffineTransform trans)通过复制此 Font对象并应用新样式和变换,创建一个新Font对象。 | 
|  Font | deriveFont(int style,
           float size)通过复制此 Font对象并应用新样式和大小,创建一个新Font对象。 | 
|  Font | deriveFont(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)通过复制当前 Font对象并应用新的字体属性集,创建一个新Font对象。 | 
|  boolean | equals(Object obj)将此 Font对象与指定Object进行比较。 | 
| protected  void | finalize()移除本机 Font对象。 | 
|  Map<TextAttribute,?> | getAttributes()返回此 Font中可用的字体属性的映射。 | 
|  AttributedCharacterIterator.Attribute[] | getAvailableAttributes()返回由此 Font支持的所有属性的键。 | 
|  byte | getBaselineFor(char c)返回适合于显示此字符的基线。 | 
|  String | getFamily()返回此 Font的系列名称。 | 
|  String | getFamily(Locale l)返回此 Font的系列名称(已经针对指定语言环境进行了本地化)。 | 
| static Font | getFont(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)返回适合于此属性集合的 Font。 | 
| static Font | getFont(String nm)从系统属性列表返回一个 Font对象。 | 
| static Font | getFont(String nm,
        Font font)从系统属性列表获取指定的 Font。 | 
|  String | getFontName()返回此 Font的字体外观名称。 | 
|  String | getFontName(Locale l)返回此 Font的字体外观名称(已经针对指定语言环境进行了本地化)。 | 
|  float | getItalicAngle()返回此 Font的斜角。 | 
|  LineMetrics | getLineMetrics(char[] chars,
               int beginIndex,
               int limit,
               FontRenderContext frc)返回使用指定参数创建的 LineMetrics对象。 | 
|  LineMetrics | getLineMetrics(CharacterIterator ci,
               int beginIndex,
               int limit,
               FontRenderContext frc)返回使用指定参数创建的 LineMetrics对象。 | 
|  LineMetrics | getLineMetrics(String str,
               FontRenderContext frc)返回一个使用指定 String和FontRenderContext创建的LineMetrics对象。 | 
|  LineMetrics | getLineMetrics(String str,
               int beginIndex,
               int limit,
               FontRenderContext frc)返回使用指定参数创建的 LineMetrics对象。 | 
|  Rectangle2D | getMaxCharBounds(FontRenderContext frc)返回最大边界定义在 FontRenderContext中的字符的边界。 | 
|  int | getMissingGlyphCode()返回此 Font不具有指定的 unicode 字形时所使用的 glyphCode。 | 
|  String | getName()返回此 Font的逻辑名称。 | 
|  int | getNumGlyphs()返回此 Font中的字形数量。 | 
|  java.awt.peer.FontPeer | getPeer()已过时。 现在,字体呈现与平台无关。 | 
|  String | getPSName()返回此 Font的 postscript 名称。 | 
|  int | getSize()返回此 Font的点大小,舍入为整数。 | 
|  float | getSize2D()返回此 Font的点大小(以float值表示)。 | 
|  Rectangle2D | getStringBounds(char[] chars,
                int beginIndex,
                int limit,
                FontRenderContext frc)返回指定 FontRenderContext指定字符数组的逻辑边界。 | 
|  Rectangle2D | getStringBounds(CharacterIterator ci,
                int beginIndex,
                int limit,
                FontRenderContext frc)返回指定 FontRenderContext中针对指定CharacterIterator进行索引的字符的逻辑边界。 | 
|  Rectangle2D | getStringBounds(String str,
                FontRenderContext frc)返回指定 FontRenderContext中指定String的逻辑边界。 | 
|  Rectangle2D | getStringBounds(String str,
                int beginIndex,
                int limit,
                FontRenderContext frc)返回指定 FontRenderContext中指定String的逻辑边界。 | 
|  int | getStyle()返回此 Font的样式。 | 
|  AffineTransform | getTransform()返回与此 Font相关的变换的副本。 | 
|  int | hashCode()返回此 Font的哈希码。 | 
|  boolean | hasUniformLineMetrics()检查此 Font是否具有统一的行规格。 | 
|  boolean | isBold()指示此 Font对象的样式是否为 BOLD。 | 
|  boolean | isItalic()指示此 Font对象的样式是否为 ITALIC。 | 
|  boolean | isPlain()指示此 Font对象的样式是否为 PLAIN。 | 
|  boolean | isTransformed()指示此 Font对象是否具有影响其大小以及 Size 属性的变换。 | 
|  GlyphVector | layoutGlyphVector(FontRenderContext frc,
                  char[] text,
                  int start,
                  int limit,
                  int flags)返回一个新 GlyphVector对象,执行完整的文本布局(如有可能)。 | 
|  String | toString()将此 Font对象转换为String表示形式。 | 
| 从类 java.lang.Object 继承的方法 | 
|---|
| clone, getClass, notify, notifyAll, wait, wait, wait | 
| 字段详细信息 | 
|---|
public static final int PLAIN
public static final int BOLD
public static final int ITALIC
public static final int ROMAN_BASELINE
public static final int CENTER_BASELINE
public static final int HANGING_BASELINE
public static final int TRUETYPE_FONT
createFont(int, java.io.InputStream) 方法指定一个 TrueType 字体资源。
public static final int TYPE1_FONT
createFont(int, java.io.InputStream) 方法指定一个 Type1 字体资源。
protected String name
Font 的逻辑名称,它被传递到构造方法中。
getName()protected int style
Font 的样式,它被传递到构造方法中。此样式可以为 PLAIN、BOLD、ITALIC 或 BOLD+ITALIC。
getStyle()protected int size
Font 的点大小,舍入为整数。
getSize()protected float pointSize
float 形式表示的 Font 的点大小。
getSize(), 
getSize2D()public static final int LAYOUT_LEFT_TO_RIGHT
public static final int LAYOUT_RIGHT_TO_LEFT
public static final int LAYOUT_NO_START_CONTEXT
public static final int LAYOUT_NO_LIMIT_CONTEXT
| 构造方法详细信息 | 
|---|
public Font(String name,
            int style,
            int size)
Font。
 
字体名称可以是字体外观名称或字体系列名称。它与样式一起使用,以查找合适的字体外观。如果指定了字体系列名称,则使用样式参数从系列中选择最合适的外观。如果指定了字体外观名称,则合并外观的样式和样式参数,以便从同一个系列查找最匹配的字体。例如,如果指定外观名称 "Arial Bold" 及样式 Font.ITALIC,则字体系统在 "Arial" 系列中寻找既是粗体又是斜体的外观,可以将字体实例与物理字体外观 "Arial Bold Italic" 相关联。将样式参数与指定外观的样式合并,而不是执行添加或减去操作。这意味着,指定粗体外观和粗体样式并不会双倍加粗字体,而指定粗体外观和普通样式也不会变细字体。
 
如果无法找到所要求样式的外观,则字体系统可以应用样式设计算法来获得所需的样式。例如,如果要求 ITALIC,但是没有可用的斜体外观,则可以通过算法使普通外观倾斜。
 
字体名称查找是区分大小写的,可以使用 US 语言环境的大小写转换规则。
name - 字体名称。可以是字体外观名称或字体系列名称,并可表示此 GraphicsEnvironment 中找到的逻辑字体或物理字体。逻辑字体的系列名称有:Dialog、DialogInput、Monospaced、Serif 或 SansSerif。如果 name 为 null,则将新 Font 的 逻辑字体名称(由 getName() 返回)设置为 "Default"。style - Font 的样式常量。样式参数是整数位掩码,可以为 PLAIN,或 BOLD 和 ITALIC 的按位或(例如,ITALIC 或 BOLD|ITALIC)。如果样式参数不符合任何一个期望的整数位掩码,则将样式设置为 PLAIN。size - Font 的点大小GraphicsEnvironment.getAllFonts(), 
GraphicsEnvironment.getAvailableFontFamilyNames()public Font(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)
Font。此 Font 只识别 TextAttribute 中作为属性定义的键。如果 attributes 为 null,则使用默认属性初始化新 Font。
attributes - 分配给新 Font 的属性,或 null| 方法详细信息 | 
|---|
@Deprecated public java.awt.peer.FontPeer getPeer()
Font 的同位体。
Font 的同位体。public static Font getFont(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)
Font。
attributes - 分配给新 Font 的属性
FontTextAttribute
public static Font createFont(int fontFormat,
                              InputStream fontStream)
                       throws FontFormatException,
                              IOException
Font。创建的新 Font 的点大小为 1,样式为 PLAIN。然后,基本字体可以与此类中的 deriveFont 方法一起使用,从而派生出新 Font 对象,这些对象具有变化的大小、样式、变换和字体特征。此方法不会关闭 InputStream。
fontFormat - Font 的类型,如果指定了 TrueType 资源,则类型为 TRUETYPE_FONT,如果指定了 Type 1 资源,则类型为 TYPE1_FONT。fontStream - InputStream 对象,表示字体的输入数据。
Font。
IllegalArgumentException - 如果 fontFormat 不为 TRUETYPE_FONT 或 TYPE1_FONT。
FontFormatException - 如果 fontStream 数据不包含指定格式所需的字体表。
IOException - 如果无法完全读取 fontStream。
public static Font createFont(int fontFormat,
                              File fontFile)
                       throws FontFormatException,
                              IOException
Font。创建的新 Font 的点大小为 1,样式为 PLAIN。基本字体可以与此类中的 deriveFont 方法一起使用,从而派生出新 Font 对象,这些对象具有变化的大小、样式、变换和字体特征。
fontFormat - Font 的类型,如果指定了 TrueType 资源,则类型为 TRUETYPE_FONT,如果指定了 Type 1 资源,则类型为 TYPE1_FONT。只要引用了返回的字体,或它派生的字体,实现就可以继续访问 fontFile 以检索字体数据。因此,如果文件被更改,或变成不可访问的,其结果就是不确定的。fontFile - File 对象,表示字体的输入数据。
Font。
IllegalArgumentException - 如果 fontFormat 不为  TRUETYPE_FONTorTYPE1_FONT。
NullPointerException - 如果 fontFile 为 null。
IOException - 如果无法读取 fontFile。
FontFormatException - 如果 fontFile 不包含指定格式所需的字体表。
SecurityException - 如果正在执行的代码没有从文件中读取的权限。public AffineTransform getTransform()
Font 相关的变换的副本。
AffineTransform 对象,表示此 Font 对象的变换属性。public String getFamily()
Font 的系列名称。  
 
字体的系列名称是特定于字体的。两个字体 Helvetica Italic 和 Helvetica Bold 具有相同的系列名称 Helvetica,但它们的字体外观名称是 Helvetica Bold 和 Helvetica Italic。可用的系列名称列表可以通过使用 GraphicsEnvironment.getAvailableFontFamilyNames() 方法得到。
 
使用 getName 可以获得字体的逻辑名称。使用 getFontName 可以获得字体的字体外观名称。
String,此 Font 的系列名称。getName(), 
getFontName()public String getFamily(Locale l)
Font 的系列名称(已经针对指定语言环境进行了本地化)。
 
字体的系列名称是特定于字体的。两个字体 Helvetica Italic 和 Helvetica Bold 具有相同的系列名称 Helvetica,但它们的字体外观名称是 Helvetica Bold 和 Helvetica Italic。可用的系列名称列表可以通过使用 GraphicsEnvironment.getAvailableFontFamilyNames() 方法得到。
 
使用 getFontName 可以获得字体的字体外观名称。
l - 语言环境,要获得该语言环境的系列名称
String,表示字体的系列名称(已经针对指定语言环境进行了本地化)。getFontName(), 
Localepublic String getPSName()
Font 的 postscript 名称。使用 getFamily 可以获得字体的系列名称。使用 getFontName 可以获得字体的字体外观名称。
String,表示此 Font 的 postscript 名称。public String getName()
Font 的逻辑名称。使用 getFamily 可以获得字体的系列名称。使用 getFontName 可以获得字体的字体外观名称。
String,表示此 Font 的逻辑名称。getFamily(), 
getFontName()public String getFontName()
Font 的字体外观名称。例如,Helvetica Bold 可以作为字体外观名称返回。使用 getFamily 可以获得字体的系列名称。使用 getName 可以获得字体的逻辑名称。
String,表示此 Font 的字体外观名称。getFamily(), 
getName()public String getFontName(Locale l)
Font 的字体外观名称(已经针对指定语言环境进行了本地化)。例如,Helvetica Fett 可以作为字体外观名称返回。使用 getFamily 可以获得字体的系列名称。
l - 语言环境,要获得该语言环境的字体外观名称
String,表示字体外观名称(已经针对指定语言环境进行了本地化)。getFamily(), 
Localepublic int getStyle()
Font 的样式。样式可以为 PLAIN、BOLD、ITALIC 或 BOLD+ITALIC。
Font 的样式isPlain(), 
isBold(), 
isItalic()public int getSize()
Font 的点大小,舍入为整数。大多数用户都熟悉使用点大小 的概念,它用于指定字体中字形的大小。点大小定义了单间距文本文档中某行的基线到下一行的基线之间的测量。点大小是基于排字点 的,大约为 1/72 英寸。
 Java(tm)2D API 规定:1 点等于用户坐标中的 1 个单位。当使用规范化变换将用户空间坐标转换为设备空间坐标时,72 个用户空间单位等于设备空间中的 1 英寸。在这种情况下,1 点就是 1/72 英寸。
Font 的点大小(以 1/72 英寸为单位)。getSize2D(), 
GraphicsConfiguration.getDefaultTransform(), 
GraphicsConfiguration.getNormalizingTransform()public float getSize2D()
Font 的点大小(以 float 值表示)。
Font 的点大小(以 float 值表示)。getSize()public boolean isPlain()
Font 对象的样式是否为 PLAIN。
Font 样式为 PLAIN,则返回 true;否则返回 false。getStyle()public boolean isBold()
Font 对象的样式是否为 BOLD。
Font 对象的样式为 BOLD,则返回 true;否则返回 false。getStyle()public boolean isItalic()
Font 对象的样式是否为 ITALIC。
Font 对象的样式为 ITALIC,则返回 true;否则返回 false。getStyle()public boolean isTransformed()
Font 对象是否具有影响其大小以及 Size 属性的变换。
Font 对象具有无标识的 AffineTransform 属性,则返回 true;否则返回 false。getTransform()public static Font getFont(String nm)
Font 对象。nm 被视为要获得的系统属性的名称。然后,根据 Font.decode(String) 规范,将此属性的 String 值解释为一个 Font 对象。如果无法找到指定属性,则返回 null。
nm - 属性名称
Font 对象,如果没有这样的属性存在,则返回 null。
NullPointerException - 如果 nm 为 null。decode(String)public static Font decode(String str)
str 参数所描述的 Font。为了确保此方法返回所需的 Font,可以使用以下方式之一格式化 str 参数。
 
"PLAIN"、"BOLD"、"BOLDITALIC" 和 "ITALIC",pointsize 是点大小的正十进制整数表示形式。例如,如果想要的字体是 Arial、粗体、点大小为 18,则按以下方式调用此方法:"Arial-BOLD-18"。这等同于调用以下 Font 构造方法:new Font("Arial", Font.BOLD, 18);,值被解释为构造方法所指定的形式。
 有效的尾部十进制字段总是被解释为 pointsize。因此,后跟十进制值的 fontname 不应该在只有 fontname 的格式中使用。
如果样式名称字段不是一个有效的样式字符串,则它被解释为样式名称的一部分,并且使用默认样式。
只有 ' ' 或 '-' 可以用来分隔输入中的字段。所标识的分隔符是最接近字符串末尾的字符,它将有效的 pointsize 或有效的样式名称与字符串的其余部分分隔开来。Null(空)pointsize 和样式字段被视为有效字段,具有该字段的默认值。
有些字体名称可以包括分隔符 ' ' 或 '-'。如果 str 不由三部分构成,例如,style 或 pointsize 字段不出现在 str 中,并且 fontname 还包含确定为分隔符的字符,则这些打算作为 fontname 一部分出现的字符也可以解释为分隔符,因此字体名称无法正确识别。
 
 
默认大小为 12,默认样式为 PLAIN。如果 str 没有指定有效大小,则返回的 Font 大小为 12。如果 str 没有指定有效样式,则返回的 Font 样式为 PLAIN。如果没有在 str 参数中指定一个有效的字体名称,则此方法将返回系列名称为 "Dialog" 的字体。要确定系统上可以使用哪些字体系列名称,可以使用 GraphicsEnvironment.getAvailableFontFamilyNames() 方法。如果 str 为 null,则返回的新 Font 的系列名称为 "Dialog",大小为 12,样式为 PLAIN。
str - 字体名称,或 null
str 描述的 Font 对象,如果 str 为 null,则返回新的默认 Font。getFamily()
public static Font getFont(String nm,
                           Font font)
Font。在 System 的 getProperty 方法中,第一个参数被视为要获取的系统属性的名称。接着将此属性的 String 值解释为 Font 对象。 
 
属性值应该是 Font.decode(String) 所接受的形式之一。如果无法找到指定属性,则返回 font 参数。
nm - 不区分大小写的属性名称font - 如果没有定义属性 nm,则为要返回的默认 Font
Font 值。
NullPointerException - 如果 nm 为 null。decode(String)public int hashCode()
Font 的哈希码。
Object 中的 hashCodeFont 的哈希码值。Object.equals(java.lang.Object), 
Hashtablepublic boolean equals(Object obj)
Font 对象与指定 Object 进行比较。
Object 中的 equalsobj - 要比较的 Object
Font 对象,且描述的字体与此对象相同,则返回 true;否则,返回 false。Object.hashCode(), 
Hashtablepublic String toString()
Font 对象转换为 String 表示形式。
Object 中的 toStringFont 对象的 String 表示形式。public int getNumGlyphs()
Font 中的字形数量。此 Font 的字形代码,范围从 0 到 getNumGlyphs() - 1。
Font 的字形数量。public int getMissingGlyphCode()
Font 不具有指定的 unicode 字形时所使用的 glyphCode。
Font 的 glyphCode。public byte getBaselineFor(char c)
大字体可以支持不同的书写系统,并且每个系统都可以使用不同的基线。字符参数确定要使用的书写系统。客户不应该假定所有字符都使用相同的基线。
c - 用来标识书写系统的字符
LineMetrics.getBaselineOffsets(), 
ROMAN_BASELINE, 
CENTER_BASELINE, 
HANGING_BASELINEpublic Map<TextAttribute,?> getAttributes()
Font 中可用的字体属性的映射。属性包括诸如连字和字形替换之类的事情。
Font 的属性映射。public AttributedCharacterIterator.Attribute[] getAvailableAttributes()
Font 支持的所有属性的键。这些属性可以用来派生其他字体。
Font 所支持的所有属性的键。
public Font deriveFont(int style,
                       float size)
Font 对象并应用新样式和大小,创建一个新 Font 对象。
style - 新 Font 的样式size - 新 Font 的大小
Font 对象。
public Font deriveFont(int style,
                       AffineTransform trans)
Font 对象并应用新样式和变换,创建一个新 Font 对象。
style - 新 Font 的样式trans - 与新 Font 相关的 AffineTransform
Font 对象。
IllegalArgumentException - 如果 trans 为 nullpublic Font deriveFont(float size)
Font 对象并应用新的大小,创建一个新 Font 对象。
size - 新 Font 的大小。
Font 对象。public Font deriveFont(AffineTransform trans)
Font 对象并应用新的变换,创建一个新  Font 对象。
trans - 与新 Font 相关的 AffineTransform
Font 对象。
IllegalArgumentException - 如果 trans 为 nullpublic Font deriveFont(int style)
Font 对象,并应用新的样式,创建一个新 Font 对象。
style - 新 Font 的样式
Font 对象。public Font deriveFont(Map<? extends AttributedCharacterIterator.Attribute,?> attributes)
Font 对象并应用新的字体属性集,创建一个新 Font 对象。
attributes - 为新 Font 所启用的属性映射
Font 对象。public boolean canDisplay(char c)
Font 是否具有指定字符的字形。
注:此方法无法处理增补字符。要支持所有 Unicode 字符,包括增补字符,可以使用 canDisplay(int) 方法或 canDisplayUpTo 方法。
c - 需要字形的字符
Font 具有该字符的字形,则返回 true;否则返回 false。public boolean canDisplay(int codePoint)
Font 是否具有指定字符的字形。
codePoint - 需要字形的字符(Unicode 代码点)。
Font 具有该字符的字形,则返回 true;否则返回 false。
IllegalArgumentException - 如果代码点不是一个有效的 Unicode 代码点。Character.isValidCodePoint(int)public int canDisplayUpTo(String str)
Font 是否可以显示指定的 String。对于使用 Unicode 编码的字符串,知道特定字体是否可以显示该字符串是很重要的。此方法返回 String str 中的一个偏移量,这是此 Font 不使用缺少的字形代码就无法显示的第一个字符。如果 Font 可以显示所有字符,则返回 -1。
str - 一个 String 对象
str 中的一个偏移量,指向 str 中此 Font 无法显示的第一个字符;如果此 Font 可以显示 str 中的所有字符,则返回 -1。
public int canDisplayUpTo(char[] text,
                          int start,
                          int limit)
Font 是否可以显示指定 text 中从 start 开始至 limit 结束的所有字符。此方法是一次方便的重载。
text - 指定 char 值的数组start - 指定 char 值数组中的指定起始偏移量 (in char)limit - 指定 char 值数组中的指定结束偏移量 (in char)
text 中的偏移量,指向此 Font 无法显示的 text 中的第一个字符;如果此 Font 可以显示 text 中的所有字符,则返回 -1。
public int canDisplayUpTo(CharacterIterator iter,
                          int start,
                          int limit)
Font 是否可以显示由 iter 指定的文本(从 start 开始至 limit 结束)。
iter - CharacterIterator 对象start - 指定 CharacterIterator 中的指定起始偏移量。limit - 指定 CharacterIterator 中的指定结束偏移量。
iter 中的偏移量,它指向 iter 中此 Font 无法显示的第一个字符;如果此 Font 可以显示 iter 中的所有字符,则返回 -1。public float getItalicAngle()
Font 的斜角。斜角是与此 Font 的动作最匹配的 caret 的反斜面。
Font 的 ITALIC 样式的角度TextAttribute.POSTUREpublic boolean hasUniformLineMetrics()
Font 是否具有统一的行规格。逻辑 Font 可以是复合字体,这意味着它由不同的物理字体组成,可以覆盖不同的代码范围。其中每一种字体都可能有不同的 LineMetrics。如果逻辑 Font 是单一字体,则规格将是统一的。
Font 具有统一的行规格,则返回 true;否则返回 false。
public LineMetrics getLineMetrics(String str,
                                  FontRenderContext frc)
String 和 FontRenderContext 创建的 LineMetrics 对象。
str - 指定的 Stringfrc - 指定的 FontRenderContext
String 和 FontRenderContext 创建的 LineMetrics 对象。
public LineMetrics getLineMetrics(String str,
                                  int beginIndex,
                                  int limit,
                                  FontRenderContext frc)
LineMetrics 对象。
str - 指定的 StringbeginIndex - str 的初始偏移量limit - str 的结束偏移量frc - 指定的 FontRenderContext
LineMetrics 对象。
public LineMetrics getLineMetrics(char[] chars,
                                  int beginIndex,
                                  int limit,
                                  FontRenderContext frc)
LineMetrics 对象。
chars - 字符数组beginIndex - chars 的初始偏移量limit - chars 的结束偏移量frc - 指定的 FontRenderContext
LineMetrics 对象。
public LineMetrics getLineMetrics(CharacterIterator ci,
                                  int beginIndex,
                                  int limit,
                                  FontRenderContext frc)
LineMetrics 对象。
ci - 指定的 CharacterIteratorbeginIndex - ci 中的初始偏移量limit - ci 的结束偏移量frc - 指定的 FontRenderContext
LineMetrics 对象。
public Rectangle2D getStringBounds(String str,
                                   FontRenderContext frc)
FontRenderContext 中指定 String 的逻辑边界。逻辑边界包含 origin、ascent、advance 和 height,其中包括了 leading。逻辑边界并不总是包围所有文本。例如,在某些语言和字体中,accent 标记可以位于 ascent 之上,或 descent 之下。要得到可视的边界框(它包围了所有文本),可以使用 TextLayout 的 getBounds 方法。
str - 指定的 Stringfrc - 指定的 FontRenderContext
Rectangle2D,它是指定 FontRenderContext 中指定 String 的边界框。FontRenderContext, 
createGlyphVector(java.awt.font.FontRenderContext, java.lang.String)
public Rectangle2D getStringBounds(String str,
                                   int beginIndex,
                                   int limit,
                                   FontRenderContext frc)
FontRenderContext 中指定 String 的逻辑边界。逻辑边界包含 origin、ascent、advance 和 height,其中包括了 leading。逻辑边界并不总是包围所有文本。例如,在某些语言和字体中,accent 标记可以位于 ascent 之上,或 descent 之下。要得到可视的边界框(它包围了所有文本),可以使用 TextLayout 的 getBounds 方法。
str - 指定的 StringbeginIndex - str 的初始偏移量limit - str 的结束偏移量frc - 指定的 FontRenderContext
Rectangle2D,它是指定 FontRenderContext 中指定 String 的边界框。
IndexOutOfBoundsException - 如果 beginIndex 小于零,或 limit 大于 str 的长度,或 beginIndex 大于 limit。FontRenderContext, 
createGlyphVector(java.awt.font.FontRenderContext, java.lang.String)
public Rectangle2D getStringBounds(char[] chars,
                                   int beginIndex,
                                   int limit,
                                   FontRenderContext frc)
FontRenderContext 指定字符数组的逻辑边界。逻辑边界包含 origin、ascent、advance 和 height,其中包括了 leading。 逻辑边界并不总是包围所有文本。例如,在某些语言和字体中,accent 标记可以位于 ascent 之上,或 descent 之下。要得到可视的边界框(它包围了所有文本),可以使用 TextLayout 的 getBounds 方法。
chars - 字符数组beginIndex - 字符数组的初始偏移量limit - 字符数组的结束偏移量frc - 指定的 FontRenderContext
Rectangle2D,它是指定 FontRenderContext 中指定字符数组的边界框。
IndexOutOfBoundsException - 如果 beginIndex 小于零,或 limit 大于 chars 的长度,或 beginIndex 大于 limit。FontRenderContext, 
createGlyphVector(java.awt.font.FontRenderContext, java.lang.String)
public Rectangle2D getStringBounds(CharacterIterator ci,
                                   int beginIndex,
                                   int limit,
                                   FontRenderContext frc)
FontRenderContext 中针对指定 CharacterIterator 进行索引的字符的逻辑边界。逻辑边界包含 origin、ascent、advance 和 height,其中包括了 leading。逻辑边界并不总是包围所有文本。例如,在某些语言和字体中,accent 标记可以位于 ascent 之上,或 descent 之下。要得到可视的边界框(它包围了所有文本),可以使用 TextLayout 的 getBounds 方法。
ci - 指定的 CharacterIteratorbeginIndex - ci 中的初始偏移量limit - ci 中的结束偏移量frc - 指定的 FontRenderContext
Rectangle2D,它是指定 FontRenderContext 中针对指定 CharacterIterator 进行索引的字符的边界框。
IndexOutOfBoundsException - 如果 beginIndex 小于 ci 的起始索引,或 limit 大于 ci 的结束索引,或 beginIndex 大于 limitFontRenderContext, 
createGlyphVector(java.awt.font.FontRenderContext, java.lang.String)public Rectangle2D getMaxCharBounds(FontRenderContext frc)
FontRenderContext 中的字符的边界。
frc - 指定的 FontRenderContext
Rectangle2D,它是具有最大边界的字符的边界框。
public GlyphVector createGlyphVector(FontRenderContext frc,
                                     String str)
Font 中的 Unicode cmap 将字符一一映射到字形,从而创建一个 GlyphVector。除了字形到字符的映射之外,此方法不做任何其他处理。这意味着,此方法对于某些脚本是无用的,如 Arabic、Hebrew、Thai 和 Indic,它们要求进行重排序、整形或连字替换。
frc - 指定的 FontRenderContextstr - 指定的 String
String 和指定 FontRenderContext 创建的新 GlyphVector。
public GlyphVector createGlyphVector(FontRenderContext frc,
                                     char[] chars)
Font 中的 Unicode cmap 将字符一一映射到字形,从而创建一个 GlyphVector。除了字形到字符的映射之外,此方法不做任何其他处理。这意味着,此方法对于某些脚本是无用的,如 Arabic、Hebrew、Thai 和 Indic,它们要求进行重排序、整形或连字替换。
frc - 指定的 FontRenderContextchars - 指定的字符数组
FontRenderContext 创建的 GlyphVector。
public GlyphVector createGlyphVector(FontRenderContext frc,
                                     CharacterIterator ci)
Font 中的 Unicode cmap 将指定字符一一映射到字形,从而创建一个 GlyphVector。除了字形到字符的映射之外,此方法不做任何其他处理。这意味着,此方法对于某些脚本是无用的,如 Arabic、Hebrew、Thai 和 Indic,它们要求进行重排序、整形或连字替换。
frc - 指定的 FontRenderContextci - 指定的 CharacterIterator
CharacterIterator 和指定 FontRenderContext 创建的 GlyphVector。
public GlyphVector createGlyphVector(FontRenderContext frc,
                                     int[] glyphCodes)
Font 中的 Unicode cmap 将字符一一映射到字形,从而创建一个 GlyphVector。除了字形到字符的映射之外,此方法不做任何其他处理。这意味着,此方法对于某些脚本是无用的,如 Arabic、Hebrew、Thai 和 Indic,它们要求进行重排序、整形或连字替换。
frc - 指定的 FontRenderContextglyphCodes - 指定的整数数组
FontRenderContext 创建的 GlyphVector。
public GlyphVector layoutGlyphVector(FontRenderContext frc,
                                     char[] text,
                                     int start,
                                     int limit,
                                     int flags)
GlyphVector 对象,执行完整的文本布局(如有可能)。复杂文本要求有完整布局,如 Arabic 或 Hindi。对不同脚本的支持取决于字体和实现。  
Bidi 只应该在具有统一方向的文本上执行。用 flags 参数来指示方向,通过使用 LAYOUT_RIGHT_TO_LEFT 来指示从右到左(Arabic 和 Hebrew)的运行方向,或通过使用 LAYOUT_LEFT_TO_RIGHT 来指示从左到右 (English) 的运行方向。
此外,有些操作(比如 Arabic 整形)需要上下文,这样在开始和结束处的字符才会有合适的形状。有时,在所提供范围之外的缓冲区中的数据并不是有效数据。值 LAYOUT_NO_START_CONTEXT 和 LAYOUT_NO_LIMIT_CONTEXT 可以被添加到 flags 参数中,分别指示在 start 之前或 limit 之后的文本不应该作为上下文进行检查。
flags 参数的所有其他值均被保留。
frc - 指定的 FontRenderContexttext - 要布局的文本start - GlyphVector 所要使用的文本的起始处limit - GlyphVector 所要使用的文本的结束处flags - 如上所述的控制标志
GlyphVector,表示 start 和 limit 之间的文本,具有经过选择和定位的字形,以便以最佳方式表示文本
ArrayIndexOutOfBoundsException - 如果 start 或 limit 超出了边界Bidi, 
LAYOUT_LEFT_TO_RIGHT, 
LAYOUT_RIGHT_TO_LEFT, 
LAYOUT_NO_START_CONTEXT, 
LAYOUT_NO_LIMIT_CONTEXT
protected void finalize()
                 throws Throwable
Font 对象。
Object 中的 finalizeThrowable - 此方法抛出的 Exception| 
 | JavaTM 2 Platform Standard Ed. 5.0 | |||||||||
| 上一个类 下一个类 | 框架 无框架 | |||||||||
| 摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 | |||||||||
版权所有 2004 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策。