/** * Copyright 2010-2023 JogAmp Community. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are * permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY JogAmp Community ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JogAmp Community OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * The views and conclusions contained in the software and documentation are those of the * authors and should not be interpreted as representing official policies, either expressed * or implied, of JogAmp Community. */ package com.jogamp.graph.font; import java.io.BufferedInputStream; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.security.PrivilegedAction; import com.jogamp.common.net.Uri; import com.jogamp.common.util.IOUtil; import com.jogamp.common.util.PropertyAccess; import com.jogamp.common.util.ReflectionUtil; import com.jogamp.common.util.SecurityUtil; import com.jogamp.common.util.cache.TempJarCache; import jogamp.graph.font.FontConstructor; import jogamp.graph.font.JavaFontLoader; import jogamp.graph.font.SymbolsFontLoader; import jogamp.graph.font.UbuntuFontLoader; /** * The optional property jogamp.graph.font.ctor * allows user to specify the {@link FontConstructor} implementation. *
* Default {@link FontConstructor} is {@link jogamp.graph.font.typecast.TypecastFontConstructor}, * i.e. using our internal typecast branch. *
*/ public class FontFactory { private static final String FontConstructorPropKey = "jogamp.graph.font.ctor"; private static final String DefaultFontConstructor = "jogamp.graph.font.typecast.TypecastFontConstructor"; /** Ubuntu is the default font family, {@value} */ public static final int UBUNTU = 0; /** Symbols is the default symbol font family and contains rounded material symbol fonts, {@value} */ public static final int SYMBOLS = 10; /** Java fonts are optional, {@value} */ public static final int JAVA = 1; private static final FontConstructor fontConstr; static { /** * For example: * "jogamp.graph.font.typecast.TypecastFontFactory" (default) * "jogamp.graph.font.ttf.TTFFontImpl" */ String fontImplName = PropertyAccess.getProperty(FontConstructorPropKey, true); if(null == fontImplName) { fontImplName = DefaultFontConstructor; } fontConstr = (FontConstructor) ReflectionUtil.createInstance(fontImplName, FontFactory.class.getClassLoader()); } public static final FontSet getDefault() { return get(UBUNTU); } public static final FontSet get(final int font) { switch (font) { case JAVA: return JavaFontLoader.get(); case SYMBOLS: return SymbolsFontLoader.get(); default: return UbuntuFontLoader.get(); } } /** * Creates a Font instance. * @param file font file * @return the new Font instance * @throws IOException */ public static final Font get(final File file) throws IOException { return fontConstr.create(file); } /** * Creates a Font instance based on a determinated font stream with its given length * of the font segment. ** No explicit stream copy is performed as in {@link #get(InputStream, boolean)} * due to the known {@code streamLen}. *
* @param stream font stream * @param streamLen length of the font segment within this font stream * @param closeStream {@code true} to close the {@code stream} * @return the new Font instance * @throws IOException */ public static final Font get(final InputStream stream, final int streamLen, final boolean closeStream) throws IOException { try { return fontConstr.create(stream, streamLen); } finally { if( closeStream ) { stream.close(); } } } /** * Creates a Font instance based on an undeterminated font stream length. ** The font stream is temporarily copied into a temp file * to gather it's size and to gain random access. * The temporary file will be deleted at exit. *
* @param stream dedicated font stream * @param closeStream {@code true} to close the {@code stream} * @return the new Font instance * @throws IOException */ public static final Font get(final InputStream stream, final boolean closeStream) throws IOException { final IOException[] ioe = { null }; final int[] streamLen = { 0 }; final File tempFile[] = { null }; final InputStream bis = SecurityUtil.doPrivileged(new PrivilegedAction