Lanterna is a Java library allowing you to write easy semi-graphical user interfaces in a text-only environment, very similar to the C library curses but with more functionality. Lanterna is supporting xterm compatible terminals and terminal emulators such as konsole, gnome-terminal, putty, xterm and many more. One of the main benefits of lanterna is that it's not dependent on any native library but runs 100% in pure Java.
Also, when running Lanterna on computers with a graphical environment (such as Windows or Xorg), a bundled terminal emulator written in Swing will be used rather than standard output. This way, you can develop as usual from your IDE (most of them doesn't support ANSI control characters in their output window) and then deploy to your headless server without changing any code.
Lanterna is structured into three layers, each built on top of the other and you can easily choose which one fits your needs best.
-
The first is a low level terminal interface which gives you the most basic control of the terminal text area. You can move around the cursor and enable special modifiers for characters put to the screen. You will find these classes in package com.googlecode.lanterna.terminal.
-
The second level is a full screen buffer, the whole text screen in memory and allowing you to write to this before flushing the changes to the actual terminal. This makes writing to the terminal screen similar to modifying a bitmap. You will find these classes in package com.googlecode.lanterna.screen.
-
The third level is a full GUI toolkit with windows, buttons, labels and some other components. It's using a very simple window management system (basically all windows are modal) that is quick and easy to use. You will find these classes in package com.googlecode.lanterna.gui2.
Lanterna is available on Maven Central, through Sonatype OSS hosting. Here's what you want to use:
<dependency>
<groupId>com.googlecode.lanterna</groupId>
<artifactId>lanterna</artifactId>
<version>3.1.2</version>
</dependency>
There is a google group for discussions and announcements related to Lanterna. You are recommended to raise issues directly on Github though.
Incomplete list of projects using Lanterna, feel free to let us know something we can add to this list:
- https://github.com/MultiMUD/clojure-lanterna
- https://github.com/datacron/project-lanterminal
See docs for examples and guides.
JavaDoc is available here:
The JavaDocs for the previous versions (2.1 and 3.0) are also available here:
There is also a development guide and some tutorials available right here on Github.