CPSC 240 - OOA&D - Fall 2023
Homework — Zork++ dungeon
Due: Saturday, Dec 9th, midnight
Clarification
This is an individual assignment, not a team
assignment. You'll be turning this in individually, not working with your
teammates on a combined solution. (Getting their formative feedback on your
work, however, is okay and even encouraged.)
Your individual dungeon should show evidence of
independent thinking and creativity. It should not be a near-replica of one or
both of your teammates' individual dungeons. Ideally, when playing them, it
shouldn't even occur to the player that the three individual dungeons written
by the teammates "go with" the same game engine (unless there are obvious
distinctive features in the game play that might tip the player off to
this.)
Zork++ dungeon
Your mission is to design a dungeon compatible with your team's text-based
game engine. It should be entertaining, challenging, and winnable. You will
submit it as a single .zork file, plus a walk-through .txt
file.
Requirements
Please adhere to the following requirements when preparing your dungeon
file.
- When the dungeon is first started, a clear description of how to win
the game should appear. If your game engine has the ability to display
introductory text beyond just the dungeon title, you can include this
information there. Otherwise, you can include it in the entry room
description.
Examples of win descriptions:
- "Welcome to Pokémon cave! There are lots
of sights to see and mazes to explore here...gotta catch all 5 Pokémon
to win!"
- "Welcome on board, Lieutenant, to the Battlestar Galactica. Your mission is to
discover which Officer currently on board is a Cylon, and to expose them by
typing 'expose [name]' while in their room. Careful -- expose the wrong
Officer and face a court martial!"
- "Welcome to Fairyland, young princess! Queen Charlotte's jeweled crown has been lost, and it's up to you to find it!"
- "Behold the Mines of Moria. Somewhere inside is a Balrog, which you must
defeat in the name of Middle Earth. Cautionary hint: this ain't likely to
happen without some magic at your disposal."
In other words, the specificity can vary, as long as the player has some idea
of what he/she is supposed to do.
- It must have at least 20 rooms. Each room description should have
at least two sentences, and no more than five sentences. (In other
words, each room description should have 2, 3, 4, or 5 sentences.) The entry
room is an exception to this rule: if you put your win criteria in the entry
room description, it can have more than five total sentences.
- It must have at least 10 items. Each item must have an "examine"
verb that prints out a one-sentence description of the item in
question.
- It must exercise every feature of your game engine. Some of your
features may not be "exercisable" — like a verbose command, for example. You
don't have to do anything to take advantage of that feature in your
.zork file. However, if your game engine supports armor slots for
combat, you'd better have some armor that fits in the armor slots somewhere in
your file. If it supports light, you'd better have some light sources and some
rooms that are normally dark. Etc.
- In addition to your myDungeonName.zork file, you must also
include a myDungeonName.txt file that includes walk-through
instructions. This file will consist of plain text (i.e., English sentences
and paragraphs) and can be edited using vim just like any other text
file can. It should explain in sufficient detail which commands to execute
in which order to win the game from your dungeon's starting state. This
file must be understandable by a child who reads at a 9th grade level.
Two whole sentences?? Wut??
Your room descriptions are the primary way that the atmosphere of your game
will be conveyed to the player. Take some time and spell out enough detail
that your players can appreciate (and remember) each room.
No more than five sentences?? Wut??
"More words" does not (remotely) equal "a better or more vivid
description." Nobody likes to read a wall of text. Your dungeon should flow
smoothly, and take into account the reader's time commitment when they enter
new rooms. Strive to express rich descriptions in fewer words. This makes for
better writing, not worse.
Making your game determinstic
Note that your dungeon will contain random components that make each play
of the dungeon different. (At the very least, your teleport event(s) will put
the adventurer in a random location each time. Also, NPCs may choose to move
to different rooms, combat may resolve differently, etc.) You will want to
make this deterministic for purposes of testing, so that your walk-through
will always "work" in the same way. To accomplish this, your team should do
the following in your game engine:
- Make sure you only instantiate one java.util.Random object
over the entire run of the program. The easiest way to do this is to make an
instance variable of type Random in your GameState class,
initialize it in the GameState constructor, and in every place where
you need to roll a random number, access that Random object and call
.nextInt() or .nextBoolean() or whatever to do so.
- Immediately after instantiating the Random object, call
".setSeed(13)" on it. (If you don't like the number 13, substitute
any other number you do like.)
After doing this, you should discover that your game runs the same way every
time you play it.
Expectations
My wife and kids and I are going to play each dungeon for about 5 minutes.
That may not sound like much, but there are 38 dungeons we have to go through,
and we have lives outside of Zork. So be aware that anything cool you want us
to see and experience should be discoverable in that amount of time. Don't make
stuff so impossible to figure out that we miss half your dungeon.
Also, please no profanity, sexual references, or hate speech of any kind.
Turning it in
To turn in this assignment, commit and push your .zork and
.txt files to the "files" directory of your project. I
will get your most recent code and those files directly from the github
repo. Then send me an email with subject line "CPSC 240 Zork++ dungeon
turn-in" whose body gives me the name of those two files. The body should also
give me your team number, and also say, "Good luck, Davies family!"
I need help!
Come to office hours, or send email with subject line "CPSC 240 Zork++
dungeon HELP!!!"