📄 pdtruetypefont.java
字号:
fd.setFontStretch( "Normal" );
break;
case OS2WindowsMetricsTable.WIDTH_CLASS_SEMI_EXPANDED:
fd.setFontStretch( "SemiExpanded" );
break;
case OS2WindowsMetricsTable.WIDTH_CLASS_EXPANDED:
fd.setFontStretch( "Expanded" );
break;
case OS2WindowsMetricsTable.WIDTH_CLASS_EXTRA_EXPANDED:
fd.setFontStretch( "ExtraExpanded" );
break;
case OS2WindowsMetricsTable.WIDTH_CLASS_ULTRA_EXPANDED:
fd.setFontStretch( "UltraExpanded" );
break;
default:
//do nothing
}
fd.setFontWeight( os2.getWeightClass() );
//todo retval.setFixedPitch
//todo retval.setNonSymbolic
//todo retval.setItalic
//todo retval.setAllCap
//todo retval.setSmallCap
//todo retval.setForceBold
HeaderTable header = ttf.getHeader();
PDRectangle rect = new PDRectangle();
rect.setLowerLeftX( header.getXMin() * 1000f/header.getUnitsPerEm() );
rect.setLowerLeftY( header.getYMin() * 1000f/header.getUnitsPerEm() );
rect.setUpperRightX( header.getXMax() * 1000f/header.getUnitsPerEm() );
rect.setUpperRightY( header.getYMax() * 1000f/header.getUnitsPerEm() );
fd.setFontBoundingBox( rect );
HorizontalHeaderTable hHeader = ttf.getHorizontalHeader();
fd.setAscent( hHeader.getAscender() * 1000f/header.getUnitsPerEm() );
fd.setDescent( hHeader.getDescender() * 1000f/header.getUnitsPerEm() );
GlyphTable glyphTable = ttf.getGlyph();
GlyphData[] glyphs = glyphTable.getGlyphs();
PostScriptTable ps = ttf.getPostScript();
fd.setFixedPitch( ps.getIsFixedPitch() > 0 );
fd.setItalicAngle( ps.getItalicAngle() );
String[] names = ps.getGlyphNames();
if( names != null )
{
for( int i=0; i<names.length; i++ )
{
//if we have a capital H then use that, otherwise use the
//tallest letter
if( names[i].equals( "H" ) )
{
fd.setCapHeight( (glyphs[i].getBoundingBox().getUpperRightY()* 1000f)/
header.getUnitsPerEm() );
}
if( names[i].equals( "x" ) )
{
fd.setXHeight( (glyphs[i].getBoundingBox().getUpperRightY()* 1000f)/header.getUnitsPerEm() );
}
}
}
//hmm there does not seem to be a clear definition for StemV,
//this is close enough and I am told it doesn't usually get used.
fd.setStemV( (fd.getFontBoundingBox().getWidth() * .13f) );
CMAPTable cmapTable = ttf.getCMAP();
CMAPEncodingEntry[] cmaps = cmapTable.getCmaps();
int[] glyphToCCode = null;
for( int i=0; i<cmaps.length; i++ )
{
if( cmaps[i].getPlatformId() == CMAPTable.PLATFORM_WINDOWS &&
cmaps[i].getPlatformEncodingId() == CMAPTable.ENCODING_UNICODE )
{
glyphToCCode = cmaps[i].getGlyphIdToCharacterCode();
}
}
int firstChar = 0;
/**
for( int i=0; i<glyphToCCode.length; i++ )
{
if( glyphToCCode[i] != 0 )
{
firstChar = Math.min( glyphToCCode[i], firstChar );
}
}*/
int maxWidths=256;
HorizontalMetricsTable hMet = ttf.getHorizontalMetrics();
int[] widthValues = hMet.getAdvanceWidth();
List widths = new ArrayList( widthValues.length );
Integer zero = new Integer( 250 );
for( int i=0; i<widthValues.length && i<maxWidths; i++ )
{
widths.add( zero );
}
for( int i=0; i<widthValues.length; i++ )
{
if(glyphToCCode[i]-firstChar < widths.size() &&
glyphToCCode[i]-firstChar >= 0 &&
widths.get( glyphToCCode[i]-firstChar) == zero )
{
widths.set( glyphToCCode[i]-firstChar,
new Integer( (int)(widthValues[i]* 1000f)/header.getUnitsPerEm() ) );
}
}
retval.setWidths( widths );
retval.setFirstChar( firstChar );
retval.setLastChar( firstChar + widths.size()-1 );
}
finally
{
if( ttf != null )
{
ttf.close();
}
}
return retval;
}
/**
* {@inheritDoc}
*/
public void drawString( String string, Graphics g, float fontSize,
float xScale, float yScale, float x, float y ) throws IOException
{
PDFontDescriptorDictionary fd = (PDFontDescriptorDictionary)getFontDescriptor();
if( awtFont == null )
{
try
{
PDStream ff2Stream = fd.getFontFile2();
String fontName = fd.getFontName();
if( ff2Stream != null )
{
awtFont = Font.createFont( Font.TRUETYPE_FONT, ff2Stream.createInputStream() );
}
else
{
//throw new IOException( "Error:TTF Stream is null");
// Embedded true type programs are optional,
// if there is no stream, we must use an external
// file.
TrueTypeFont ttf = getExternalFontFile2( fd );
if( ttf != null )
{
awtFont = Font.createFont( Font.TRUETYPE_FONT, ttf.getOriginalData() );
}
else
{
awtFont = Font.getFont( fontName, null );
}
}
}
catch( FontFormatException f )
{
throw new WrappedIOException( f );
}
}
AffineTransform at = new AffineTransform();
at.scale( xScale, yScale );
Graphics2D g2d = (Graphics2D)g;
g2d.setRenderingHint( RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON );
g2d.setFont( awtFont.deriveFont( at ).deriveFont( fontSize ) );
g2d.drawString( string, (int)x, (int)y );
}
/**
* Permit to load an external TTF Font program file
*
* Created by Pascal Allain
* Vertical7 Inc.
*
* @param fd The font descriptor currently used
*
* @return A PDStream with the Font File program, null if fd is null
*
* @throws IOException If the font is not found
*/
private TrueTypeFont getExternalFontFile2(PDFontDescriptorDictionary fd)
throws IOException
{
TrueTypeFont retval = null;
if ( fd != null )
{
String baseFont = getBaseFont();
String fontResource = externalFonts.getProperty( UNKNOWN_FONT );
if( (baseFont != null) &&
(externalFonts.containsKey(baseFont)) )
{
fontResource = externalFonts.getProperty(baseFont);
}
if( fontResource != null )
{
retval = (TrueTypeFont)loadedExternalFonts.get( baseFont );
if( retval == null )
{
TTFParser ttfParser = new TTFParser();
InputStream fontStream = ResourceLoader.loadResource( fontResource );
if( fontStream == null )
{
throw new IOException( "Error missing font resource '" + externalFonts.get(baseFont) + "'" );
}
retval = ttfParser.parseTTF( fontStream );
loadedExternalFonts.put( baseFont, retval );
}
}
}
return retval;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -