Chronovoros: A Multiplane Graphic Novel

The Nordic Game Jam 2021 is over and–as far as I know–everyone survived. My team set out to make a “cinematic text adventure” you can play in your browser. Which wasn’t totally a thing, so we had to invent some stuff.

The theme, announced at 6:30PM Friday, was “Pending.” (Yes, you can imagine the initial confusion!) We had the story, setting and characters in rough form by mid-morning Saturday. All five characters were designed, the outline was running in Twine, my basic multiplane hack was running, and I had some of the layouts sketched out by the end of that day. (Around 1AM, for all of us.) Sunday was a sprint to get the temporary artwork replaced, layers assembled and compressed, story finished, and the bugs squashed. We got it submitted at 4:50PM Sunday–10 minutes to spare!

The story and interactive logic were written by Sejr Thompson. The character design and other hand-illustrated art were by Alexander Pechlivanidis. My own role was twofold: Designing the layouts–in an animation sense–of the independently scrolling background and foreground art layers, and hacking the Twine text engine to display them.

It’s a jam game, so there are a few rough edges, but not half as many as you’d expect. Reviews so far have been very good. Check it out:

Play Chronovoros on Itch.io

The High Arctic: A Story World Pitch

View as PDF

A story world pitch deck for Alex McDowell’s “Planet JUNK” collaboration. 500 years after the collapse of our civilization, an admixed tribe live an Inuit lifestyle in northern Greenland.

Destroying the world in 30 years is depressing, but this isn’t my first time down this philosophical road. God kings and abject despotism have held civilizations together for thousands of years–many times longer than democracy. Tribal-scale survival for hundreds of thousands of years.

The horror writer must look where they don’t want to. I feel that we understand, on some level, how fragile our current civilization is. With rare exceptions, we dress up collapse stories to make them more palatable–as Romero zombies, as alien invasions, as fantasy-science-gone-amok.

As dark as it was at times, I wanted to look at a downscaling of human life, and find some beauty and hope in our own survival.

14th Century Funeral Monument

Illustration commissioned by History Live! North East for an intriguing history project: To 3D print a life-sized sculpted knight’s tomb.

English funerary effigies like these began to be produced in the 14th Century in immitation of the Continental style, with locally-sourced alabaster in place of imported marble. According to Rachel Dressler, the waxy translucency of the stone was prized for its immitation of flesh, and “spiritual aura” in the light. History Live! North East is working with the University of Maine to create a modern reproduction of such a monument as an educational outreach tool. Sponsors (and I must recommend becoming one) can see their own coat of arms added to the base of the sarcophagus.

The Lighthouse Keeper

Among any number of negative habits is my tendancy to come up with an idea out of desperation at the last minute, play with it for a little while, and then fall in love and want to dump six months into it. Class workshops on different aspects of game design usually trigger this problem. This one is no different. (See also a simple RPG I’m trying to get working in Tabletop Simulator.)

As boring as it sounds, being a lighthouse keeper was as much about lifesaving as shipwreck prevention. A certain solitary type seems to have been attracted to the United States Treasury’s Lighthouse Establishment/Board/Service between 1791 and 1939 (which I think we can agree encompasses the “Golden Age” of lighthouses). Hoisting a dory into four-meter swells from a flooded gear room at the base of the tower in a pitch-black howling gale was a job requirement, and having a sturdy dog with sharp senses and no fear of the water along wasn’t all about companionship. (“Saved,” from the Louis Prang Collection commemorates a real lighthouse dog’s rescue of a child.) Denis Noble’s Lighthouses & Keepers is a good intro to this world.

I’m attracted to the character of an Indian man serving as a keeper sometime around the turn of the last century–someone like WWI US Army Sergeant Bhagat Singh Thind, who under the racial ideas of the time tried and failed to gain US citizenship when the Supreme Court ruled that, while “Aryan” he was not “white.”

I envision an adventure game made up of episodes (equipment failures, hurricanes, shipwrecks) with free exploration segments before the crisis portion triggers, in which you wander the lighthouse with your dog, read water-damaged books (real ones) about “race science” and other odd but consequential ideas for your character’s situation, and maintain the equipment. The offshore lighthouse serves as a metaphor for your own situation, literally defending a shore you can never reach. In these quiet moments, most of your default push/pull interactions are small acts of cleaning and maintenance (and scritching your dog). I want to make you complicit in the feeling that you’re constantly–even lovingly–maintaining this life-preserving tower.

In truth, an offshore lighthouse was manned by a crew of 3-4. Many keepers were married, and raised families at the facilities. The “solitary” aspect would be a departure from strict historicism–though sickness, injury or just plain poor manpower planning could easily leave a single hand to run a light. It was a quiet and hardworking life, though vastly superior to the sailing trade most keepers left.

I’ll leave you with this cutaway of Britain’s Eddystone Lighthouse, and an 1892 magazine article describing a visit there. It’s a fun topic to get lost in for a few hours. But for now, I think it’s best I leave it at that.

Tiny Convoy: Scaling Back

It was always an ambitious project, and not everything made it over the finish line.

What Got Cut

Glowing=on made it into the game, but no useful HUD feedback

UI Feedback: There’s a lot happening behind the scenes that the game doesn’t explain well. Every “CPU” (the brains of the robot, but also a physical robot part in the game) has randomized stats: Processing, Memory, Inputs and Outputs. These special stats aren’t altered by Upgrades, but they can be boosted by being close to (“meshing with”) nearby robots with higher stats. Processing governs how often an AI-controlled bot can reevaluate its choices. Memory is how much you can’t see but can “remember”–the fog of war. Inputs allow you a certain number of sensors you can equip. Outputs allow a set number of moving parts you can control. Likewise, damage isn’t well described, although your damaged parts do noticeably work less well.

Multiple “Car” Robots: Everything the bots do is designed around being able to take up more than one tile, dragging parts behind like train cars. Sadly, none of this made it into the final game, making even the word “convoy” seem slightly out of place. Bots sitting on top of other bots, and being carried along is–as best I can tell–entirely possible even in the demo build, but without trailers there’s not much point to it. So, no, we don’t get to play Tiny Convoy: Fury Road.

The Conversation Grid: The idea was to coordinate with your convoy without using words. You’d click on a friend and their internal map (from the Pathfinder) would come up as a grid of little icons. You could click on things to give them “ideas,” or to dissuade them from doing something dumb. It would have fed into their AI, not as a command, but as one of the AI’s competing ideas, with a boosted weight–sort of like the forgotten but brilliant “Galapagos.”

That Said…

Tutorial subs came very late in the design process, when it was clear playtesters couldn’t understand much of what they could do in the game–breaking design pillar #1

There is the start of a fun little game here. The many interacting systems largely work as intended, and cross-talk in interesting ways. The whole visual and audio presentation is inviting and detailed. With more content, fine-tuning and iterative playtesting, this could easily become a very good game.

But, on to second semester!

Tiny Convoy: Systems Programming

Since I was mostly the programmer, I’d like to look at some of the systems that make the game engine work. But first…

Inheritance?

For me, what made this game possible was an email exchange with Michael Schmidt at Unity, in which he cleared up something critical. Since Unity regards every script as a different C# type, how can you subclass a script into different variations? More specifically, how can one script interact with another when it doesn’t know if it’s the class, one of the subclasses, or one of the subclass’s subclasses?

Crunchy McCrunch-Crunch

The key is that Unity will treat a subclass script as if it were any class up its chain of inheritance. When I subclass ActualThing into Upgrade, and Upgrade into Sensor, other scripts can reference a Sensor script as if it were an Upgrade script or an ActualThing script. So these lines are equivalent:

float currentMass = someGameObject.GetComponent<ActualThing>().mass;
float currentMass = someGameObject.GetComponent<Upgrade>().mass;
float currentMass = someGameObject.GetComponent<Sensor>().mass;

A Sensor script can then override, for instance, ActualThing’s takeDamage() function, and respond to it differently than, say, a rock would:

//in ActualThing:
public virtual void takeDamage(float damageAmount){
     //reduce hp
//in Sensor:
public override void takeDamage(float damageAmount){
     //reduce hp
     //reduce sight distance

This is how basic object inheritence patterns can be implemented in Unity.

Systems

The Grid: The first programming challenge was an infinite, non-repeating grid. Based on my previous thinking on large pseudorandom world generation, I worked out a system that places BigTiles (containing a 10×10 grid of normal game Tiles and other content on top of them) from a list of available BigTiles. A given x and y will always generate the same BigTile, allowing the game to dispose of BigTiles it no longer needs, but generate them again if needed. Each game picks a random x and y offset to the starting position–a pair of C# ints of value -2 billion to 2 billion. The x and y offsets are summed and used as another pseudorandom seed to further shuffle things around atop the BigTile. The list of available BigTiles changes based on the distance from the game’s starting point, allowing the game to gate more powerful and challenging content. Specific BigTiles can also be forced to appear, like the starting location.

Lots of stuff, not-quite-randomly generated

Pathfinding: The bots use an A* pathfinding system. Niek worked out the initial code, and I adapted it to allow planning without executing the route (for AI reasoning) and to talk to the existing grid-based systems. This required a deep dive into Amit Patel’s A* Pages, a deep summation of pathfinding systems, which I highly recommend.

AI: The bots not being driven by the player have competing desires, to which they assign weights based on need and availability of a solution. The highest weight wins. They may reevaluate their options several times on the way to their goal, but the current “plan” has a sunk-cost-fallacy bonus attached, to reduce indecisiveness. The AI can query the Pathfinder (a separate script) for the “cost” of a path; it will also store the steps needed for pathfinding, to avoid a processing-heavy path recalculation for the action it ultimately decides to take.

I grew up calling them that; turns out they’re “Touch-Me-Nots”

Mystery Boxes: Remember how every BigTile has its own pseudorandom seed number? MysteryBoxes are a system that uses these to “randomly” shuffle things around on BigTiles when they’re generated–plants, upgrades, whatever you’d like. The plant growing on top of a toppled monument? That’s not scripted. One limitation is that if something on a BigTile gets destroyed, it’ll reappear if the player ever goes far enough away and comes back. A special subclass, the CPUBox, will generate a new CPU (the base of a new bot) if your party is smaller than the allowed size, or a random Upgrade if not. Like other gated content, the maximum number of party members increases with distance from your starting point.

Class flowchart. Always out of date.

Tiny Convoy: Plan

“Tiny Convoy” is as a demo-length convoy simulator–a moving base builder–developed in Unity 2019 by Niek Meffert, Lucas Oliveira and myself. Playable betas for Mac and Windows can be downloaded here. The goal is to survive as a group of tiny robots in a big dangerous world: find power, upgrade your bots, and avoid dangers.

Remember the annoying escort missions in “Warcraft III,” where your soldiers kept hauling off to attack anything that moved, instead of protecting the things they were supposed to? It’s like that. Except your bots can’t attack anything. You are essentially robot herbivores. Looked at another way, “Tiny Convoy” is a herd simulator.

One-pager

As a small team in our first year Masters, the work was loosly siloed. Oliveira took the lead on modelling and texturing, Meffert was point on UI and the first version of the A* pathfinder, and the C# code base is about 90% mine. (I also designed the Touch-Me-Not exploding plant.)

1. Emergent visual storytelling–no dialogue, no scripted beats
2. Keep moving & exploring
3. No weapons
4. Cooperation is essential to survive & thrive

Design Pilars

Our goal was to marry emergence and progression in an interesting and satisfying way. We wanted to build a game in which the player could create in their own mind an emergent storyline around an algorithmically-generated world. If the content one encountered became too boring and undifferentiated, there would be no sense of progression, and little incentive to keep exploring. On the other hand, if too many things were deliberately laid in the player’s path at defined points, it would take on the feeling of an “on rails” story game, to the detriment of replayability.

Concept sketch

Every “Civilization” player remembers when the Mongols took their capital, and they rallied back to win. What happened was only the randomized game content interacting with the rules and the player’s choices, but it took on the quality of a narrative moment because it was different and valued by the player. Likewise, we wished to create moments like “When Little Blue got stepped on,” and  “When we found the field of Touch-Me-Nots on the other side of the desert”—moments created entirely by the game systems interacting with the player’s choices, but which would feel personally meaningful.

The game loop for Upgrade Mode

 To do this, we needed to construct a series of game loops, with systems of player feedback. We would gradually challenge the player by introducing limits on stock (not enough power available) and new sinks (dangers that damage parts). The game engine would introduce new content and changes to the starting conditions in a measured manner as the player moved farther and farther across the game world.

“Per Aspera Ad Astra” In One Image

The complete silhouette illustration by the German Symbolist master Karl Wilhelm Diefenbach, assembled as one ultra-wide image. “Per Aspera Ad Astra” (“Through Hardship to the Stars”) is a complex, striking and joyful work defying easy explanation. Diefenbach himself was an untethered, original thinker–Theosophist, Symbolist, Naturist, Himself-ist–perhaps best summed up in the paradox that virtue pushed past reason becomes vice. The silhouette procession of children, animals and much more was originally a 68 meter long frieze, designed in 1875 and executed by Diefenbach’s protegé Hugo Höppener (“Fidus”) while Diefenbach was in a sanitarium. It was adapted into a book of 34 illustrations by 1893, scans of which can be found on the Commons along with more of Diefenbach’s work.

The images for download here are from these scans, matched and straightened nondestructively with hand cleanup, into a 2.9GB greyscale 172,058 x 2,473 px Large Document Format file.

The scrolling YouTube video (above) is probably the easiest viewing method right now. Be sure to set the quality to full 1080p60 and go fullscreen.

The TIFF is 110MB, full sized (172058 x 2473 px) and may be compatible with more software. I’d recommend downloading the zip file, as trying to render the TIFF might crash your browser.

The PNG is full sized and only 67MB, but may be harder to decompress. Same browser warnings.

The JPEG is 6MB, scaled down to 64,000 x 920 px (the max for the file format).

First panel

Information in English is hard to find. “Per Aspera Ad Astra” sometimes seems to be confused with “Kindermusik” (“Children’s Music”) a different series sharing themes and at least one figure. Diefenbach spent many of his later years on Capri, where there is a museum dedicated to his surviving works. (Too few, sadly.) His reputation improved by the passing century, the original 68 meter frieze of “Per Aspera Ad Astra” is now on display in the town of his birth at the City Museum Hadamar.

Please note that this assembled version should not be considered a “transformative work” for purposes of copyright, so the image files here are in the public domain. I don’t currently have the storage and bandwidth on SpaceToast.net to host the original file, but if you’d like to work with it please contact me through the About page and we’ll figure out a way to get it to you.

October Haunts Me

An html5 auto-conversation game about the different versions of ourselves that have been, are, and will be, meeting an ex from many years prior. Graphics designed/performed with iOS Messages animojis. Created for the October 2020- game jam at KADK. (Plus fixes, cleanup, and the addition of a third character.)

Forest: Beta 7

Introducing beta 7 of Forest, with better graphics, a more dynamic game world, and many behind the scenes tweaks. This project is released under an MIT License.

Updates

Forest Gods. Nearly all aspects of the board can now be influenced by randomly-generated, free-floating roamers. Some are dramatic (like lightning gods) others practically invisible (like soil porosity gods). They’re intended to make the forest more varied, and perhaps even less lonely and more mysterious.

Improved Fire. Fire has been an aspect of the game world for several versions, but is completely rewritten in beta 7 to be much more graphical, dramatic, realistic in its effect on the forest, and unpredictable.

Better Graphics. The band of the sun now moves throughout the year more accurately, and the stars now properly blur into rings as well. Fog is a custom shader, the minimum of height fog and linear distance fog. Lighting for the ground and water now comes from an array of lights aligned with the sun ring. (Trees are still sprites, however, and don’t yet respond to lighting.) The randomly generated forest’s average temperature is used as a stand-in for latitude.

Smaller Board. Moved from a 200×200 tile grid down to 128×128. This seems to tax the CPU a little less without noticeably changing the scale of the game.

Erosion. Soil is now washed along by water. Stream system formation is still rare, but it does happen.