termotes

Termotes puts Twitch emotes right in your terminal.

Termotes

Termotes is a Crystal library that draws Twitch emotes (or indeed any GIF/PNG files) right in your terminal! It does so with the Unicode block elements ▀ and ▄ in order to paint two whole pixels per character cell.

The example montage program is provided to demonstrate basic usage and results. After running shards install to grab the PNG dependency and make all to build the examples, executing ./montage < examples/pokes should produce something like the following:

Another demonstration for good measure:

Full disclosure: these images showcase idealized scenarios; while the render loop does go out of its way to gracefully respond to changes in window size (either via explicit resizing or {in,de}creasing the font size), the transition can be a little jarring in practice. Please see for a more realistic run.

Usage

The primary entry point is Termotes::Termote.new, a "virtual" initializer that returns either a StaticTermote or an AnimatedTermote. You can pass in all sorts of things:

require "termotes"
alias Tmote = Termotes::Termote

# static Twitch emote of size 2 (can be 1-3) at top-center
a = Tmote.new "KEKW", x: 0.5, y: 0.0, size: 2
# animated Twitch emote at bottom-right with FPS auto-detected by ffmpeg
b = Tmote.new "ThisIsFine", 0.9, 0.85, 3

# local PNG roughly centered horizontally and vertically
c = Tmote.new "lenna.png", x: 0.5, y: 0.5
# local GIF at the top-left going very fast
d = Tmote.new "/some/local/meme.gif", fps: 88.0

[a, b, c, d].each &.render
Termotes.render_loop

Once created, a Termote must then be added to the registry by invoking its #render method. After all desired emotes have been rendered, invoke Termotes.render_loop to start the show. This method fires off an infinite loop that continually renders animation frames in addition to listening for changes to the size of the terminal and re-rendering as necessary. Invoke it in a spawn block if you need to retain control of your program.

Note well that drawing pixels in the terminal requires much more (physical) space than most other graphics environments; while this library handles larger inputs just fine, you'll almost certainly want to be using a terminal emulator that allows you to decrease its font size on the fly.

Repository

termotes

Owner
Statistic
  • 2
  • 0
  • 0
  • 0
  • 1
  • about 4 years ago
  • December 30, 2020
License

Links
Synced at

Tue, 21 Jan 2025 11:38:37 GMT

Languages