Skip to content

Boss Battle Simulator for building communities. Swing frontend that displays boss fight animation, Spring REST API for handling actions.

License

Notifications You must be signed in to change notification settings

narlock/RogueBoss

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rogue Boss

Simple "Boss Battle" simulator for building communities.

Apache Maven Spring Boot 3 Java 17

Application Description

Rogue Boss is an application that implements mini "boss battles" for users to interact with a front end. A boss is chosen randomly from a list, given a type (see types). Users can attack the boss via an open-front end implementation provided by developers that utilize Rogue Boss. Rogue Boss acts as a back end application that can receive RESTful API requests to attack the boss while also storing boss data locally using a JSON format. Rogue Boss also implements a simple GUI that contains a simple animation and health bar indicating the current status of each events that are send via the API.

This application as it stands leaves choices for other developers on how they want to call the API. This application is not responsible for providing a front end interface for calling the API.

GUI Screenshots

RB1 RB2

Application Context

Context Diagram

Rogue Boss contains three different main components: the REST API, for frontend interfaces to interact with, the User Interface, for displaying events received from the REST API, and the JSON datastore, stored at /home/Documents/narlock/RogueBoss/boss.json contains the information of the current boss. This is used to persist the data when the application starts and shuts down.

API Specification

GET /rban

Pings the Rogue Boss application. This should be utilized to ensure connection to the API is stable and that the GUI displays the correct boss information. When the application is started, the application will call this endpoint to ping the graphics panel.

Response

HTTP/1.1 200 OK
Content-Type: text/plain

Success

POST /rb

Send an attack request. Request body should contain unique information with respect to the calling user. The current supported models are TRINITY and ANT.

Request

POST /rb

{
    "id": "123",
    "name": "Trinity",
    "type": "DARK",
    "model": "TRINITY",
    "weapon": 1,
    "powerUp": 1,
    "exp": 2000
}

Response

HTTP/1.1 200 OK
Content-Type: application/json

{
    "note": "Critical hit! 6 damage dealt.",
    "slain": false,
    "boss": {
        "level": 3,
        "bossType": "SLIME",
        "type": "DARK",
        "health": 1290,
        "damageList": [
            {
                "id": "123",
                "damage": 6
            }
        ],
        "name": "DARK SLIME LV3"
    }
}

The damageList attribute of the response will contain information of each user attacking the boss. The damage sub-attribute will add the new damage number indicated by the note field.

Typing

This game has a simple typing system. Certain types are super/not very effective against one another.

  • 🔥 FIRE is weak to WATER, but super effective against EARTH.
  • 💧 WATER is weak to EARTH, but super effective against FIRE.
  • 🪨 EARTH is weak to FIRE, but super effective against WATER.
  • 🔮 PSYCHIC is weak to LIGHT, but super effective against DARK.
  • 💫 LIGHT is weak to DARK, but super effective against PSYCHIC.
  • 🌑 DARK is weak to PSYCHIC, but super effective against LIGHT.

Future Improvements

  • Unit Testing
  • Add new character models
  • Add new animations (utilizing weapon attribute)

Artwork Usage

The artwork in narlock's Rogue Boss were created by narlock. Please ask for permission if you plan to use these assets for your own projects.

About

Boss Battle Simulator for building communities. Swing frontend that displays boss fight animation, Spring REST API for handling actions.

Topics

Resources

License

Stars

Watchers

Forks

Languages