联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2018-05-16 01:39


Written Exercise 1: Imagine you would like to allow rooms to have a new type of exit (e.g. "up").

Identify each class and method that you would have to change in order to allow for this type of exit.

Briefly describe the changes you would make in each class and method that you identified. NOTE:

Do not actually make these changes yet!

Several methods in the Game class contain repeated functionality. Specifically, the printWelcome

method and the goRoom methods both print a description of the current room and a list of the

exits. As we have learned, having the same functionality implemented in multiple locations can

lead to the introduction of errors when software is modified. Correct this problem by factoring the

common functionality out of these methods into a method of its own. Then call this new method

each place the description and exits are to be displayed.

Part II:

Currently the code that generates and displays the list of exits from a room is contained in the

Game class. This is not a particularly good design. Each room in the game is represented by a

Room object. The Room object contains fields that store the information about that room's exits.

Therefore it should seem like this program would be better if the code to generate a list of the exits

for a room would be contained in the Room class. Make this improvement by adding a method

named getExitString to the Room class. This method should return a String listing the exits from

the room. For example, if the room has exits to the north and west, this method should return a

String containing: "north west".

Now that each Room is capable of generating a list of its own exits. Refactor the code in the Game

class to take advantage of this functionality. I.e. anywhere the Game class generates a list of the

exits from the current room, change it to use your getExitString method.

Written Exercise 2: After making the above improvements to the code, imagine again that you

would like to allow rooms to have a new type of exit (e.g. "up"). Now identify each class and

method that you would have to change in order to add the new type of exit. Has the design

improved? Why or why not? NOTE: Do not actually make these changes at this stage!

Currently, the Game class generates the full description of the current room (including information

about exits) and displays it. This is dealing with data of the Room class, so the Room class should

be responsible for generating this description. Add a method called getLongDescription to the

Room class that returns a String containing the description and exits of a room, and refactor the

Game class to use it whenever the Game needs to print information about a Room.


Part III:

Design your own text-based adventure game, using the given zuul game as a starting point. Some

possible game scenarios are described in Exercise 6.3 of the text and you will have others from

your brainstorming activity. If you find it difficult to visualize this sort of game scenario, try modeling

your game on some familiar real-world location. If you need additional inspiration, you can try

playing the original Colossal Cave Adventure game.

Some additional specifications:

Your game scenario must include at least six different rooms.

There must be at least six types of exits for the rooms in your game. For example, you

could use north, south, east, west, up and down. This requirement does NOT mean that

each room must have 6 exits -- most or even all rooms will have fewer.

Your game scenario must include at least four items that the player could find, pick up and

potentially use.

Your game must have some way for the player to win. Most likely, this will be by achieving

some goal such as finding a particular item, surviving for some specified number of moves,

... whatever makes sense for your game.

Written Exercise 3: Write a brief description of your game, including the setting for the game, the

items in the game, and how a player wins. Save this in a Word doc to be submitted with your

assignment.

Written Exercise 4: Draw a map for your game scenario. Label the rooms and the exits

(connections between rooms), and specify the locations of the items. The map can be hand-drawn

- you do not need to use a drawing program. This map must also be placed in the Word doc.

Update the comments at the beginning of the Game class and the message displayed by the

printWelcome method so that they describe your game.

Change the createRoomsAndPlayer method in the Game class so that it creates the rooms and

exits that you invented for your game. You do not need to add any items to your game yet. You will

add items later.

Update the test methods in the GameTest class as necessary to account for your changes to the

Game class. You can directly edit the code in the test class, or delete any test methods that do not

pass and re-record them. Play the game for a bit - enjoy the fruits of your hard work!

Part IV

In many games (perhaps even in yours) there may be a very large number of different types of

exits (e.g. "up", "down", "window", "slide", "stairway", "trapdoor", "trampoline", "fire-pole" etc...) One

way to support such exits would be to make the changes that you identified in Written Exercise 2

for each imaginable type of exit. This is clearly better than it would have been before you

completed Part II, but it is still not ideal. It would be better if it were possible for an exit to have any

arbitrary name and that when given the name of an exit we could find the associated Room that

lies beyond. This should sound like a good job for a HashMap where the name of an exit is the key

and the Room lying beyond the exit is the value. Improve the design of the Room class by

refactoring it so that it uses a HashMap to store the exits instead of an individual field for each exit.

Play the game to check that it still works - take a deep breath and relax a bit!


Part VI:

You game scenario requires that there be items positioned throughout the world that the player can

pick up and possibly use. An item sounds like something that should be represented by an object!

So create an Item class to represent the items in your game. You will need to decide what fields

your Item class needs to have, what parameters the constructor will require and what methods the

class will have. At a minimum, items will have a name and a description. However, items may have

any other attributes that make sense for your game (e.g. weight, colour, value, destructive power

..)

Now that there is a class for representing Items we need a way to allow the rooms to contain an

item. Modify the Room class so that one item can be added to or removed from the room. You will

need to think about what fields and methods to add to the Room class. Also think about what the

methods that you add should do when an attempt is made to add an item to a room that already

contains an item, or an attempt is made to remove an item from a room that does not contain an

item.

Now that a room can contain an item, when the player enters a room he/she should be told about

the item in that room (if there is one). Modify the appropriate code so that if the player enters a

room containing an item, the name and description of the item are displayed along with the

description of the room and the list of exits.

Edit the code in the Game class so that the items for your game are created and added to the

appropriate rooms at the start of the game. Recall that your game must include at least four items.

Be sure to test any methods that you add or modify.

Play the game to ensure that your items are appearing in the rooms - enjoy the coolness of what

you are creating!

Part VII:

Now that rooms can contain items and a player will know when they enter a room with an item, it

would be nice if the player could pick up and carry items. Add functionality to the Player class that

will allow the player to pick up and drop items. The player should be able to carry any number (i.e.

a collection) of items.

Update your tests for the Player class to test the addition and removal of items.

Modify the Game class so that it will recognize the command take. When the user enters the "take"

command, the item in the current room, if there is one, should be added to the items that the player

is carrying and a message should be printed indicating that the player has taken the item. If there

is no item in the current room the take command should print an error message. Be sure to test

any methods that you add or modify. (Hint: Remember that one task of the Game constructor is to

"teach" the CommandReader what words are valid commands. Thus, you will need to make a

change in Game's constructor if you want to introduce a new command.)

Play the game to be sure the take command works!

Modify the Game class so that it will recognize the command inventory. When the user types

"inventory" the game prints the names of the items that the player is currently carrying. You should

think carefully about where the list of item names should be generated. (Consider the fact that the

player is carrying the items, and think about how the list of exits for a room is generated and

displayed.)

Play the game to be sure the inventory command works!

Add support to the game for a drop command so that the player can drop an item by name (e.g.

"drop book"). The dropped item should appear in the current room. If the current room already

contains an item, the drop command should print an error message indicating that the room is full

and the player should continue to carry the item.

Play the game to be sure the drop command works!


Notice that when you use the help command take, inventory and drop do not appear as command

words. Modify the printHelp method of the Game class so that it automatically displays any new

command words that are added to the game. Hint: there is a helpful method in the

CommandReader class.

Play the game to be sure the modified help command works - celebrate!

THIS IS END OF THE REQUIRED PART OF THE ASSIGNMENT. Below are bonus

enhancements:

If you completed all of the above parts, you may complete any or all of the following exercises for

extra credit. You must explicitly state which (if any) of these bonus problems you have done.

Include a description of the bonus exercises that you have completed with the written exercises.

Problems worth at most 2 extra points:

Exercise 6.41 in the text.

Exercise 6.42 in the text.

Problems worth at most 4 extra points:

Exercise 6.23 in the text.

Exercise 6.43 in the text.

Exercise 6.44 in the text.

Exercise 6.45 in the text.

Allow each room to contain a collection of items (rather than just one).

Modify the game so that only a list of the names of the items in a room are displayed when

the player enters. Then add a look command that allows the player to look at an item in the

current room by name. For example, if the player types look book and there is an item

named "book" in the current room, your game should display the description of that item. If

there is no such item, your game should display an error message. If the player enters the

look command with no second word, it should display the entire description of the room, its

exits and the names of any items again.

Problems worth at most 6 extra points:

Exercise 6.26 in the text.

Exercise 6.47 in the text.

Modify your game to allow the player to win (as you described in your game scenario).

Problems worth at most 8 extra points:

Do Exercise 6.48 in the text. Note that you must do Exercise 6.47 before doing this one.

Hints:

You can add the following method to the Room class to randomly choose an exit for the

character when it moves. Note that exits is the field (of type HashMap) that contains the

exits for the room - if you used a different field name, use that name instead.

/**

* choose a potential exit at random

*/

public String randomExit() {

Object [] dirs = exits.keySet().toArray();

int index = (int) (Math.random() * dirs.length);

return (String) dirs[index];

}


Your test cases for character movement do not need to check the location of the character

after moving (because characters may move randomly).

Variable bonus points:

if some other game modification or extension makes more sense for your game scenario, you

may make this modification or extension for extra credit with approval of your tutor. You must

also thoroughly describe this modification or extension in your written game description.


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp