Development principles
First, let's get acknowledged with important requirements the game has to fulfill, which should be in check not only for the planning phase, but through the whole process of development.
Gameplay design requirements
- Competitive - with scoring based on player’s performance (which should be optimised around lowest probability of any two players getting the same result and thus drawing)
- Skill-based - minimal or no luck contribution to the score
- Match-based - relatively short, independent game sessions, not continuous gameplay like MMORPG for example
- Replayable - engaging the player to play repeatedly and ensuring that instead of using skill, the player won't memorize the solution (so some randomization variance is recommended)
- Finite - with match finishing conditions, like limited time, reaching some goal, losing all lives
- Mobile-friendly - with controls applicable for mobile devices (and desktop at the same time)
Technical requirements
- Minimum supported Unity Version is:
2021.3.5f1
. - The game must work properly with WebGL. Take into consideration its limitations and be careful not to use WebGL incompatible code or assets (for example some shaders won’t work).
- The game should be in
9:16
or16:9
aspect ratio. - The game should run smoothly on any of the following platforms: mobile, desktop and Telegram.
We use a single WebGL build which is hosted through the PlayPad to access all of the specified platforms.
- UI should be displayed properly regardless of used device.
- Proper mobile input handling must be provided.
- Any interactive UI elements such as buttons have to be of appropriate size for comfortable use on small screens.
- UI should be guiding and intuitive.
- The game must be divided into minimum of 2 scenes. Lobby (or menu) scene & Gameplay scene.
tip
We recommend using 3 scenes, Initial, Lobby and Gameplay and then placing all the
DoNotDestroyOnLoad()
game objects in the Initial scene, but this is not mandatory. - Gameplay implementation must follow multiplayer server authoritative approach.
- This is mandatory even for "single player" games (which we call asynchronous multiplayer, since players compete worldwide via the leaderboards).
- It provides security and reliability of matches results, preventing cheating (how it does so you can find in the related article).