-
-
Notifications
You must be signed in to change notification settings - Fork 614
CustomFontAddonCreating
Mike Penz edited this page Nov 24, 2020
·
6 revisions
Please note, this guide is outdated and showcases the legacy font class output
This is the old legacy guide how you can manually create a font addon for your project. The prefered way of doing this is using this tool: android-iconics.mikepenz.com
If you plan to use an existing icon font, one provided by your design team, or if you have an svg and want to use it as drawable just follow those simple steps.
Open Fontello or IcoMoon and select the icons you need. Add your vectors (.svg) and then just download the font.
- Unpack the .zip you just downloaded and add the *.ttf to your project under
src/main/assets/fonts
- In the next step you will have to know the unicode value for the icons
- this information can be found in the
fontello-codes.css
(if you used fontello) - or in the style.css (if you used icomoon)
- Great you got your IconFont and you know which unicode character displays which icon. Now you can create your own font with it. You have to options 2.1. or 2.2.
- To implement a GenericFont just provide the mapping before you use the Iconics. (best inside a CustomApplication)
//Create a new GenericFont by defining a 3 char long fontId and by defining the path to the font (starting inside src/main/assets)
GenericFont gf2 = new GenericFont("gmf", "fonts/materialdrawerfont.ttf");
//now register the icons which are inside the font. Just provide the unicode value and name.
//the unicode value is defined as '\e800', just add the 'u' after '\' to tell java that it's an unicode char
gf2.registerIcon("person", '\ue800');
gf2.registerIcon("up", '\ue801');
gf2.registerIcon("down", '\ue802');
//now register the created GenericFont
Iconics.registerFont(gf2);
- After defining the GenericFont you can use it like this
new IconicsDrawable(this).icon("gmf-person").sizeDp(24);
- A more complex but easier to use / more safe implementation is to create a CustomFont.
- For a QuickStart just use the CustomFont used in the Sample app
- A CustomFont has to implement the
ITypeface
interface, and can then be easily used as any of the provided fonts
public class CustomFont implements ITypeface {
//define the font file to use
private static final String TTF_FILE = "fontello.ttf";
private static Typeface typeface = null;
private static HashMap<String, Character> mChars;
//return a icon by it's key
@Override
public IIcon getIcon(String key) {
return Icon.valueOf(key);
}
//return all possible key unicode-character mappings
@Override
public HashMap<String, Character> getCharacters() {
if (mChars == null) {
HashMap<String, Character> aChars = new HashMap<>();
for (Icon v : Icon.values()) {
aChars.put(v.name(), v.character);
}
mChars = aChars;
}
return mChars;
}
/**
* The Mapping Prefix to identify this font (example: fon-android -> `fon` is the mappingPrefix)
* must have a length of 3
*
* @return mappingPrefix (length = 3)
*/
@Override
public String getMappingPrefix() {
return "fon";
}
//return all possible icon names
@Override
public Collection<String> getIcons() {
Collection<String> icons = new LinkedList<>();
for (Icon value : Icon.values()) {
icons.add(value.name());
}
return icons;
}
//implement all additional methods from the interface
//...
//return the font from the assets (you can take this method in most cases)
@Override
public Typeface getTypeface(Context context) {
if (typeface == null) {
try {
typeface = Typeface.createFromAsset(context.getAssets(), "fonts/" + TTF_FILE);
} catch (Exception e) {
return null;
}
}
return typeface;
}
//implement the enum containing all possible icons. each icon name is like `fontId`_`iconNamE` --> `fon_test1` maps to the icon with the unicode char \e800
public static enum Icon implements IIcon {
//define all possible mappings here:
fon_test1('\ue800'),
fon_test2('\ue801');
//define all methods required by the IIcon interface, you can just copy and paste those
char character;
Icon(char character) {
this.character = character;
}
public String getFormattedName() {
return "{" + name() + "}";
}
public char getCharacter() {
return character;
}
public String getName() {
return name();
}
// remember the typeface so we can use it later
private static ITypeface typeface;
public ITypeface getTypeface() {
if (typeface == null) {
typeface = new CustomFont();
}
return typeface;
}
}
}