ADVENTURE 2-D RETRO GAME
21CSC206P – ADVANCE OBJECT ORIENTED
               PROGRAMMING
                  Abstract Report
                      Submitted by
      Devjeet Saha [Reg. No.: RA2311027010048]
                 B.Tech. CSE – BDA
     Harsh Thakur [Reg. No.: RA2311027010065]
               B.Tech. CSE - BDA
           SCHOOL OF COMPUTING
 COLLEGE OF ENGINEERING AND TECHNOLOGY
 SRM INSTITUTE OF SCIENCE AND TECHNOLOGY
             (Under Section 3 of UGC Act, 1956)
    S.R.M. NAGAR, KATTANKULATHUR – 603 203
            CHENGALPATTU DISTRICT
               SEPTEMBER 2024
Problem Statement:
In the fast-paced, visually intense gaming landscape of today, many players—especially from newer
generations—have forgotten the charm and simplicity of retro games that once defined childhood for
millions. These 2D adventure games, with their nostalgic pixel art, engaging yet straightforward gameplay,
and unique sense of challenge, are largely overshadowed by modern, hyper-realistic titles. As a result, an
entire era of gaming history is fading from memory, depriving players of the joy and creativity these
classics once inspired.
The challenge is to reintroduce and reimagine retro-style 2D adventure games for today’s audience, while
preserving their nostalgic essence. We aim to create a game that captures the magic of these older titles,
making them appealing not only to those who grew up playing them, but also to new players who have
never experienced the joys of retro gaming. By blending classic game mechanics with subtle modern
updates, we can help players relive their childhood memories while also introducing the next generation to
a timeless gaming experience.
Key Features:
•   Pixel Art Aesthetics:
    Classic, hand-drawn pixel art that evokes nostalgia, blending vibrant environments with detailed
    character sprites, reminiscent of iconic games from the 80s and 90s.
•   Simple Yet Engaging Controls:
    Intuitive controls, easy to pick up but offering depth for mastery, making it accessible to both
    casual players and retro gaming enthusiasts.
•   Challenging Platforming and Exploration:
    Richly designed levels with a combination of platforming, puzzle-solving, and hidden secrets,
    encouraging exploration and rewarding curiosity.
•   Nostalgic Soundtrack:
    A chiptune soundtrack that brings back the feel of retro consoles, enhancing the atmosphere with
    catchy, nostalgic tunes and sound effects.
•   Classic Adventure Storyline:
    A simple, yet captivating story filled with heroism, quests, and a variety of colorful characters that
    harken back to the epic adventures of yesteryear.
•   Modern Enhancements:
    Subtle modern features like autosaving, smoother animations, and optional difficulty settings to
    appeal to both retro fans and newcomers.
•   Boss Fights with Classic Mechanics:
    Epic boss encounters, requiring players to memorize patterns and use timing-based strategies to
    overcome tough yet fair challenges.
•   Retro-Inspired Collectibles:
    In-game collectibles such as coins, gems, or power-ups, rewarding exploration and mastery of the
    levels while evoking memories of classic gameplay.
Constraints:
•   Graphical Limitations:
•   Pixel Art Challenges: While pixel art is iconic, it requires significant effort to create
    detailed, visually appealing designs that still feel true to the retro aesthetic. Balancing
    high-quality visuals with simplicity can be difficult.
•   Resolution Restrictions: To maintain the retro feel, the game may need to be limited to
    specific resolutions or scaling options, which could reduce visual clarity on modern
    displays.
•   2. Appealing to Modern Audiences:
•   Balancing Nostalgia with Innovation: Striking the right balance between classic
    mechanics and modern expectations could be a challenge. Players may expect modern
    conveniences (e.g., smooth frame rates, advanced animations, or forgiving difficulty) that
    can clash with the retro style.
•   Limited Appeal: Some players might view the pixel art and retro mechanics as outdated
    or simplistic, potentially narrowing the target audience.
•   3. Performance on Modern Platforms:
•   Platform Compatibility: Ensuring smooth performance across multiple platforms (PC,
    consoles, mobile devices) while preserving the retro feel could present technical
    challenges, especially if using modern game engines that prioritize 3D or high-fidelity
    graphics.
•   Input Lag: Retro games rely heavily on precise controls, so even small amounts of input
    lag on
Key Components:
•   User Interface (UI):
       o Main Menu:
       o Displays the game title, options to start a new game, load a saved game, view settings, and exit.
       o Level Select Screen:
       o Allows players to choose which level to play or replay, displaying unlocked levels and progress.
       o Gameplay HUD (Heads-Up Display):
       o Shows the player’s health, score, collectibles, and other important gameplay information (e.g.,
           power-ups).
       o Inventory Menu:
       o Displays the player’s collected items, gear, and power-ups. Players can use, equip, or discard
           items here.
       o Pause Menu:
       o Options to resume the game, adjust settings, or quit to the main menu.
       o Settings Menu:
       o Adjust game settings like audio, difficulty, and visual preferences.
       o Character/Stats Screen:
       o Displays the player's character stats, including health, abilities, and progress
       o In-Game Dialogues & Cutscenes
       o Shows text and animations for storyline progression and NPC (non-player character)
           interactions.
•   Game Data Model:
       o Player:
       o Represents the player's details, such as health, abilities, inventory, and progress in the game.
       o Enemy:
       o Represents various enemies the player encounters, including attributes like health, attack power,
           and behavior patterns.
       o NPC (Non-Player Characters):
       o Characters that the player can interact with for quests, information, or purchases (e.g.,
           shopkeepers, quest givers).
       o Item:
       o Represents collectible items in the game, such as weapons, power-ups, and health potions.
       o Quest:
       o Represents tasks or missions given to the player by NPCs, including rewards and conditions for
           completion.
       o Level:
       o Defines the structure of a level, including enemies, obstacles, and environmental elements.
       o Environment Object:
       o Represents interactable objects in the game world, such as doors, switches, and hidden paths.
       o Achievement:
       o Tracks in-game milestones or achievements unlocked by the player (e.g., defeating a boss,
           collecting items).
       o Save Game:
       o Represents the saved progress of the player, including level, inventory, and quests.
Development Progress:
 ▪ GamePanel:
   The GamePanel is the central class where the game runs at a constant frame rate of 60 frames per
   second (FPS). It manages both the game's logic and the drawing of graphical components. It
   controls the screen resolution, tile sizes, and manages entities like the player. The main game loop
   uses a delta-based approach to ensure smooth animation and consistent gameplay across different
   systems.
 ▪ Tile System:
   A custom tile system is implemented to design and render the game world. Each tile is 48x48 pixels,
   scaling up from the original 16x16 design. The game map is stored as a text file and loaded
   dynamically into a 2D array, where each number in the file corresponds to a particular tile. The
   TileManager class is responsible for managing, drawing, and loading tile images (e.g., grass, water,
   walls), which are stored in the resources folder.
 ▪ Player Entity and Sprite Animation:
   The player is represented as a movable entity, controlled via keyboard inputs (KeyHandler). The
   player's movement is based on WASD keys, allowing for directional control. The game features
   sprite animations for the player's movement in different directions (up, down, left, right). A sprite
   sheet is used to render the player, with a series of frames (sprites) that cycle during movement to
   simulate walking.
 ▪ KeyHandler Input System:
   The KeyHandler class detects keyboard events, allowing the player to move the character in four
   directions. The game responds instantly to key presses and releases, ensuring smooth and responsive
   controls. Movement speed and direction are dynamically updated based on the player's input.
 ▪ Graphics Rendering:
   The game uses Java's Graphics2D library to render both the tiles and player sprites onto the screen.
   The paintComponent method in GamePanel is overridden to draw the tiles first, followed by the
   player sprite on top. This ensures a layered rendering system where the player can move around
   within the environment. Each tile and player sprite is drawn according to the current game state,
   which is updated at regular intervals.
    ▪ Game Loop and Real-Time Updates:
      The game employs a real-time update loop using a separate thread to ensure smooth gameplay and
      responsive rendering. The game loop is implemented using a Runnable interface, with a calculated
      draw interval to maintain a steady 60 FPS. The loop ensures that the game logic (such as player
      movement and animation frame updates) and rendering (drawing the map and the player) happen
      seamlessly.
    ▪ Map Design and Loading:
      The game world is defined by a map stored in a text file. The map is a grid of numbers, where each
      number represents a different type of tile (e.g., grass, water, walls). This allows for flexibility in map
      design and easy modifications. The TileManager loads the map at runtime and draws it on the screen,
      ensuring that the game world appears correctly and efficiently.
    ▪ Future Expansion:
      The game engine is designed with future enhancements in mind. New features like enemy entities,
      item pickups, and additional maps can be easily added. The modular design of the TileManager,
      Entity, and KeyHandler systems allows for scalability, making it possible to integrate additional
      game mechanics, such as combat systems, inventory management, and quest lines.
Technology Stack:
•   Here’s a technology stack for your Java-based 2D adventure game, broken down into frontend,
    backend, and database components:
•   Frontend: The user interface where players interact with the game.
       o JavaFX:
       o A framework for building the graphical user interface with rich 2D graphics and animations.
         Ideal for creating game windows, menus, and interactive elements.
•   Backend: The logic layer that processes game mechanics and manages data.
•   -Java Classes for Game Logic:
        o Custom Java classes to handle game mechanics, such as player movement, collision detection,
           enemy behavior, and level progression.
•   Database: Stores game data and progress.
       o File-Based Storage:
       o Simple file-based storage (e.g., JSON or XML files) for saving game state, player progress, and
         high scores. Suitable for single-player games where complex data structures are not required.
       o Embedded Database:
       o Optionally use an embedded database like SQLite for more structured data storage, such as
         player profiles, achievements, and in-game statistics, if needed.
•   Development Tools:
•   -IDE:
       o IntelliJ IDEA or Eclipse for Java development, providing features like debugging, code
          analysis, and integration with version control systems.
        o Version Control:
        o Git for source code management, allowing collaborative development and tracking changes.
•   Other Considerations:
        o Asset Management
        o Tools for managing game assets like images, sound effects, and music, such as TexturePacker
          for optimizing sprites or Tiled for creating tilemaps.
        o Build Tools*
        o Maven or Gradle for managing dependencies and automating the build process.
•   This technology stack will support the development of a 2D adventure game in Java, providing the
    necessary tools for creating a compelling user experience while managing game logic and data
    efficiently.
Reference material:
    •   https://youtu.be/Kmgo00avvEw?si=M-bBtINFqIhWqgFB
    •   https://www.youtube.com/watch?v=lxyZ_NhCtD8&list=PLyVKCvpm4iiS-NZ0z349Sg-muhayUK-p_
    •   https://codegym.cc/groups/posts/182-java-game-programming-for-beginners-where-to-start
    •   https://profiletree.com/java-game-development/
    •   https://itch.io/game-assets/tag-2d/tag-map
    •   https://github.com/janbodnar/Java-Snake-Game
    •   https://www.youtube.com/watch?v=6_N8QZ47toY&list=PL4rzdwizLaxYmltJQRjq18a9gsSyEQQ-0
Code snippets:
GamePlay Example: