1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
|
/**
* ===========================================
* LibLayout : a free Java layouting library
* ===========================================
*
* Project Info: http://reporting.pentaho.org/liblayout/
*
* (C) Copyright 2006-2007, by Pentaho Corporation and Contributors.
*
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation;
* either version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307, USA.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* ------------
* $Id: OutputProcessorMetaData.java 6489 2008-11-28 14:53:40Z tmorgner $
* ------------
* (C) Copyright 2006-2007, by Pentaho Corporation.
*/
package org.jfree.layouting.output;
import org.jfree.layouting.input.style.keys.page.PageSize;
import org.jfree.layouting.input.style.values.CSSConstant;
import org.jfree.layouting.layouter.context.FontSpecification;
import org.pentaho.reporting.libraries.fonts.registry.FontFamily;
import org.pentaho.reporting.libraries.fonts.registry.FontStorage;
import org.pentaho.reporting.libraries.fonts.registry.FontMetrics;
/**
* Creation-Date: 14.12.2005, 13:47:00
*
* @author Thomas Morgner
*/
public interface OutputProcessorMetaData
{
public boolean isFeatureSupported (OutputProcessorFeature.BooleanOutputProcessorFeature feature);
public double getNumericFeatureValue (OutputProcessorFeature.NumericOutputProcessorFeature feature);
public String getNormalizedFontFamilyName (final String name);
public FontFamily getDefaultFontFamily();
public FontFamily getFontFamilyForGenericName(CSSConstant genericName);
/**
* Although most font systems are global, some may have some issues with
* caching. OutputTargets may have to tweak the font storage system to their
* needs.
*
* @return
*/
public FontStorage getFontStorage();
public double getFontSize (CSSConstant constant);
/**
* Returns the media type of the output target. This corresponds directly to
* the CSS defined media types and is used as a selector.
*
* @return the media type of the output target.
*/
public String getMediaType();
/**
* The export descriptor is a string that describes the output characteristics.
* For libLayout outputs, it should start with the output class (one of
* 'pageable', 'flow' or 'stream'), followed by '/liblayout/' and finally
* followed by the output type (ie. PDF, Print, etc).
*
* @return the export descriptor.
*/
public String getExportDescriptor();
/**
* Returns the default physical page size. If not defined otherwise, this
* will also be the logical size.
*
* @return
*/
public PageSize getDefaultPageSize();
/**
* Returns the vertical page span. If the value is less than one, it will
* be corrected to one.
*
* @return
*/
public int getVerticalPageSpan ();
/**
* Returns the horizontal page span. If the value is less than one, it will
* be corrected to one.
*
* @return
*/
public int getHorizontalPageSpan ();
public boolean isValid (FontSpecification spec);
public FontMetrics getFontMetrics(FontSpecification spec);
public Class[] getSupportedResourceTypes();
/**
* An iterative output processor accepts and processes small content chunks.
* If this method returns false, the output processor will not receive the
* content until the whole document is processed.
*
* @return
*/
public boolean isIterative();
}
|