Eclipse Platform
Release 3.2

org.eclipse.ui.themes
Interface IThemeManager


public interface IThemeManager

A theme manager is an object that contains references to usable ITheme objects and maintains a reference to the currently active theme. This theme will be used by the workbench to decorate tab folders and other controls where possible. The workbench implementation of this interface will push the values of the current theme into the underlying jface registries (ColorRegistry and FontRegistry whenever the current theme changes. Clients who do not need access to specific themes may instead attach listeners to these registries directly.

This interface is not intended to be implemented or extended by clients.

Since:
3.0
See Also:
IWorkbench.getThemeManager()

Field Summary
static java.lang.String CHANGE_CURRENT_THEME
          Indicates that the current theme has changed to a new theme.
static java.lang.String DEFAULT_THEME
          The default theme id.
 
Method Summary
 void addPropertyChangeListener(IPropertyChangeListener listener)
          Adds a property listener to the manager.
 ITheme getCurrentTheme()
          Get the currently active theme.
 ITheme getTheme(java.lang.String id)
          Get a theme.
 void removePropertyChangeListener(IPropertyChangeListener listener)
          Removes a property listener from the workbench.
 void setCurrentTheme(java.lang.String id)
          Set the currently active theme.
 

Field Detail

CHANGE_CURRENT_THEME

static final java.lang.String CHANGE_CURRENT_THEME
Indicates that the current theme has changed to a new theme.

See Also:
Constant Field Values

DEFAULT_THEME

static final java.lang.String DEFAULT_THEME
The default theme id.

See Also:
Constant Field Values
Method Detail

addPropertyChangeListener

void addPropertyChangeListener(IPropertyChangeListener listener)
Adds a property listener to the manager. Any events fired by the underlying registries of the current theme will cause an event to be fired. This event is the same event that was fired by the registry. As such, the "source" attribute of the event will not be this manager, but rather the color or font registry. Additionally, an event is fired when the current theme changes to a new theme. The "property" attribute of such an event will have the value CHANGE_CURRENT_THEME.

Parameters:
listener - the listener to add

getCurrentTheme

ITheme getCurrentTheme()
Get the currently active theme.

Returns:
the current theme. This will never be null.

getTheme

ITheme getTheme(java.lang.String id)
Get a theme.

Parameters:
id - the theme to find.
Returns:
the ITheme or null if it cannot be found.

removePropertyChangeListener

void removePropertyChangeListener(IPropertyChangeListener listener)
Removes a property listener from the workbench.

Parameters:
listener - the listener to remove

setCurrentTheme

void setCurrentTheme(java.lang.String id)
Set the currently active theme.

Parameters:
id - the id of the new active theme

Eclipse Platform
Release 3.2

Guidelines for using Eclipse APIs.

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