Below, you can see a very basic progress chart. The blue bars indicate, how far (in %) I am to complete the game. The grey bars indicate the remaining effort required for releasing Milestone 1.
That's right, there will be milestone releases for you to test. Consider them as early alpha versions or technical demos. The reason for that is very simple. Before finalizing the game, a lot of work needs to be done - a lot of work that I am planning to invest in my free time. With Milestone 1 (or even before), I am able to see how many people like and/or support my work. Depending on this, Pixel Tennis's future will be decided.
I hope you understand that there is no motivation if there is nobody that is interested in this project
Btw, the category order of the chart has nothing to do with priority. My LibreOffice just wanted to mix them randomly at a certain time.
Website / Forum
As you can see, there is a website / forum. pixeltennis.de is located on a German paid hoster with SSL support and more than enough capacity.
The game uses an SQL database hosted at pixeltennis.de
Networking P2P Gameplay
Unity's networking system works out of the box for local connections. If you want to connect via internet, they only offer a paid method which costs per connected user which is too expensive for me.
As an alternative, Pixel Tennis currently uses a one-time-fee third party library that tries to establish a peer to peer connection. It greatly reduces server load, but can also fail in 5-10% of certain system configurations. P2P also means, that the whole multiplayer logic is handled by the clients alone.
As announced on 03/2019, it is planned to switch from peer to peer connections to a semi authoritive server instead.
Since 03/2019 all match related connection logic goes through the dedicated server using a custom network implementation.
The main gameserver is hosted on a dedicated Linux machine at a paid hoster. It keeps track of accounts and ingame progress. The user account login is handled by an external interface that verifies against your forum login.
The current version already can provide character data, chats and control creating and joining rooms.
As announced on 03/2019, the game server will also handle multiplayer logic in the future.
Beside basic animations like rotating a smash circle or giving the ball a nice trailing effect, nothing is done. Things like character animation or certain camera scenes will be done much later.
Nothing to see here. Btw, there will be no pay to win gatcha coins - never :)
I know, collecting items is a very motivating part of the game, but Milestone 1 will not have anything like this at first.
Not even started. I only have basic ideas on how to achieve this.
3D Modeling is a very big topic which will require much time and effort. Luckily, a prototype can also be made of basic shapes.
Same as for 3D Modeling. The current player model of Pixel Tennis just looks like Pikachu (without face, ears, arms, legs and tail...)
As posted in Your opinion on Pixel Tennis future art style, Pixel Tennis will most likely get a pixel art style to greatly reduce 3D modeling and animation work. I am still looking for a 3D artist in Searching someone for 3D modeling and animation.
Important as well., but not on my priority list. Will not be in Milestone 1.
See Your opinion on Pixel Tennis exp rates discussion.
A very basic user interface is can be seen in [devblog] Pixel Tennis – menu & online gameplay.
Running, Charging and hitting a ball (Stroke, Lob) works in network mode, even special shots are available. The camera follows the player.
Btw, the court position logic (which player stays where in 1on1 or 2on2 at which state) was awful to implement...
//Note: You cannot reply to this topic, because it is only intended to work as a kind of changelog :)
- Mister Ad
- Google Advertising
Verified a way to use the forum account credentials to log into the gameserver.
Revised player state synchronization to reduce delays on the local client.
Score system implemented which determines points for the certain player. The score is currently handled internally and not visible as there is no UI. Fixed serve-ball-hit-ground-target-position
More tests on P2P networking - fails on my system when UPnP is disabled. Error handling and fallback connections required.
First test with externally hosted gameserver made. Success!
Revised P2P networking to check connectivity before actually loading the match. Makes sure that all clients successfully loaded the match scene before starting it.
Interface implementation for main functions like reading character data and item handling by BoneD.
Added account verification based on forum login
Improved exception handling on connection loss.
Rewriting complete server/client logic to make it independant from Unity core for performance and resource usage reasons on server side.
Fixed player states (ready, master) when room changes (player switch slots, room details updated etc).
Return to room after match ends.
Rewriting database validation and replaced engine for better performance
Complete network communication protocol rewritten. All changes lead to a 4x performance increase at about 1/10th of data usage!
The old logic worked still good enough for the game server, but...
... Pixel Tennis multiplayer will switch from UNet peer to peer to a semi authoritative server. This means, that the server needs to process a lot more data making the mentioned network optimizations mandatory. You can read the reason for the switch here.
Starting to develop custom replacement methods for UNet's build in functions. This includes, object spawn handling, message handling on object base and smooth player position synchronization across a match hosted on the semi authoritative server.
Although, this does not have any visual effect, it requires a lot work and refactoring (more than 500 lines of code added/changed in the past 2 weeks). Thanks Unity's UNET deprecation...
Switch from UNet peer to peer to a custom network implementation is mostly done. Pixel Tennis' match networking logic will now run through a dedicated server located in Germany.
- Increased network compatibility as no direct connection (port forwarding + firewall madness) is required anymore
- Better protection against client manipulation
- Restored compatibility to future Unity Engine versions
- Increased server load
- Players connecting far away from the server location will experience higher pings as before. However, additional dedicated servers at different countries can be established later if required.
I learned very much about message handling, serialization and networking in general. Although this task required so much work and did not bring new features, it was still a very important step towards Pixel Tennis' future.
"Secretly" upgraded the hosting contract for pixeltennis.de for more space and performance
Changed database engine back to MySQL for better maintainability and performance
Improved and simplified database layout
Moved more gameplay logic from client to server side to prevent client side manipulation
Fixed all player now return back to their room after finishing a match
Added version validation on client login to notify if there is an update available for the game
Prepared character creation and skill point assignment on server side including validation. Big thanks @BoneD!
Reduced slice speed by 10% as it was to effective on online matches
Fixed smash indicator not disappearing under certain conditions
Added exp and level distribution after match.
Prevent multiple logins with the same account.
Fixed chat messages in a room not reaching the first player
Added logic for sending/managing private messages between characters*
Added logic for creating/deleting characters*
Added logic for distributing skill points to characters*
*Currently only available on server side. Client still needs to provide a UI and the corresponding calls to make them available.
Menu Navigation / UI
Implemented nested prefabs to greatly improve UI structuring as Unity finally supports it in their LTS releases.
UI handling and instantiation rewritten based on a best practices menu system design. In numbers: These UI changes took about 20 hours to complete and resulted into a change of about 30k lines of (mostly generated) source files.
Remember logged in username between sessions
Fixed some UI elements being invisible on certain screen/window resolutions
Again, a big thanks @BoneD for helping out on the gameserver side!
Added character creation UI
Added settings UI for controlling screen resolution, visual quality and audio volume
Adjust framerate based on the screen refresh rate
Users browsing this forum: No registered users and 3 guests