Skip to content

C# Linux game created using Unity for the game engine and C++ Berkeley sockets for networking

Notifications You must be signed in to change notification settings

CarsonRoscoe/DefendAman

 
 

Repository files navigation

DefendAman

DefendAman is a multiplayer, top-down, 2D, team-based MOBA action game developed for Linux using Unity. The premise of the game is simple. There are multiple teams of players and one player on each team is the "Aman". Players must work with their team to simultaneously defend their Aman while also trying to take out the opposing team's Aman. This classic game of "VIP" is modernised with class selection, character progression, resource gathering, base buildings, and chat system. DefendAman combines fast-paced action with teamwide tactics for an exciting experience.

Splash Art

##Authors:

##Introduction:

###Matchmaking: A match of DefendAman is played with two teams. When a player connects to a server hosting a DefendAman game, they can choose which side they want to play on. Teams are made up of at least two players and a game must have minimum of four players before it will begin. At the start of the match, each team can have one only one player to be the Aman. Gameplay revolves around managing both defense and offense; players have to ensure their Aman is safe before striking at the opposing team.

Grassland

###Themes: There are two unique themes players can choose to play in, Grassland and Tron. They are asset packages loaded locally on the client's workstation, meaning that all the players are able to share the same map elements while playing under different themes.

Grassland

Grassland

###Classes: Each player can take on one of three roles: Ninja, Gunner or Wizard. Each class has a distinct play style that provides a unique benefit to a team.

  • Ninja

    • Close-quarter combat specialists with high health pool and defense

      • Normal attack: Swing katana
      • Special ability-shukuchi: Teleport to the designated area, granting increased maneuverability in and out of combat.

      ninja special

  • Gunner

    • Nimble ranged attackers.

      • Normal attack: Fire out a stream of regular bullets
      • Special ability-curtain call: Fire a long ranged explosive laser attack.

      gunner special

  • Wizard

    • Wizards are the spell-based heavy hitters.

      • Normal attack: Cast fireballs that applies a DOT(damage over time) to the target.
      • Special ability-ice age: Casts a large ice AoE (Area of Effect) that weakens enemies and strengthens allies. Disables enemy abilities while they are in the affected area

      wizard special

  • Aman

    • The player chosen to be the Aman receives buff in both health and attack to make him stronger than the general normal player, allowing him to go head to head with any single player.

    • The "Aman" player will also have a special glow around its character to indicate that he/she is the "Aman"

      *[TODO:: Insert Aman player screen shot here]*

###Buildings: DefendAman also features an aspect of base building and resource management. Scattered throughout the playing field are various objects that provide an essential resource. When a player destroys one of these objects, they can collect the resource that falls out. That resource is used to build walls and provide upgrades for their team. Creating defensive fortifications is an essential way for a team to defend their Aman.

resource collection

Currently, there are five different types of buildings player can purchase using the ingame currency.

resource collection resource collection

  • Wall

    • A very generic wall that blocks enemy vision and also prevents ninja from teleporting through.

    resource collection

  • Watch Tower

    • A rotating watch tower that grants vision to ally team members, which strengthens map awareness and control

    resource collection

  • Turret

    • A simple turret that annihilates anyone who comes across its FOV (field of visoin)

      [TODO::turret screenshot here]

  • Upgrade buliding

    • Once it is placed, players can gain access to upgrading their firearms which allows more damage output.

      *[TODO:: Insert upgrade buliding screen shot here]*

      *[TODO:: Insert upgrade buliding shopt panel screen shot here]*

  • Potion buliding

    • Once it is placed, players can gain access to puchasing various types of potions which grants more survivability and manuverability.

      *[TODO:: Insert potion buliding screen shot here]*

      *[TODO:: Insert potion buliding shopt panel screen shot here]*

##How-To:

###Compile:

  • Notes:

    • Pre-existing debug and release game build, server executable, client c++ library, and map generator library can be found available under:
      • DefendAman/Builds/Debug
      • DefendAman/Builds/Release
    • Since the latest version of Unity has compatibility issues with linux builds, we would need to roll back to a slightly older version of Unity.
  • Open project:

    • Once the Unity editor is downloaded on a Windows machine, open the executable.
    • On the projects selection menu, click "Open"
    • Browse to the DefendAman project, and select the folder to open it.
  • Build game executable:

    • Make sure the project is correctly loaded in the Unity editor
    • Open build settings window through File->Build Settings on the top left corner
    • Make sure all scenes are properly loaded in the "Scenes in Build" window
      • If nothing is displayed in the window:
        • Open grass_theme, tron_theme, and MenuScene by double clicking them individually
        • On the build settings, add each scenes to the build by clicking on add current
    • Select target platform to be Linux under Build Settings window
      • Note: Might take a while for the editor to switch from Windows to Linux
    • Select the corresponding architecture to run on. (x86_64 for the lab computers)
    • Click on build to compile the executable along with the data files into a selected folder.

###Run executable on Linux:

  • Notes:

    • To run the executable on a Linux machine, the following folder and files NEEDS to be under the same directory
      • Executable file (i.e DefendAman_release.x86_64)
      • Executable data folder (i.e DefendAman_release_Data)
      • ClientLibrary.so (For C++ networking)
      • MapGenerationLibrary.so (For C++ random map generation)
  • Run game executable:

    • Give game executable file execution permission.
    • Double click on executable or run it through terminal, which will open the player selection window for configuring resolution and game quality.
    • IMPORTANT: Resolution setting needs to match the monitor, which is 16x9 for lab computers, and quality has to be simplest.
      • If an incorrect resolution and quality is selected, various issues may arise due to the compatability of Unity and Linux

About

C# Linux game created using Unity for the game engine and C++ Berkeley sockets for networking

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 76.8%
  • C++ 20.2%
  • GLSL 2.5%
  • Other 0.5%