Skip to content

DeeDeeG/noto-color-emoji-font

Noto Color Emoji SVGinOT Font

Major credit to eosrei (and various other contributors). This is a lightly modified version of his twemoji-color-font repo.

(Legal note: he has not commented on this project, to my knowledge, and my crediting him does not imply his endorsement. /legalese)

Intro

This is a color and B&W emoji SVGinOT font, built from the latest version of the Noto Color Emoji artwork with support for most ZWJ sequences, skin tone diversity and country flags (not all flags supported). Also comes with the recent gendered professions emoji, such as judge, airplane pilot, and cook.

This is essentially a recreation of the font from Nougat, minus most of the flags.

The font works in all operating systems, but will currently only show color emoji in Firefox, Thunderbird, Photoshop CC 2017, and Windows Edge V38.14393+. This is not a limitation of the font, but of the operating systems and applications. Regular B&W outline emoji are included for backwards/fallback compatibility.

Do you prefer EmojiOne graphics? (repo by eosrei and various contributors)

Table of Contents

Examples

Demo in Firefox on Linux. Firefox color emoji in Linux

What is SVGinOT?

SVG in Open Type is a standard by Adobe and Mozilla for color OpenType and Open Font Format fonts. It allows font creators to embed complete SVG files within a font enabling full color and even animations. There are more details in the SVGinOT proposal and the OpenType SVG table specifications.

SVGinOT Font demos (Firefox only):

Linux Details

The font can be installed for a user or system-wide. Get the latest version from releases: https://github.com/DeeDeeG/noto-color-emoji-font/releases

Note: This requires Bitstream Vera is installed and will change your systems default serif, sans-serif and monospace fonts.

Why Bitstream Vera

The default serif, sans-serif and monospace font for most Linux distributions is DejaVu. DejaVu includes a wide range of symbols which override the color emoji characters. The previous solution was to make EmojiOne Color the default system font, but that causes a number of issues. A better solution is a different font that doesn't override any emoji characters such as Bitstream Vera. Bitstream Vera is the source of the glyphs used in DejaVu, so it's not very different. 99%+ of people will not notice the difference.

Additional default font options

The Noto Sans/Noto Serif and Roboto font families conflict far less than DejaVu. You may want to try them. Primary issues are the 0x2639 and 0x263a characters.

Known issues

Install on Linux

Standard install

Open the font in a font viewer program and press install. Websites and applications that specifically call for Noto Color Emoji will use the font. Certain issues with Fontconfig may prevent the emoji from showing up by default. For a more thorough installation, use the install script described below.

Manual install on any Linux

Install for the current user without root:

# 1. Download the latest version
wget https://github.com/DeeDeeG/noto-color-emoji-font/releases/download/v1.2-nougat/NotoColorEmoji-SVGinOT-Linux-1.2.tar.gz
# 2. Uncompress the file
tar zxf NotoColorEmoji-SVGinOT-Linux-1.2.tar.gz
# 3. Run the installer
cd NotoColorEmoji-SVGinOT-Linux-1.2
./install.sh

Install on macOS

Both SVGinOT versions are available from releases: https://github.com/DeeDeeG/noto-color-emoji-font/releases

  1. NotoColorEmoji-SVGinOT-1.2.zip - The regular version of the font installs like any other font and can be specifically selected, but macOS will default to the Apple Color Emoji font for emojis.
  2. NotoColorEmoji-SVGinOT-OSX-1.2.zip - A hack to replace the Apple Color Emoji font by using the same internal name. Install and accept the warning in Font Book.

Reiterating: Only FireFox supports SVGinOT color emoji for now. Safari and Chrome will use the fallback black and white emoji.

Install on Windows

There are two install options for Windows. Both SVGinOT versions are available from releases: https://github.com/DeeDeeG/noto-color-emoji-font/releases

Standard install

The regular version of the font installs like any other font and can be specifically selected, but Windows will default to the Segoe UI Emoji font for emoji characters. Download: https://github.com/DeeDeeG/noto-color-emoji-font/releases/download/v1.2-nougat/NotoColorEmoji-SVGinOT-1.2.zip

Replace the default Windows emoji fonts

Windows 7, 8, 10 use emoji from both Segoe UI Symbol and Segoe UI Emoji. We need to replace both fonts, but keep the existing symbol characters from Segoe UI Symbol.

This package contains an install script that will generate both fonts (or in Windows 7, just Segoe UI Symbol) and install them for you. Running the install script requires both Python and pip in the PATH.

  1. Download the most recent Python 3 for Windows: https://www.python.org/downloads/windows/
  2. Start the installer, select "Add Python 3.6 to PATH" and finish the install process.
  3. Download Noto Color Emoji Windows package from releases: https://github.com/DeeDeeG/noto-color-emoji-font/releases/download/v1.2-nougat/NotoColorEmoji-SVGinOT-Win-1.2.zip
  4. Uncompress the file.
  5. Open the new NotoColorEmoji directory.
  6. Run install.cmd. Note: This will take some time.
  7. Install both new fonts when requested.
  8. Done!

Reiterating: Only FireFox and Edge support SVGinOT color emoji for now. Chrome will use the fallback black and white emoji.

Building

Overview:

  1. B&W SVGs are generated on-the-fly from the color SVGs
  2. The B&W SVGs are imported based on their filename to create either regular glyphs or ligature glyphs.
  3. The color SVGs are imported to override both types of glyphs.

Requires:

  • Inkscape
  • Imagemagick
  • potrace/mkbitmap
  • FontTools 3.0+
  • FontForge 20160405+
  • SVGO
  • make
  • SCFBuild (Created by eosrei for EmojiOne Color!)

Setup and build on Ubuntu 14.04 LTS:

sudo add-apt-repository ppa:fontforge/fontforge
sudo apt-get update
sudo apt-get install inkscape potrace npm nodejs nodejs-legacy fontforge \
python-fontforge python-pip python-yaml imagemagick git make
sudo npm install -g svgo
sudo pip install fonttools
git clone https://github.com/DeeDeeG/noto-color-emoji-font.git
cd noto-color-emoji-font
git clone https://github.com/eosrei/scfbuild.git SCFBuild
# Type a number after the "-j" in the following command to control number of threads.
# The build involves an extremely large number of short tasks (several per glyph).
# Due to starting and stoping on each thread, CPU usage can be well below 100%, for strong processors.
# If your machine is powerful, a higher number of threads per-core will be faster and use more of your CPU power.
# basic processors: 1 thread per core is best. Strong processors: at least 2 threads per core is best.
make -j 4
# If you want to build all the packages (totally optional), run:
sudo apt-get install devscripts
# Which allows you to build the DEB_PACKAGE target, and:
make package -j 4
#
# "make package" will run without devscripts installed, and it will
# make the Linux, macOS and Windows packages, but it won't build the
# .deb package.
#
# It's good to run "make package" before running a simple "make," if
# you want the packages, or else you will find your computer
# re-building the ttf font files in order to satisfy the dependencies
# of the "package" build target.

License

The TTF fonts are licensed CC-BY-4.0. The SVG artwork is licensed Apache 2.0. Please see LICENSE.md for details.

About

Color emoji SVGinOT font using Noto emoji, with multiple releases, such as Lollipop and Nougat. Linux/MacOS/Windows

Topics

Resources

License

Unknown and 3 other licenses found

Licenses found

Unknown
LICENSE.md
Apache-2.0
LICENSE-APACHE.txt
CC-BY-4.0
LICENSE-CC-BY.txt
Unknown
LICENSE-MIT.txt

Stars

Watchers

Forks

Packages

No packages published