Skip to content

Latest commit

 

History

History
79 lines (66 loc) · 5.64 KB

File metadata and controls

79 lines (66 loc) · 5.64 KB

Overview

This repository contains my coursework from Tom Looman's Professional Game Development in C++ and Unreal Engine course, which he originally taught at Stanford University.

This project contains all of my assignment solutions, additional tasks, improvements and the coursework itself.

After learning all other parts of the engine for 5-7 months besides C++, I originally started this project in April of 2024 and after dedicating most of my free time to it, finishing in October of the same year.

alt text

Goal

After getting a general hang of the engine itself (blueprints, materials, Niagara, modelling, environment art, etc...),I wanted to dive deep into C++ programming inside Unreal itself.

Having been a software engineer for most of my professional career, I did not want to start with a tutorial or similar that was aimed at beginners. Luckily, Tom's course is 100% aimed at those who are already familiar with programming and teached only UE-specific concepts.

Project features

A ready-to-use gameplay framework that makes it easy for designers and other developers to add features based on the building blocks of the framework I made.

The project is a culmination of about 7 months of work, encompassing most of my free time, thus an exhaustive feature list would be... exhaustive. The list of major features completed are some of the following:

  • Third Person Character movement with Enhanced Input.
  • Multiplayer/Replication support for all available gameplay features.
  • An ActionSystem similar in implementation to Epic Games' GAS.
    • Low performance overhead.
    • Replication support with prediction and server-side authentication.
    • Utilises GameplayTags throughout.
    • Support for Actions (one-time) and Effects (over-time).
    • Blueprint Action & Effect support for easy iteration for designers.
    • Some actions include:
      • Damaging projectile ability.
      • Black hole projectile ability (gravity affects simulating objects).
      • Dash ability (projectile teleportation).
      • Reflection ability (reflects projectiles back attackers).
    • Some effects include:
      • Fire damage over time effect.
      • Stunned effect.
      • Thorns effect (reflects a percentage of damage back to the attacker).
  • An AttributeSystem holding the Health and Rage of the player and relevant information.
    • Rage is given to the player upon receiving damage.
    • Replication support with server-side authentication.
    • Values are customizable in Blueprints on a per-usage basis.
  • AI behavior and AI enemies.
    • Custom behavior tree enemy AI behavior: roaming, sensing, chasing, positioning, attacking, fleeing, hiding, healing
    • EQS queries to support the AI's various positioning-related tasks.
    • Custom BT tasks and services to support the AI's varios abilities: healing, attacking, etc.
  • A Delegate-based logic to update UI and various other systems. 14 different delegates are used instead of ticks throughout. In shipped code, no tick functions are used.
  • GameMode and other framework implementations.
    • GameMode responsibilites are separated into Components.
    • GameMode EQS queries upon gameplay start to spawn a set of pickups in random places.
    • GameMode reads enemy data, spawn chance weights and such from DataAssets and DataTables.
    • GameMode spawn enemies over time, with weighted randomized chances, based on a difficulty curve.
    • GameMode rewards players with credits upon destroying enemies.
  • Various world interactions.
    • Treasure Chests can be opened, giving credits to the player.
    • Pickups can be collected for credits, health, or even to enable new abilities.
    • Levers can be toggled to give the player key-cards that can enable the opening of closed items (such as chests, doors, etc.).
    • World interactors also respond with relevant localized state descriptions to queriers.
  • A SaveGame system encapsulated in its own GameplaySubsystem.
    • The SaveGame system saves various world-state elements.
    • Not currently replicated as that would've required EOS/Steam integration for UUIDs which was outside of the project scope.
  • AssetManager C++ implementation.
    • Loads the DataAssets and their DataTables asynchrounously.
    • Also includes async loading of other assets elsewhere in the project.
  • UMG implementations.
    • Main menu, pause menu, gameplay HUD, all with animations, states, and standardized behavior.
  • Various GameplayTags, console commands and developer settings defined in C++.
    • All GameplayTags are defined in C++.
    • Console commands include elements such as: Health/Damage multipliers, flags to prevent/enable spawning of enemies and drawing of debug elements in world.
    • Developer settings include a project-level setting to specificy save-game file names without needing to launch the game from a shipped build.

Issues, TODOs and contribution

Most of what I wanted to achieve in this project, I did. There remained some outstanding issues and 1-2 bugs however, which are all recorded under the issues tab.

If you, for some reason, would like to contribute with knowledge, or code fixes, you're absolutely welcome to take a look at that page. :)

Course review

This course was rare in a way that it's clear that it is aimed at programmers and not beginners. For me, this was a great addition. These sort of works are rare and certainly welcome.

Even though I think the materials were often rushed, requiring me to do significant refactoring to get to a level that matched my quality expectations, those that will put in the work, will definitely get a lot out of this.