trunk contents moved to root

This commit is contained in:
Jindra Petřík
2014-05-10 20:50:57 +02:00
parent 1b851e66a8
commit 199a4d0c2b
2296 changed files with 0 additions and 0 deletions

View File

@@ -0,0 +1,86 @@
package fontastic;
/**
* Fontastic
* A font file writer to create TTF and WOFF (Webfonts).
* http://code.andreaskoller.com/libraries/fontastic
*
* Copyright (C) 2013 Andreas Koller http://andreaskoller.com
*
* 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
*
* @author Andreas Koller http://andreaskoller.com
* @modified 06/19/2013
* @version 0.4 (4)
*/
import fontastic.FPoint;
import java.util.ArrayList;
import java.util.List;
/**
* Class FContour
*
* Stores a contour (list of FPoint).
*
*/
public class FContour {
List<FPoint> points;
FContour() {
this.points = new ArrayList<>();
}
FContour(PVector[] points) {
this.points = new ArrayList<>();
for (PVector p : points) {
this.points.add(new FPoint(p));
}
}
FContour(PVector[] points, PVector[] controlpoints) {
this.points = new ArrayList<>();
for (int i=0; i<points.length; i++) {
this.points.add(new FPoint(points[i], controlpoints[i] ));
}
}
FContour(FPoint[] points) {
this.points = new ArrayList<>();
for (int i=0; i<points.length; i++) {
this.points.add(points[i]);
}
}
public List<FPoint> getPoints() {
return points;
}
public FPoint[] getPointsArray() {
FPoint[] pointsArray = points.toArray(new FPoint[points.size()]);
return pointsArray;
}
public void setPoints(PVector[] points) {
this.points = new ArrayList<>();
for (PVector p : points) {
this.points.add(new FPoint(p));
}
}
}

View File

@@ -0,0 +1,116 @@
package fontastic;
/**
* Fontastic
* A font file writer to create TTF and WOFF (Webfonts).
* http://code.andreaskoller.com/libraries/fontastic
*
* Copyright (C) 2013 Andreas Koller http://andreaskoller.com
*
* 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
*
* @author Andreas Koller http://andreaskoller.com
* @modified 06/19/2013
* @version 0.4 (4)
*/
import java.util.ArrayList;
import java.util.List;
/**
* Class FGlyph
*
* Stores a glyph with all its properties.
*
*/
public class FGlyph {
private char glyphChar;
private List<FContour> contours;
private int advanceWidth = 512;
FGlyph(char c) {
glyphChar = c;
this.contours = new ArrayList<>();
}
public void addContour() {
contours.add(new FContour());
}
public void addContour(PVector[] points) {
contours.add(new FContour(points));
}
public void addContour(FPoint[] points) {
contours.add(new FContour(points));
}
public void addContour(PVector[] points, PVector[] controlPoints) {
contours.add(new FContour(points, controlPoints));
}
public void addContour(FContour contour) {
contours.add(contour);
}
public void setAdvanceWidth(int advanceWidth) {
this.advanceWidth = advanceWidth;
}
public char getGlyphChar() {
return glyphChar;
}
public int getAdvanceWidth() {
return advanceWidth;
}
public List<FContour> getContours() {
return contours;
}
public FContour[] getContoursArray() {
FContour[] contoursArray = contours.toArray(new FContour[contours.size()]);
return contoursArray;
}
public FContour getContour(int index) {
return contours.get(index);
}
public int getContourCount() {
return contours.size();
}
public void setContour(int index, PVector[] points) {
contours.set(index, new FContour(points));
}
public void setContour(int index, FPoint[] points) {
contours.set(index, new FContour(points));
}
public void setContour(int index, FContour contour) {
contours.set(index, contour);
}
public void clearContours() {
this.contours.clear();
}
}

View File

@@ -0,0 +1,82 @@
package fontastic;
/**
* Fontastic
* A font file writer to create TTF and WOFF (Webfonts).
* http://code.andreaskoller.com/libraries/fontastic
*
* Copyright (C) 2013 Andreas Koller http://andreaskoller.com
*
* 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
*
* @author Andreas Koller http://andreaskoller.com
* @modified 06/19/2013
* @version 0.4 (4)
*/
/**
* Class FPoint extends PVector
*
* Stores a point with x and y coordinates and optional PVector controlPoint1 and controlPoint2.
*
*/
public class FPoint extends PVector {
public PVector controlPoint;
private boolean hasControlPoint;
public FPoint() {
}
public FPoint(PVector point) {
this.x = point.x;
this.y = point.y;
this.hasControlPoint = false;
}
public FPoint(float x, float y) {
this.x = x;
this.y = y;
this.hasControlPoint = false;
}
public FPoint(PVector point, PVector controlPoint) {
this.x = point.x;
this.y = point.y;
this.controlPoint = controlPoint;
this.hasControlPoint = true;
}
public void setControlPoint(PVector controlPoint1) {
this.controlPoint = controlPoint1;
this.hasControlPoint = true;
}
public void setControlPoint(float x, float y) {
this.controlPoint = new PVector(x,y);
this.hasControlPoint = true;
}
public boolean hasControlPoint1() {
return hasControlPoint;
}
}

View File

@@ -0,0 +1,518 @@
/**
* Fontastic A font file writer to create TTF
* http://code.andreaskoller.com/libraries/fontastic
*
* Copyright (C) 2013 Andreas Koller http://andreaskoller.com
*
* Uses: doubletype http://sourceforge.net/projects/doubletype/ for TTF creation
*
* 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
*
* @author Andreas Koller http://andreaskoller.com
* @modified 03/16/2014 JPEXS - removed Woff
* @version 0.4 (4)
*/
package fontastic;
import org.doubletype.ossa.*;
import org.doubletype.ossa.module.*;
import org.doubletype.ossa.adapter.*;
import java.io.*;
import java.util.ArrayList;
import java.util.Map;
import java.util.List;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* Fontastic A font file writer to create TTF and WOFF (Webfonts).
* http://code.andreaskoller.com/libraries/fontastic
*
*/
public class Fontastic {
private org.doubletype.ossa.module.TypefaceFile typeface;
private org.doubletype.ossa.Engine m_engine;
private String fontname;
private List<FGlyph> glyphs;
private int advanceWidth = 512;
private File ttffile;
private File outfile;
private File tempDir;
public final static String VERSION = "0.4";
/**
* Uppercase alphabet 26 characters *
*/
public final static char alphabet[] = {'A', 'B', 'C', 'D', 'E', 'F', 'G',
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
'U', 'V', 'W', 'X', 'Y', 'Z'};
/**
* Lowercase alphabet 26 characters *
*/
public final static char alphabetLc[] = {'a', 'b', 'c', 'd', 'e', 'f',
'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
't', 'u', 'v', 'w', 'x', 'y', 'z'};
/**
* Return the version of the library.
*
* @return String
*/
public static String version() {
return VERSION;
}
/**
* Constructor
*
* @example Fontastic f = new Fontastic(this, "MyFont");
*
* @param theParent Your processing sketch (this).
* @param fontname Font name
*
*/
public Fontastic(String fontname, File outfile) throws IOException {
this.fontname = fontname;
this.outfile = outfile;
intitialiseFont();
this.glyphs = new ArrayList<>();
}
/**
* Returns the font name.
*
* @return String
*/
public String getFontname() {
return fontname;
}
private static File createTempDirectory()
throws IOException {
File temp;
temp = File.createTempFile("temp", Long.toString(System.nanoTime()));
if (!(temp.delete())) {
throw new IOException("Could not delete temp file: " + temp.getAbsolutePath());
}
if (!(temp.mkdirs())) {
throw new IOException("Could not create temp directory: " + temp.getAbsolutePath());
}
return (temp);
}
/**
* Creates and initialises a new typeface. Font data is put into sketch
* folder data/fontname.
*/
private void intitialiseFont() throws IOException {
tempDir = createTempDirectory();
/*if (!tempDir.exists()) {
if(!tempDir.mkdirs()){
if (!tempDir.exists()) {
throw new IOException("Cannot create temp dir");
}
}
} else {
//deleteFolderContents(tempDir, false);
}*/
m_engine = Engine.getSingletonInstance();
m_engine.buildNewTypeface(fontname, tempDir);
this.setFontFamilyName(fontname);
this.setVersion("CC BY-SA 3.0 http://creativecommons.org/licenses/by-sa/3.0/"); // default
// license
String directoryName = tempDir + File.separator + "bin" + File.separator;
ttffile = new File(directoryName + fontname + ".ttf");
}
/**
* Builds the font and writes the .ttf and the .woff file as well as a HTML
* template for previewing the WOFF. If debug is set (default is true) then
* you'll see the .ttf and .woff file name in the console.
*/
public void buildFont() throws FileNotFoundException {
// Create TTF file with doubletype
m_engine.getTypeface().addRequiredGlyphs();
//m_engine.fireAction();
//m_engine.addDefaultGlyphs();
for (FGlyph glyph : glyphs) {
m_engine.checkUnicodeBlock(glyph.getGlyphChar());
GlyphFile glyphFile = m_engine.addNewGlyph(glyph.getGlyphChar());
glyphFile.setAdvanceWidth(glyph.getAdvanceWidth());
for (FContour contour : glyph.getContours()) {
EContour econtour = new EContour();
econtour.setType(EContour.k_quadratic);
for (FPoint point : contour.points) {
EContourPoint e = new EContourPoint(point.x, point.y, true);
if (point.hasControlPoint1()) {
econtour.addContourPoint(new EContourPoint(point.controlPoint.x, point.controlPoint.y, false));
/*EControlPoint cp1 = new EControlPoint(true,
point.controlPoint1.x, point.controlPoint1.y);
e.setControlPoint1(cp1);
*/
}
/*
if (point.hasControlPoint2()) {
EControlPoint cp2 = new EControlPoint(false,
point.controlPoint2.x, point.controlPoint2.y);
e.setControlPoint2(cp2);
} */
econtour.addContourPoint(e);
}
glyphFile.addContour(econtour);
}
glyphFile.saveGlyphFile();
}
m_engine.buildTrueType(false);
// End TTF creation
if(outfile.exists()){
outfile.delete();
}
ttffile.renameTo(outfile);
cleanup();
}
/**
* Deletes all the glyph files created by doubletype in your data/fontname
* folder.
*/
private void cleanup() {
File[] filesToExclude = new File[0];
deleteFolderContents(tempDir, true, filesToExclude);
}
/**
* Sets the author of the font.
*/
public void setAuthor(String author) throws FileNotFoundException {
m_engine.setAuthor(author);
}
/**
* Sets the copyright year of the font.
*/
public void setCopyrightYear(String copyrightYear) throws FileNotFoundException {
m_engine.setCopyrightYear(copyrightYear);
}
/**
* Sets the version of the font (default is "0.1").
*/
public void setVersion(String version) {
m_engine.getTypeface().getGlyph().getHead().setVersion(version);
}
/**
* Sets the font family name of the font. Also called in the constructor. If
* changed with setFontFamilyName() it won't affect folder the font is
* stored in.
*/
public void setFontFamilyName(String fontFamilyName) throws FileNotFoundException {
m_engine.setFontFamilyName(fontFamilyName);
}
/**
* Sets the sub family of the font.
*/
public void setSubFamily(String subFamily) throws FileNotFoundException {
m_engine.getTypeface().setSubFamily(subFamily);
}
/**
* Sets the license of the font (default is "CC BY-SA 3.0
* http://creativecommons.org/licenses/by-sa/3.0/")
*/
public void setTypefaceLicense(String typefaceLicense) throws FileNotFoundException {
m_engine.setTypefaceLicense(typefaceLicense);
}
/**
* Sets the baseline of the font.
*/
public void setBaseline(float baseline) throws FileNotFoundException {
m_engine.setBaseline(baseline);
}
/**
* Sets the meanline of the font.
*/
public void setMeanline(float meanline) throws FileNotFoundException {
m_engine.setMeanline(meanline);
}
/**
* Sets the advanceWidth of the font. Can be changed for every glyph
* individually. Won't affect already created glyphs.
*/
public void setAdvanceWidth(int advanceWidth) {
m_engine.setAdvanceWidth(advanceWidth);
this.advanceWidth = advanceWidth;
}
public void setTopSideBearing(float topSideBearing) throws FileNotFoundException {
try {
m_engine.getTypeface().setTopSideBearing(topSideBearing);
} catch (OutOfRangeException e) {
System.out
.println("Error while setting aopSideBearing (must be within range "
+ m_engine.getTypeface().getEm());
e.printStackTrace();
}
}
public void setBottomSideBearing(float bottomSideBearing) throws FileNotFoundException {
try {
m_engine.getTypeface().setBottomSideBearing(bottomSideBearing);
} catch (OutOfRangeException e) {
System.out
.println("Error while setting bottomSideBearing (must be within range "
+ m_engine.getTypeface().getEm());
e.printStackTrace();
}
}
public void setAscender(float ascender) throws FileNotFoundException {
try {
m_engine.getTypeface().setAscender(ascender);
} catch (OutOfRangeException e) {
System.out
.println("Error while setting ascender (must be within range 0 to "
+ m_engine.getTypeface().getEm() + ")");
e.printStackTrace();
}
}
public void setDescender(float descender) throws FileNotFoundException {
try {
m_engine.getTypeface().setDescender(descender);
} catch (OutOfRangeException e) {
System.out
.println("Error while setting descender (must be within range 0 to "
+ m_engine.getTypeface().getEm() + ")");
e.printStackTrace();
}
}
public void setXHeight(float xHeight) throws FileNotFoundException {
try {
m_engine.getTypeface().setXHeight(xHeight);
} catch (OutOfRangeException e) {
System.out
.println("Error while setting xHeight (must be within range 0 to "
+ m_engine.getTypeface().getEm()
+ " as well as lower than the ascender "
+ m_engine.getTypeface().getAscender() + ")");
e.printStackTrace();
}
}
/**
* Sets the default metrics for the typeface: setTopSideBearing(170); // 2
* px setAscender(683); // 8 px setXHeight(424); // 5 px setDescender(171);
* // 2 px setBottomSideBearing(0); // 0px
*
*/
public void setDefaultMetrics() throws FileNotFoundException {
m_engine.getTypeface().setDefaultMetrics();
}
/**
* Add a glyph
*
* @param c Character of the glyph.
*
* @return FGlyph that has been created.
*
*/
public FGlyph addGlyph(char c) {
FGlyph glyph = new FGlyph(c);
glyph.setAdvanceWidth(advanceWidth);
glyphs.add(glyph);
return glyph;
}
/**
* Add a glyph and its one contour
*
* @param c Character of the glyph.
*
* @param FContour Shape of the glyph as FContour.
*
* @return The glyph FGlyph that has been created. You can use this to store
* the glyph and add contours afterwards. Alternatively, you can call
* getGlyph(char c) to retrieve it.
*/
public FGlyph addGlyph(char c, FContour contour) {
FGlyph glyph = new FGlyph(c);
glyphs.add(glyph);
glyph.addContour(contour);
glyph.setAdvanceWidth(advanceWidth);
return glyph;
}
/**
* Add a glyph and its contours
*
* @param c Character of the glyph.
*
* @param FContour [] Shape of the glyph in an array of FContour.
*
* @return The FGlyph that has been created. You can use this to store the
* glyph and add contours afterwards. Alternatively, you can call
* getGlyph(char c) to retrieve it.
*/
public FGlyph addGlyph(char c, FContour[] contours) {
FGlyph glyph = new FGlyph(c);
glyphs.add(glyph);
for (FContour contour : contours) {
// if (debug) System.out.println(p.x + " - " + p.y);
glyph.addContour(contour);
}
glyph.setAdvanceWidth(advanceWidth);
return glyph;
}
/**
* Get glyph by character
*
* @param c The character of the glyph
*
* @return The glyph
*/
public FGlyph getGlyph(char c) {
FGlyph glyph = null;
for (int i = 0; i < glyphs.size(); i++) {
if (glyphs.get(i).getGlyphChar() == c) {
glyph = glyphs.get(i);
break;
}
}
return glyph;
}
/**
* Engine getter
*
* @return The doubletype Engine used for font creation, so that you can
* access all functions of doubletype in case you need them.
*/
public Engine getEngine() {
return m_engine;
}
/**
* Returns the TypefaceFile
*
* @return The doubletype TypefaceFile used for font creation, so that you
* can access functions of doubletype in case you need them.
*/
public TypefaceFile getTypefaceFile() {
return m_engine.getTypeface();
}
/**
* Returns the .ttf file name
*
* @return The .ttf file name, which is being created when you call build()
*/
public String getTTFfilename() {
return ttffile.toString();
}
private static void deleteFolderContents(File folder,
boolean deleteFolderItself) {
File[] files = folder.listFiles();
if (files != null) { // some JVMs return null for empty dirs
for (File f : files) {
if (f.isDirectory()) {
deleteFolderContents(f, true);
f.delete();
} else {
f.delete();
}
}
}
if (deleteFolderItself) {
folder.delete();
}
}
private static void deleteFolderContents(File folder,
boolean deleteFolderItself, File[] exceptions) {
File[] files = folder.listFiles();
if (files != null) { // some JVMs return null for empty dirs
for (File f : files) {
boolean deleteFile = true;
for (File exceptfile : exceptions) {
if (f.equals(exceptfile)) {
deleteFile = false;
}
}
if (deleteFile) {
if (f.isDirectory()) {
deleteFolderContents(f, true, exceptions);
f.delete();
} else {
f.delete();
}
}
}
}
if (deleteFolderItself) {
folder.delete();
}
}
}

View File

@@ -0,0 +1,27 @@
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package fontastic;
/**
*
* @author JPEXS
*/
public class PVector {
public double x;
public double y;
public PVector() {
}
public PVector(double x, double y) {
this.x = x;
this.y = y;
}
}