blob: 5171dda3699691efa910cfe79f9e043536a2f56a [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2004 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jface.viewers;
import org.eclipse.swt.graphics.Image;
/**
* A label decorator decorates the label text and image for some element.
* The original label text and image are obtained by some other means,
* for example by a label provider.
*
* @see ILabelProvider
*/
public interface ILabelDecorator extends IBaseLabelProvider {
/**
* Returns an image that is based on the given image,
* but decorated with additional information relating to the state
* of the provided element.
*
* Text and image decoration updates can occur as a result of other updates
* within the workbench including deferred decoration by background processes.
* Clients should handle labelProviderChangedEvents for the given element to get
* the complete decoration.
* @see LabelProviderChangedEvent
* @see IBaseLabelProvider#addListener
*
* @param image the input image to decorate, or <code>null</code> if the element has no image
* @param element the element whose image is being decorated
* @return the decorated image, or <code>null</code> if no decoration is to be applied
*
* @see org.eclipse.jface.resource.CompositeImageDescriptor
*/
public Image decorateImage(Image image, Object element);
/**
* Returns a text label that is based on the given text label,
* but decorated with additional information relating to the state
* of the provided element.
*
* Text and image decoration updates can occur as a result of other updates
* within the workbench including deferred decoration by background processes.
* Clients should handle labelProviderChangedEvents for the given element to get
* the complete decoration.
* @see LabelProviderChangedEvent
* @see IBaseLabelProvider#addListener
*
* @param text the input text label to decorate
* @param element the element whose image is being decorated
* @return the decorated text label, or <code>null</code> if no decoration is to be applied
*/
public String decorateText(String text, Object element);
}