联系方式

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

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

日期:2022-04-17 02:35

Introduction

This document specifies the requirements for the first assignment of

the Mobile Game Development course. This assignment will develop

your skills by allowing you to put into practice what has been taught to

you in class during the first 5 weeks of the course. This assignment requires you to design, implement, test, and debug a

simple game using the LibGDX framework that will run on Android

phones. The work for this assignment is to be performed individually

and will be submitted via LearnOnline. If any parts of this specification appear unclear, please contact us for

clarification. Task Description

The style of game being made is an arcade-style game in the style of

Lunar Lander. The player controls a vehicle that constantly moves to

the right with a fixed camera, as with most side-scrolling arcade

games. The player can move a short distance forward (to the middle

of the screen) and a short distance back (to the left edge of the

screen). The player can shoot one short range shot (approximately

one third of the screen width) forward. Enemies can can from above

or in front. Enemies from above are flying which move across the top

of the screen; enemies from in front move towards the player can can

be shot. If an enemy hits the player they loose a life. If a bomb

dropped from the flying enemy hits the player they also loose a life. Main Features

Main Menu: when the game is launched a menu will appear with two

buttons - one marked "PLAY" to play the game, another marked

"EXIT" to return to the OS. The main menu’s background can be

coloured in or left black. This screen may have a name for the game

displayed as well. Game Screen: For the purposes of this assignment a game screen of

800 by 480 pixels is assumed. You will be given a series of

spritesheets for the protagonist and spritesheets for the enemies, with some bonus explosions, projectiles, bombs and backgrounds. Gameplay

Gameplay is relatively straightforward. The player is located on the

left side of the screen close to the bottom (note that this should be in

landscape). On starting the game, the player immediately starts

moving to the right, with the camera following the player such that

the player does not change position while the background scrolls past. While playing the player can move a shot distance forward or back by

increasing or decreasing their speed, but cannot go off the screen or

pass the middle of the screen. Periodically a flying or ground-based threat will appear. Ground-based threats appear from the right and move towards the

player; flying enemies appear at the top of the screen from either the

left or the right and move towards the other side where they go off

screen. The player shoots forward and can only hit the ground

enemy. Forward shots travel at most a third of the screen width. Shots can hit and kill ground-based threats. The player dies if hit by a

ground-based enemy or a bomb. When handling collisions, I'd rather you avoided using Box2D and

instead relied on the simpler overlap feature of a rectangle or

bounding box. Box2D is great, but we'll be covering it later in the

course. A demonstration video will be provided to show how the basic

gameplay should function. Fail State

If the player hits an enemy or bomb the player will die using a

provided animation and the player will stop. A button should appear

labelled "RESTART” which will reset the game again from the start

with the player at the far left side of the map. Assets

You will be provided with all of the assets required to make the main

features of the game. You must also ensure any new assets used are

either made by yourself or licensed under a permissive license for use

in an academic project. Use of public domain resources is

recommended. Also, just to keep things professional, make sure any

assets you add to the game are safe for work. Additional Features

For the last few features you have a choice of which features you

would like to add to complete the game:

 A pause feature

 Sounds

 Looping background music

 Unique graphical style

 Second level (or more)

 Jump action and associated threats (holes in the ground; rocks)

 Variations in enemy movements and types

Each addition is worth a number of marks (see Marking Criteria for

details) and their combined total is more than the maximum number

of marks available for this part. The listed marks indicate a

high-standard of completion, where there is no visual clash with other

elements on-screen and manipulating any new controls does not

come at the cost of inconvenient movements on the player’s part. These new features may require some additional research by you to

implement as the course will not have covered all of these possibilities

yet. Basically this is a chance for you to show off and go above and

beyond what is expected of you. New features added are still subject to the requirement for your game

to run quickly and smoothly and so make sure you do not use an

excessive amount of memory or write poorly optimized code, either of

which could cause your game to hang or stutter. Descriptions of each

additional system are available below:

Sounds

Adding sound will give the game much more atmosphere. Ensure you

have a complete suite of effects including jumping, the player being

hit, as well as win/lose conditions. Remember to only use sounds you

have the rights to use, freesound.org is a good start, as is BFXR. Music

Adding a nice soundtrack can also improve the play experience. If you

do this make sure the song loops continuously. Finding appropriate

royalty free music can take some digging around, many people swear

by incompetech for their music needs. Unique Graphical Style

Instead of using the provided assets, you may choose to replace or

modify some or all of the assets to make them more striking and

unique. If you want to get the full marks for this feature, you must

ensure all of the assets added look like they’re part of a consistent art

style and they must all appear consistently scaled. Additional gameplay

This option is a little more vague than the others and will require some

additional creativity on your part. Essentially you add some sort of

progression to the game with additional mechanics. Code Quality

Docmentation

Use Javadoc-style documentation on methods and constructors. Documentation can be omitted for simple methods if their

functionality is obvious and they have no side-effects. Code

comments can be used sparingly, aim to comment blocks of code

rather than individual statements unless the outcomes of the

statements are not obvious. Code Style

You must write your code in a consistent style. Keep your style close

to Java guidelines and if you choose to deviate from it, please do so

consistently. Note that you are not specifically required to follow

Object-Oriented design, you merely need to make sure your code is

legible - however, you will find that a good object-based structure will

pay off. Version Control

You must use a git repository to track your implementation progress

and to keep a record of your work. You may choose to exclude the

majority of the project from being tracked to keep your file version

history compact and make it easier to switch between computers, but

you must at least include the source directory of the core module. If

you make any changes to the source in the android or desktop

modules then be sure they are included in version control as well. Submission Details

You must submit your complete Android Studio project folder in a

single zip archive file. The zip archive must include all source files and

asset files required to compile and run your project in both android

and desktop modes. The submitted archive must also include your

version control directory (there should be a .git/folder inside the

project), and a document outlining what features you have

implemented. Once you have created the zip file according to the specifications, you

are required to upload it to the Individual Assignment Submission link

via the course website on LearnOnline. The deadline for the

submission is on 11 April 2021, 11:59 PM. Marking Criteria

Criteria Mark

Main Features 45

Main menu with Play and Exit buttons 5

Control of player 10

Collision response 10

Animations 10

Fail and success states, including retry button 10

Stability 15

Android module stability without stuttering, errors or crashes 10

Code Quality 15

Documentation and commenting 5

Consistent and readable code style 5

Correct use of version control 5

Additional Features 30

Ability to pause the game 5

Sounds 5

Looping background music 5

Unique graphical style 5

Second level (or more) 10

Additional behaviours 10

Total possible marks 100


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

python代写
微信客服:codinghelp