Pilmoji is an emoji renderer for Pillow, Python's imaging library.
It supports not only unicode emojis, but also Discord emojis.
Pilmoji uses twemoji for unicode emojis.
For Discord emojis, Pilmoji will send a request to Discord's CDN.
Everything is cached, to ensure fast results.
You can also use Microsoft's emojis instead of Twemoji, if that's what you prefer.
- Asynchronous support
- Multi-line support
- Discord emoji support
- Emoji position and size adjusting
- Twemoji and Microsoft emoji support
- Caching
Pilmoji has both synchronous (requests) and asynchrounous (aiohttp) support.
Pilmoji should be installed using pip
:
pip install pilmoji
Installing from Github will most likely fail.
from pilmoji import Pilmoji
from PIL import Image, ImageFont
my_string = '''
Hello, world! 👋 Here are some emojis: 🎨 🌊 😎
I also support Discord emoji: <:rooThink:596576798351949847>
'''
with Image.new('RGB', (550, 80), (255, 255, 255)) as image:
font = ImageFont.truetype('arial.ttf', 24)
with Pilmoji(image) as pilmoji:
pilmoji.text((10, 10), my_string.strip(), (0, 0, 0), font)
image.show()
import asyncio
from pilmoji import AsyncPilmoji
from PIL import Image, ImageFont
my_string = '''
Hello, world! 👋 Here are some emojis: 🎨 🌊 😎
I also support Discord emoji: <:rooThink:596576798351949847>
'''
async def main():
with Image.new('RGB', (550, 80), (255, 255, 255)) as image:
font = ImageFont.truetype('arial.ttf', 24)
async with AsyncPilmoji(image) as pilmoji:
await pilmoji.text((10, 10), my_string.strip(), (0, 0, 0), font)
image.show()
asyncio.run(main())
Results are the exact same.
Is an emoji too low, or too small for a given font?
You can also render emojis with offsets:
pilmoji.text((10, 10), my_string.strip(), (0, 0, 0), font,
emoji_size_factor=1.15, emoji_position_offset=(0, -2))
Pilmoji also supports Microsoft emojis.
Simply set the use_microsoft_emoji
kwarg to True, as such:
with Pilmoji(image, use_microsoft_emoji=True) as pilmoji:
...
- [async] If you're running PIL in an executor, use the sync version of Pilmoji instead.
- [async] It is not recommended to run PIL in asynchronous conditions (PIL is blocking.)
- If you really have to, run the manipulation in an executor.