Code Search for Developers
 
 
  

IDeviceRenderer.java from BIRT at Krugle


Show IDeviceRenderer.java syntax highlighted

/***********************************************************************
 * Copyright (c) 2004 Actuate Corporation.
 * 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:
 * Actuate Corporation - initial API and implementation
 ***********************************************************************/

package org.eclipse.birt.chart.device;

import java.util.Locale;

import org.eclipse.birt.chart.exception.ChartException;

import com.ibm.icu.util.ULocale;

/**
 * Combines the primitive rendering notifications provided in the primitive and
 * other convenience methods needed by a device renderer. In addition, it
 * provides an accessor to retrieve the underlying graphics context on which
 * primitives are being rendered.
 * 
 * Any new device renderer would have to implement this interface for it to
 * transparently build charts via the rendering framework provided.
 * 
 * Note that the device renderer works in conjunction with a display server
 * implementation to correctly layout primitives.
 */
public interface IDeviceRenderer extends
		IPrimitiveRenderer,
		IStructureDefinitionListener
{

	/**
	 * A property name that identifies a device-specific file identifier
	 */
	public static final String FILE_IDENTIFIER = "device.file.identifier"; //$NON-NLS-1$

	/**
	 * A property name that identifies an output format identifier
	 */
	public static final String FORMAT_IDENTIFIER = "device.output.format.identifier"; //$NON-NLS-1$

	/**
	 * A property name that identifies a device-specific graphics context
	 */
	public static final String GRAPHICS_CONTEXT = "device.output.context"; //$NON-NLS-1$

	/**
	 * A property name that identifies a device-specific visual component (e.g.
	 * used for event detection)
	 */
	public static final String UPDATE_NOTIFIER = "device.component"; //$NON-NLS-1$

	/**
	 * A property name that identifies the expected bounds of the chart being
	 * generated. This notification is sent out to provide the renderer with a
	 * hint about the location and size of the output being generated typically
	 * used with an Image file output. This is internally set by the
	 * 'Generator'.
	 */
	public static final String EXPECTED_BOUNDS = "device.bounds"; //$NON-NLS-1$

	/**
	 * A property name that identifies an instance of a cached java.awt.Image
	 * that may be passed in for potential reuse. In general, the image device
	 * renderers are configured to create a new image instance for every chart
	 * image generation request if a cached image is not specified. Ensure that
	 * the image passed in externally uses the correct size in pixels equivalent
	 * to the expected bounds specified in points.
	 */
	public static final String CACHED_IMAGE = "cached.image"; //$NON-NLS-1$

	/**
	 * A property name that indicates if the output associated with the device
	 * should be compressed ('true') or written out as is uncompressed
	 * ('false'). Device renderers should interpret a missing undefined value as
	 * uncompressed.
	 */
	public static final String COMPRESSED_OUTPUT = "output.compressed"; //$NON-NLS-1$

	/**
	 * A property name that indicates the dpi (dots/pixels per inch) resolution
	 * to use when rendering to the device. This is used to convert 'points' in
	 * pixels (a point is 1/72 inch). If not indicated, it will use the default
	 * dpi resolution of the corresponding display server (typically 96dpi)
	 */
	public static final String DPI_RESOLUTION = "device.resolution"; //$NON-NLS-1$

	/**
	 * A Property to enable/disable the caching of the image stream on disk
	 * Default is false.
	 */
	public static final Object CACHE_ON_DISK = "device.disk.cache"; //$NON-NLS-1$

	/**
	 * Device-specific write-only properties that may be set for each device
	 * renderer
	 * 
	 * @param sProperty
	 *            The property whose value is to be set
	 * @param oValue
	 *            The value associated with the property
	 */
	void setProperty( String sProperty, Object oValue );

	/**
	 * Returns an instance of the low level graphics context being used to
	 * render primitives
	 * 
	 * @return An instance of the low level graphics context being used to
	 *         render primitives
	 */
	Object getGraphicsContext( );

	/**
	 * Returns an instance of the low level display server capable of providing
	 * text metrics, screen resolution, etc.
	 * 
	 * @return An instance of the low level display server capable of providing
	 *         text metrics, screen resolution, etc.
	 */
	IDisplayServer getDisplayServer( );

	/**
	 * Indicated to the caller if the device renderer needs additional structure
	 * definition callbacks to identify how primitives are to be grouped to
	 * possibly aid in client side event handling.
	 * 
	 * @return 'true' if structure definition notificates are required in the
	 *         device renderer implementation.
	 */
	boolean needsStructureDefinition( );

	/**
	 * A notification sent to the device to initialize itself before rendering
	 * begins
	 * 
	 * @throws RenderingException
	 */
	void before( ) throws ChartException;

	/**
	 * A notification sent to the device to cleanup after rendering is done
	 * 
	 * @throws RenderingException
	 */
	void after( ) throws ChartException;

	/**
	 * A notification sent to the device to free all allocated system resources.
	 */
	void dispose( );

	/**
	 * Notifies a device renderer to present an exception in its context
	 * 
	 * @param ex
	 *            The exception to be presented
	 */
	void presentException( Exception ex );

	/**
	 * Provides the locale to device renderer implementations as needed to
	 * retrieve localized resources for presentation.
	 * 
	 * @return The locale to be used
	 * @deprecated use {@link #getULocale()} instead.
	 */
	Locale getLocale( );

	/**
	 * Provides the locale to device renderer implementations as needed to
	 * retrieve localized resources for presentation.
	 * 
	 * @return The locale to be used
	 * @since 2.1
	 */
	ULocale getULocale( );
}



See more files for this project here

BIRT

BIRT is an open source, Eclipse-based reporting system that integrates with your application to produce compelling reports for both web and PDF.

Project homepage: http://www.eclipse.org/birt/phoenix/
Programming language(s): Java,XML
License: gpl2

  DeviceAdapter.java
  DisplayAdapter.java
  EmptyUpdateNotifier.java
  ICallBackNotifier.java
  IDeviceRenderer.java
  IDisplayServer.java
  IImageMapEmitter.java
  IPrimitiveRenderer.java
  IStructureDefinitionListener.java
  ITextMetrics.java
  IUpdateNotifier.java
  TextAdapter.java
  package.html