联系方式

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

您当前位置:首页 >> Java编程Java编程

日期:2019-06-27 10:59

ASSIGNMENT 2: Game and Drawing Application

COURSE NUMBER: COMP 1010

COURSE TITLE: Introduction to Computer Science 1

TERM: Summer 2019

1

Assignment 2: Game and Drawing Application

DUE DATE: JUNE 23, 2019 AT 11:59PM

Preparation:

Review the following topics

Variables and final named constants

Trigonometry

Active Processing: setup() and draw()

State-driven programming

User-defined functions

Data types – int, float and boolean

Text

IF statement and relational boolean operators

Notes:

Name your sketches using your name, the assignment number, and the question number, exactly as in this

example: LastnameFirstnameA2Q1.

Your programs must run upon download to receive any marks.

Submit one pde file for each question.

Assignments must follow the programming standards document published on the course website on Moodle.

These assignments are your chance to learn the material for the exams. Code your assignments independently.

We use software to compare all submitted assignments to each other, and pursue academic dishonestly

vigorously.

Q1: A Simple Game Simulator - 10 marks

For this question, you will implement a simple

game simulator. A frame from the game is shown

on the right.

The game uses the character you created for

Assignment 1 and a food item. Your program

must create a food item (a simple red circle) at a

random location on the canvas. When the user

clicks on the food, the character must move

towards the food until it reaches the food, that is,

until the centre of the character reaches the

position of the mouse when the mouse was

clicked. When the character covers the food, the

food is considered eaten. The user receives a

score for every food item eaten. The score is

awarded based on the relative location of the food

and the character when the food item first appears

(see below).

When the food is eaten by the character, the

program must generate another food item in a random location for the character to eat. This

game play should continue until either the score reaches or exceeds a goal score or the score is

ASSIGNMENT 1: Game and Drawing Application

DEPARTMENT AND COURSE NUMBER: COMP 1010

2

less than a minimum required score to play. In either case, an appropriate message should be

printed on the canvas and the game stopped.

Your program must keep track of the score on the left in a score bar.

In each round of the game, draw a red circle to represent the food and draw your character.

Ensure that the whole food item is always drawn within the canvas (considering the score bar

and edges).

The game rules are as follows. Depending on where the new food item is located relative to the

character, the score gets a multiplier:

If the food is above and to the left of the character, multiply the score by 5

If the food is above and to the right of the character, multiply the score by 0.2

If the food is below and to the left of the character, multiply the score by 2

If the food is below and to the right of the character, multiply the score by 0.7

Use trigonometry to figure out the relative location of the food and the character. HINT:

calculate the angle between the food and the character and use it to identify the relative location.

For example, if the angle is between 0 and HALF_PI, the food is above and to the left of the

character.

The user should start the game with a certain initial score (e.g., 40) and a goal that s/he hopes to

reach (e.g., 400). The user must keep playing until either:

1) s/he reaches or exceeds the goal, or

2) s/he has a score of less than 1.

Show the score as a vertical bar against a white background on the left side of the screen. A

small bar near the bottom means the user has a low score. A bar that reaches the top of the

window means the user has reached or exceeded the goal. If the bar disappears, the user has lost.

You should also show the current score after each round as a text at the top part of the score bar.

As shown in the screenshot, the blue bar and the text indicate that the user has received a score of

200 so far in the game. You can refer to the demo video created for this question.

Notes:

You should use a canvas size of 500 by 500.

You should use 50 for the size of your character and 30 for the diameter of the food.

You should make global constants for the parameters of the game, such as the colors

used, sizes of the food and character, and so on. You should be able to quickly and easily

change the appearance of the food, the starting score, and so on.

You will also need global variables to keep track of the current score, the goal score, the

location of the character, food, and mouse when it was clicked, and so on.

Use a boolean variable to indicate whether or not the game is over. If the game is over,

the user shouldn’t be able to play and move the character.

Use float for the variables as you must use trigonometry.

You should use a constant to control the speed of the movement of the character. You

should divide the distance between the food and the character by this constant to create a

smooth movement effect.

You should erase the canvas for every round of the game and redraw the character, the

food, and the score bar.

ASSIGNMENT 1: Game and Drawing Application

DEPARTMENT AND COURSE NUMBER: COMP 1010

3

You can use the built-in function called mouseClicked() to capture the mouse

coordinates.

Q2: A Simple Paint Application - 10 marks

For this question, you will implement a simple drawing application that let users to draw and

choose some options for their drawings.

Here are the minimum requirements for the

application:

Use a canvas size of 800 by 600.

Pick at least three simple features

from a drawing application (e.g.,

color, background, shape, stroke

weight). Add the features' names in

the canvas with the text command.

Now pick at least four options for

each of these features (e.g., for color:

red, green, blue, yellow; for stroke

weight: 1, 2, 3, 4) and represent them

in the canvas (e.g., in the screenshot,

stroke colors are shown in rectangles,

thicknesses are shown with lines).

Add a large sub-canvas (i.e., rectangle) inside the main canvas. Restrict the drawing to

this subcanvas.

Add functionalities for the feature options in such a way that if the user clicks on an

option, s/he can draw lines or shapes in the sub-canvas with the selected options (e.g., if a

user clicks on a red stroke color, s/he will be able to draw with red ink).

This seems complex, but the amount of code should not be too large, and if you

implement it using many small functions, one at a time, it will be much easier. Here's a

suggested approach (you can do it differently if you prefer):

o Use a drawPalette() function to draw the palette of options. You may want to

further divide this into three smaller functions, one for each option.

o Use a checkPaletteClick() function to act appropriately if the user clicks in the

palette. Again, you might want to use three smaller functions, one for each of the

three options.

o Just as you would write the usual setup() and draw() functions, you can write a

mouseClicked() function, which contains code that you want to run when a mouse

click is detected.

o Use a drawInCanvas() function when the mouse is in the drawing area.

Assignment Notes:

Hand in two pde files, one each for Questions 1 and 2.

Make sure your files are named exactly as specified in the instructions at the beginning of

the assignment.

Follow all the programming standards.


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

python代写
微信客服:codinghelp