Eclipse Platform
Release 3.3

org.eclipse.jface.resource
Class FontDescriptor

java.lang.Object
  extended byorg.eclipse.jface.resource.DeviceResourceDescriptor
      extended byorg.eclipse.jface.resource.FontDescriptor

public abstract class FontDescriptor
extends DeviceResourceDescriptor

Lightweight descriptor for a font. Creates the described font on demand. Subclasses can implement different ways of describing a font. These objects will be compared, so hashCode(...) and equals(...) must return something meaningful.

Since:
3.1

Constructor Summary
FontDescriptor()
           
 
Method Summary
static FontData copy(FontData next)
          Returns a copy of the original FontData
static FontData[] copy(FontData[] original)
          Returns an array of FontData containing copies of the FontData from the original.
abstract  Font createFont(Device device)
          Creates the Font described by this descriptor.
static FontDescriptor createFrom(Font font)
          Creates a FontDescriptor that describes an existing font.
static FontDescriptor createFrom(FontData data)
          Creates a new FontDescriptor given the associated FontData
static FontDescriptor createFrom(FontData[] data)
          Creates a new FontDescriptor given the an array of FontData that describes the font.
static FontDescriptor createFrom(Font font, Device originalDevice)
          Deprecated. use createFrom(Font)
static FontDescriptor createFrom(String name, int height, int style)
          Creates a new FontDescriptor given an OS-specific font name, height, and style.
 Object createResource(Device device)
          Creates the resource described by this descriptor
abstract  void destroyFont(Font previouslyCreatedFont)
          Deallocates anything that was allocated by createFont, given a font that was allocated by an equal FontDescriptor.
 void destroyResource(Object previouslyCreatedObject)
          Undoes everything that was done by a previous call to create(...), given the object that was returned by create(...).
 FontData[] getFontData()
          Returns the set of FontData associated with this font.
 FontDescriptor increaseHeight(int heightDelta)
          Returns a FontDescriptor that is equivalent to the reciever, but whose height is larger by the given number of points.
 FontDescriptor setHeight(int height)
          Returns a new FontDescriptor that is equivalent to the reciever, but has the given height.
 FontDescriptor setStyle(int style)
          Returns a FontDescriptor that is equivalent to the reciever, but uses the given style bits.
 FontDescriptor withStyle(int style)
          Returns a FontDescriptor that is equivalent to the reciever, but has the given style bits, in addition to any styles the reciever already has.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

FontDescriptor

public FontDescriptor()
Method Detail

createFrom

public static FontDescriptor createFrom(Font font,
                                        Device originalDevice)
Deprecated. use createFrom(Font)

Creates a FontDescriptor that describes an existing font. The resulting descriptor depends on the Font. Disposing the Font while the descriptor is still in use may throw a graphic disposed exception.

Parameters:
font - a font to describe
originalDevice - must be the same Device that was passed into the font's constructor when it was first created.
Returns:
a newly created FontDescriptor.
Since:
3.1

createFrom

public static FontDescriptor createFrom(Font font)
Creates a FontDescriptor that describes an existing font. The resulting descriptor depends on the original Font, and disposing the original Font while the descriptor is still in use may cause SWT to throw a graphic disposed exception.

Parameters:
font - font to create
Returns:
a newly created FontDescriptor that describes the given font
Since:
3.1

createFrom

public static FontDescriptor createFrom(FontData[] data)
Creates a new FontDescriptor given the an array of FontData that describes the font.

Parameters:
data - an array of FontData that describes the font (will be passed into the Font's constructor)
Returns:
a FontDescriptor that describes the given font
Since:
3.1

createFrom

public static FontDescriptor createFrom(FontData data)
Creates a new FontDescriptor given the associated FontData

Parameters:
data - FontData describing the font to create
Returns:
a newly created FontDescriptor

createFrom

public static FontDescriptor createFrom(String name,
                                        int height,
                                        int style)
Creates a new FontDescriptor given an OS-specific font name, height, and style.

Parameters:
name - os-specific font name
height - height (pixels)
style - a bitwise combination of NORMAL, BOLD, ITALIC
Returns:
a new FontDescriptor
See Also:
Font.Font(org.eclipse.swt.graphics.Device, java.lang.String, int, int)

getFontData

public FontData[] getFontData()
Returns the set of FontData associated with this font. Modifying the elements in the returned array has no effect on the original FontDescriptor.

Returns:
the set of FontData associated with this font
Since:
3.3

copy

public static FontData[] copy(FontData[] original)
Returns an array of FontData containing copies of the FontData from the original.

Parameters:
original - array to copy
Returns:
a deep copy of the original array
Since:
3.3

copy

public static FontData copy(FontData next)
Returns a copy of the original FontData

Parameters:
next - FontData to copy
Returns:
a copy of the given FontData
Since:
3.3

setStyle

public final FontDescriptor setStyle(int style)
Returns a FontDescriptor that is equivalent to the reciever, but uses the given style bits.

Does not modify the reciever.

Parameters:
style - a bitwise combination of SWT.NORMAL, SWT.ITALIC and SWT.BOLD
Returns:
a new FontDescriptor with the given style
Since:
3.3

withStyle

public final FontDescriptor withStyle(int style)

Returns a FontDescriptor that is equivalent to the reciever, but has the given style bits, in addition to any styles the reciever already has.

Does not modify the reciever.

Parameters:
style - a bitwise combination of SWT.NORMAL, SWT.ITALIC and SWT.BOLD
Returns:
a new FontDescriptor with the given additional style bits
Since:
3.3

setHeight

public final FontDescriptor setHeight(int height)

Returns a new FontDescriptor that is equivalent to the reciever, but has the given height.

Does not modify the reciever.

Parameters:
height - a height, in points
Returns:
a new FontDescriptor with the height, in points
Since:
3.3

increaseHeight

public final FontDescriptor increaseHeight(int heightDelta)

Returns a FontDescriptor that is equivalent to the reciever, but whose height is larger by the given number of points.

Does not modify the reciever.

Parameters:
heightDelta - a change in height, in points. Negative values will return smaller fonts.
Returns:
a FontDescriptor whose height differs from the reciever by the given number of points.
Since:
3.3

createFont

public abstract Font createFont(Device device)
                         throws DeviceResourceException
Creates the Font described by this descriptor.

Parameters:
device - device on which to allocate the font
Returns:
a newly allocated Font (never null)
Throws:
DeviceResourceException - if unable to allocate the Font
Since:
3.1

destroyFont

public abstract void destroyFont(Font previouslyCreatedFont)
Deallocates anything that was allocated by createFont, given a font that was allocated by an equal FontDescriptor.

Parameters:
previouslyCreatedFont - previously allocated font
Since:
3.1

createResource

public final Object createResource(Device device)
                            throws DeviceResourceException
Description copied from class: DeviceResourceDescriptor
Creates the resource described by this descriptor

Specified by:
createResource in class DeviceResourceDescriptor
Parameters:
device - the Device on which to allocate the resource
Returns:
the newly allocated resource (not null)
Throws:
DeviceResourceException - if unable to allocate the resource

destroyResource

public final void destroyResource(Object previouslyCreatedObject)
Description copied from class: DeviceResourceDescriptor
Undoes everything that was done by a previous call to create(...), given the object that was returned by create(...).

Specified by:
destroyResource in class DeviceResourceDescriptor
Parameters:
previouslyCreatedObject - an object that was returned by an equal descriptor in a previous call to createResource(...).

Eclipse Platform
Release 3.3

Guidelines for using Eclipse APIs.

Copyright (c) IBM Corp. and others 2000, 2007. All rights reserved.