package org.apache.fop.render.pdf.fonts;
import org.apache.fop.render.pdf.Font;
import org.apache.fop.layout.FontDescriptor;
import org.apache.fop.fonts.Glyphs;
import org.apache.fop.pdf.PDFStream;
import org.apache.fop.pdf.PDFT1Stream;
import java.io.InputStream;
import java.io.FileInputStream;
import java.io.BufferedInputStream;
import java.util.Hashtable;
public class extends Font implements FontDescriptor {
private final static String fontName = "";
private final static String encoding = "";
private final static int capHeight = ;
private final static int xHeight = ;
private final static int ascender = ;
private final static int descender = ;
private final static int[] fontBBox = {
,
,
,
};
private final static String embedFileName = ;
private final static String embedResourceName = ;
private static PDFT1Stream embeddedFont=null;
private final static int flags = ;
private final static int stemV = ;
private final static int italicAngle = ;
private final static int firstChar = ;
private final static int lastChar = ;
private final static int[] width;
private final static Hashtable kerning=new Hashtable();
static {
width = new int[256];
width[] = ;
Hashtable tmptable;
tmptable=new Hashtable();
tmptable.put(Glyphs.glyphToString(""), new Integer());
kerning.put(Glyphs.glyphToString(""), tmptable);
}
public final boolean hasKerningInfo() {return kerning.isEmpty();}
public final java.util.Hashtable getKerningInfo() {return kerning;}
public byte getSubType() {return org.apache.fop.pdf.PDFFont.TYPE1;}
public boolean isEmbeddable() {
return (embedFileName==null && embedResourceName==null) ? false : true;
}
public PDFStream getFontFile(int i) {
InputStream instream=null;
// Get file first
if (embedFileName!=null)
try {
instream=new FileInputStream(embedFileName);
} catch (Exception e) {
System.out.println("Failed to embed fontfile: "+embedFileName);
}
// Get resource
if (instream==null && embedResourceName!=null)
try {
instream=new BufferedInputStream(this.getClass().getResourceAsStream(embedResourceName));
} catch (Exception e) {
System.out.println("Failed to embed fontresource: "+embedResourceName);
}
if (instream==null)
return (PDFStream)null;
// Read fontdata
byte[] file = new byte[128000];
int fsize = 0;
try {
int l = instream.read(file, 0, 128000);
fsize += l;
if (l==128000) {
// More to read - needs to extend
byte[] tmpbuf;
while (l > 0) {
tmpbuf = new byte[file.length + 64000];
System.arraycopy(file, 0, tmpbuf, 0, file.length);
l=instream.read(tmpbuf, file.length, 64000);
fsize += l;
file = tmpbuf;
if (l < 64000) // whole file read. No need to loop again
l=0;
}
}
embeddedFont=new PDFT1Stream(i, fsize);
embeddedFont.addFilter("flate");
embeddedFont.addFilter("ascii-85");
embeddedFont.setData(file, fsize);
instream.close();
} catch (Exception e) {}
return (PDFStream) embeddedFont;
}
public String encoding() {
return encoding;
}
public String fontName() {
return fontName;
}
public int getAscender() {
return ascender;
}
public int getCapHeight() {
return capHeight;
}
public int getDescender() {
return descender;
}
public int getAscender(int size) {
return size * ascender;
}
public int getCapHeight(int size) {
return size * capHeight;
}
public int getDescender(int size) {
return size * descender;
}
public int getXHeight(int size) {
return size * xHeight;
}
public int getFlags() {
return flags;
}
public int[] getFontBBox() {
return fontBBox;
}
public int getItalicAngle() {
return italicAngle;
}
public int getStemV() {
return stemV;
}
public int getFirstChar() {
return firstChar;
}
public int getLastChar() {
return lastChar;
}
public int width(int i, int size) {
return size * width[i];
}
public int[] getWidths(int size) {
int[] arr = new int[getLastChar()-getFirstChar()+1];
System.arraycopy(width, getFirstChar(), arr, 0, getLastChar()-getFirstChar()+1);
for( int i = 0; i < arr.length; i++) arr[i] *= size;
return arr;
}
}