In this assignment you will begin to construct your implementation of Dr. Lewis's Player interface. This will be the little character that goes running around on your screen. If your game doesn't have something fitting that description then you should come to talk to me about what you need to do for this assignment. For this assignment the player needs to do two things:
The design for this assignment will include a description of the player class you will write and its methods, plus a UML diagram showing how all your classes fit together. As before, for the design step you can write a ``skeleton'' version of the new class. You should also look again at your descriptions of classes you wrote for previous homeworks and see if they need to be improved or updated. Remember that I want at least a short comment about every class and every method. Writing these comments before writing the code encourages you to ``think first, then code''. They also help human readers of your code understand how everything fits together.
Like the previous homework, this one will have you writing and editing a fair bit of code. The class for your player could easily be the largest class in your game. However, you don't have to write all of it now, just the beginnings of it. Notice that the Player interface extends the GameEntity interface, so your player class will need all the methods of both interfaces. (Remember that these methods are how the game framework interacts with your classes.) Over time you will probably also wind up writing other private and public methods for your player that help it get things done as well as allow it to interact with other parts of your game. Some of the key things you will write are the following.
The combination of update and listener methods should give you a player class that takes input from the keyboard or mouse and uses it to move around any screens that you have built. The movement should be appropriate for the blocks that are present -- for example, if you have wall blocks or other obstacles, the player should not be able to move through them. In a side-view game the player should also fall if not supported by something, and you might want to implement some way for the user to make the player jump. If you have blocks that are supposed to change when the player moves onto them, you should implement that as well in this homework.
As mentioned above, the player's position is represented as a Location (a class in the game framework). Notice that this class is immutable. The value passed to setPartialsInWhole determines whether entities move around in whole-block units or in smaller steps. A value of 1 makes things such as collision detection easier, but a larger value gives you smoother motion. The partialMove method is useful for moving entities around without having to keep track of whether you are about to run off the edge of your screen.
You will need
As before, you will probably find the project API and the Java 1.4 API (linked from the course ``Useful links'' page) useful.
You can use the Together project you set up for Homework 2, but I recommend setting up a new project for each homework assignment (so that if something goes wrong you have a previous project to fall back on). You should copy your Java source files (*.java) from the old project, but I recommend that you not copy the project files (*.tpr, *.tws, and default.*) but instead create a new project from scratch.
Once you have your project set up and your classes outlined (i.e., defined in at least the skeleton form described earlier), use the ``generate HTML documentation'' feature of Together to generate documentation, putting it in the proper directory as described in the overall ``Project Description'' document. Turn in your design as described in the ``Project Description'' document.
For this step, fill in the bodies of the methods in your player class and make any changes needed to the classes you wrote for Homework 2 (including fixing any problems). Make sure your code compiles and your player moves around and interacts with blocks in the way that's right for your game.
When you're happy with how your code works, generate a final version of your documentation and turn in the code as described in the ``Project Description'' document. For this assignment, you will be turning in all your source-code (.java) files, plus possibly a file saved from the screen editor -- basically, everything I need to recompile and run your game. You do not need to send me .class files or the files that contain your Together project (*.tpr, etc.).