/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* $Id$ */ package org.apache.fop.afp.fonts; /** * A font defined as a set of lines and curves as opposed to a bitmap font. An * outline font can be scaled to any size and otherwise transformed more easily * than a bitmap font, and with more attractive results. */ public abstract class AbstractOutlineFont extends AFPFont { /** The character set for this font */ protected CharacterSet charSet = null; /** * Constructor for an outline font. * * @param name the name of the font * @param embeddable sets whether or not this font is to be embedded * @param charSet the chracter set */ public AbstractOutlineFont(String name, boolean embeddable, CharacterSet charSet) { super(name, embeddable); this.charSet = charSet; } /** * Get the character set metrics. * * @return the character set */ public CharacterSet getCharacterSet() { return charSet; } /** * Get the character set metrics. * @param size ignored * @return the character set */ public CharacterSet getCharacterSet(int size) { return charSet; } /** * Get the first character in this font. * @return the first character in this font */ public int getFirstChar() { return charSet.getFirstChar(); } /** * Get the last character in this font. * @return the last character in this font */ public int getLastChar() { return charSet.getLastChar(); } /** * The ascender is the part of a lowercase letter that extends above the * "x-height" (the height of the letter "x"), such as "d", "t", or "h". Also * used to denote the part of the letter extending above the x-height. * * @param size the font size (in mpt) * @return the ascender for the given size */ public int getAscender(int size) { return charSet.getAscender() * size; } /** * Obtains the height of capital letters for the specified point size. * * @param size the font size (in mpt) * @return the cap height for the given size */ public int getCapHeight(int size) { return charSet.getCapHeight() * size; } /** * The descender is the part of a lowercase letter that extends below the * base line, such as "g", "j", or "p". Also used to denote the part of the * letter extending below the base line. * * @param size the font size (in mpt) * @return the descender for the given size */ public int getDescender(int size) { return charSet.getDescender() * size; } /** * The "x-height" (the height of the letter "x"). * * @param size the font size (in mpt) * @return the x height for the given size */ public int getXHeight(int size) { return charSet.getXHeight() * size; } /** * Obtain the width of the character for the specified point size. * @param character the character * @param size the font size (in mpt) * @return the width of the character for the specified point size */ public int getWidth(int character, int size) { return charSet.getWidth(toUnicodeCodepoint(character)) * size; } /** * Get the getWidth (in 1/1000ths of a point size) of all characters in this * character set. * * @param size the font size (in mpt) * @return the widths of all characters */ public int[] getWidths(int size) { int[] widths = charSet.getWidths(); for (int i = 0; i < widths.length; i++) { widths[i] = widths[i] * size; } return widths; } /** * Get the getWidth (in 1/1000ths of a point size) of all characters in this * character set. * * @return the widths of all characters */ public int[] getWidths() { return getWidths(1000); } /** {@inheritDoc} */ public boolean hasChar(char c) { return charSet.hasChar(c); } /** * Map a Unicode character to a code point in the font. * @param c character to map * @return the mapped character */ public char mapChar(char c) { return charSet.mapChar(c); } /** {@inheritDoc} */ public String getEncodingName() { return charSet.getEncoding(); } }