Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/statico/langterm
🕹️ WebGL-based VT220 emulator, made as a learning example and frontend for a text adventure
https://github.com/statico/langterm
bitmap-font cli console demo fun glsl if inform7 interactive-fiction lulz retro shaders story terminal text-adventure vt220 vt520 webgl webgl-game
Last synced: 2 months ago
JSON representation
🕹️ WebGL-based VT220 emulator, made as a learning example and frontend for a text adventure
- Host: GitHub
- URL: https://github.com/statico/langterm
- Owner: statico
- License: mit
- Created: 2016-10-01T02:18:29.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2023-11-16T17:20:38.000Z (about 1 year ago)
- Last Synced: 2024-05-02T06:01:49.569Z (9 months ago)
- Topics: bitmap-font, cli, console, demo, fun, glsl, if, inform7, interactive-fiction, lulz, retro, shaders, story, terminal, text-adventure, vt220, vt520, webgl, webgl-game
- Language: JavaScript
- Homepage: https://langworth.com/
- Size: 1.39 MB
- Stars: 76
- Watchers: 5
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# langterm 🕹️
```
__ _____________ __ ___
/ //_ __/ __/ _ \/ |/ / langterm by Ian Langworth, 2017
/ /__/ / / _// , _/ /|_/ / featuring "The Archive", a cheesy
/____/_/ /___/_/|_/_/ /_/ interactive fiction game```
This is a WebGL-based VT220 emulator with a simple fallback for non-JS/non-WebGL/non-desktop browsers. Made as a learning example and frontend for a cute text adventure game. It's also used as my home page on https://langworth.com/.
![CleanShot 2023-11-16 at 09 19 40](https://github.com/statico/langterm/assets/137158/aaa1e4b9-9003-4c09-9ef4-2ff29f184a74)
## How It Works
The game has two view modes: simple and fancy.
If the user is on a small screen, or fires a touch event, or we cannot initialize WebGL, we fallback to the simple mode which is just a scrollable text box and an input field. Touch devices should have the on-screen keyboard appear which makes the game playable.
On larger desktops with hardware keyboards, provide the full pseudo-CRT experience using WebGL. This works as follows:
1. A data structure, Terminal, keeps track of the logical appearance of the terminal.
1. The terminal is rendered to a 2048x2048 texture by drawing triangles filled up with bitmap font data found in `assets/apple2font.png`. That font came from [KreativeKorp's Ultimate Apple II Font](http://www.kreativekorp.com/software/fonts/apple2.shtml) and was turned into a sprite sheet with [Codehead’s Bitmap Font Generator](http://www.codehead.co.uk/cbfg/).
1. That texture is rendered to another texture as a full-screen quad (two triangles) and post-processed to add CRT-like scanline and warping effects. I got the CRT shader from [this CRT shader by Timothy Lottes](https://www.shadertoy.com/view/XsjSzR).
1. The background image was from [here](https://goo.gl/AHU79T) and is reused with permission. I photoshopped the text out and noise added to make it look blank. It's rendered to a full-screen quad, and some vignetting and noise is added for effect. I could have used `background-size: cover` in CSS and composited the vignette and noise over the web page, but I wanted to do it all in GLSL as a learning example.
1. The terminal texture is rendered to a 2D quad. I initially used a 3D quad with a persepctive matrix, but the field of view gets stretched with short/wide windows. Using 2D and writing my own aspect ratio math in the shader looks better. Also, I had to enable GL blending to properly composite this texture and its alpha channel over the background image.
1. Text input gets added to a buffer. When you hit Enter, the input buffer is sent to an interactive fiction server running a custom story made with Inform7. See [my gluluxe-httpd project](https://github.com/statico/glulxe-httpd) for the server. The story is closed source, but you can check out a limited public version [here](https://github.com/statico/the-archive-public). The whole idea is that you'll have to figure it out on your own ;)
I started with [WebGL Boilerplate](https://github.com/paulirish/webgl-boilerplate). For more involved projects and to reduce repetition, I would consider using ThreeJS.
## Build/Test
1. [Get a Glulx game](https://github.com/statico/glulxe-httpd#get-started) and run [statico/glulxe-httpd](https://github.com/statico/glulxe-httpd)
2. Serve this directory with something like `python -m SimpleHTTPServer` and go to http://localhost:8000## See Also
- ["The Archive" (Public Redacted Version)](https://github.com/statico/the-archive-public) for the game on my home page
- [Apple II font](http://www.kreativekorp.com/software/fonts/apple2.shtml) from KreativeKorp (used with permission)
- [Codehead’s Bitmap Font Generator](http://www.codehead.co.uk/cbfg/)
- [CRT styled scanline shader](https://www.shadertoy.com/view/XsjSzR) by Timothy Lottes
- [Original VT520 photo](https://goo.gl/AHU79T) by Ratko Grbic (modified by me to remove text)
- [Inform7](http://inform7.com/) was used to create the story
- [glulxe-httpd](https://github.com/statico/glulxe-httpd) runs the story
- [WebGL Boilerplate](https://github.com/paulirish/webgl-boilerplate)## License
The source code in this repository is released under the MIT License. Other assets, such as the VT520 photo, fonts and CRT GLSL shader, are subject to any license provided by the original authors.