/**
* ===========================================
* 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: FontSmoothResolveHandler.java 6653 2008-12-02 14:53:40Z tmorgner $
* ------------
* (C) Copyright 2006-2007, by Pentaho Corporation.
*/
package org.jfree.layouting.layouter.style.resolver.autovalue.fonts;
import org.jfree.layouting.LayoutProcess;
import org.jfree.layouting.input.style.StyleKey;
import org.jfree.layouting.input.style.keys.font.FontSmooth;
import org.jfree.layouting.input.style.keys.font.FontStyleKeys;
import org.jfree.layouting.layouter.context.FontSpecification;
import org.jfree.layouting.layouter.context.LayoutContext;
import org.jfree.layouting.layouter.model.LayoutElement;
import org.jfree.layouting.layouter.style.resolver.ResolveHandler;
import org.jfree.layouting.output.OutputProcessorFeature;
/**
* Creation-Date: 18.12.2005, 15:13:24
*
* @author Thomas Morgner
*/
public class FontSmoothResolveHandler implements ResolveHandler
{
public FontSmoothResolveHandler()
{
}
/**
* This indirectly defines the resolve order. The higher the order, the more
* dependent is the resolver on other resolvers to be complete.
*
* @return
*/
public StyleKey[] getRequiredStyles()
{
return new StyleKey[] {
FontStyleKeys.FONT_SIZE
};
}
/**
* Resolves a single property.
*
* @param currentNode
* @param style
*/
public void resolve(final LayoutProcess process,
final LayoutElement currentNode,
final StyleKey key)
{
// as this is an 'auto' handler, we can assume that 'auto' is the
// current value
final LayoutContext layoutContext = currentNode.getLayoutContext();
final FontSpecification fs =
layoutContext.getFontSpecification();
final double threshold =
process.getOutputMetaData().getNumericFeatureValue
(OutputProcessorFeature.FONT_SMOOTH_THRESHOLD);
if (fs.getFontSize() < threshold)
{
layoutContext.setValue(FontStyleKeys.X_FONT_SMOOTH_FLAG, FontSmooth.NEVER);
}
else
{
layoutContext.setValue(FontStyleKeys.X_FONT_SMOOTH_FLAG, FontSmooth.ALWAYS);
}
}
}