Ugly Briefs Update #1
The ugly underwear updates
Alright everyone, per demand on Discord I shall be attempting to provide briefs on the current development including all the setbacks and backend related code/technical works. Personally I don’t believe these to be worth while updates as my inclination is that many would feel turned off by the lack of pretty pictures or noteworthy appreciable differences in the project. Also I’d prefer to put on more of a professional and positive face when it comes to the development updates, but since there is demand for even the techno-babble and frustrations (and potentially rants on my end) with some of the reworks I’ve been going through, then I shall oblige and we’ll see where this goes. I’ll try to keep these “brief” as much as possible since there is much I can talk about these topics, but I would be more than happy to expand on these if you leave a comment in the Discord
Torque Rotation and the rework of SpaceshipPawn movement
Since Unreal 4.20 there was a massive hiccup in the way that Unreal changed the way they compiled blueprints. This change was related to how blueprints were cached and compiled with dependencies. This issue back in 2018 has caused massive issues with our main pawn called “SpaceshipPawn” since it had a ton of linked dependencies since the Demo (Turrets, Camera Boom, Movement, Rotation, Weapons, HUD, etc. etc.) and caused the eventual slow down of compiling to be between 20-40 seconds!! That turn around was just ridiculous for checking against small bug fixes and quick hop-in/hop-out tests to see if things worked (bug fixes or new features). So, in order to fix this, a massive rework was needed to build the Components of the SpaceshipPawn rather than have everything piled into one code class and Blueprint.
Starting with the move over to Torque rather than Frame Updated rotation (forced rotation on the pawn), this allowed me to use “Angular Velocity” that I can grab directly from the physics thread rather than math out the forced direction of the Pawn every frame (which is very bad for the CPU FPS when too many entities are active). This global accessible variable works MUCH better also in Multiplayer since the actual Angular Velocity (and resistances like air or what ever) is already pre-calculated for all the clients and updates much faster than passing replicated events or values through the network and also is just over all faster on the CPU.
Even though, things like Gimbal Lock on rotation of the Spaceships was addressed by the Local Rotation code per frame that I did (rather than complicated Quaternions which annoys the shit out of me lol), I also discovered that using Angular Velocity allowed me to better handle the updates back and forth between the SpaceshipPawn and the Camera Boom. This means I can better handle rotations like the weird wobble when doing a role in a larger vessel. Since in the previous method I was inverse translating your rotation speeds depending which direction you’re turning in order to provide the experience of “lag” rotation on the Camera, this new method just takes your current angular velocity into account for acceleration/deceleration while rotating. Also with this, I was able to split the Camera Boom off into it’s own C++ component so it can be compiled and ran independently of the SpaceshipPawn and only references what ever parent it’s bound to, so it’s not reliant on any specific class (which is what I’m trying to achieve with all dependent classes (Turrets, Weapons, etc)).
As far as the old SpaceshipPawn, it wasn’t really openly discussed in groups about slower blueprint compile times (except for a few bug reports that went unanswered), but I discovered that it was an eventual change over to at least VS 2018 and the new framework handled by Windows 10 that handled these different BP compiling instructions. Since I am a stubborn developer, it took the change over to Unreal 4.25 that required Window 10 (who trusts even versions of Windows to begin with? Haha!) to continue development. Since the move over to Windows 10, I’ve since now seen a drop back down from the old SpaceshipPawn compile times to 1-3 seconds…. (Grumble grumble). I’m annoyed this compile time has dropped so much since I’ve basically been recreating the SpaceshipPawn with the new component setup and half way through all the core components. I’m still not happy with the old SpaceshipPawn setup since there were a lot of short cuts done to get the Demo out to everyone which did bite me in the ass when it came to optimization and bug fixes needed, so I’m still going to keep on trucking with the overhaul on the SpaceshipPawn’s components since it definitely is a more optimized approach than reverting back to using the old Pawn going forward.
Summary
Perhaps I could split the difference when it comes to MP and the Alpha release to setup the SpaceshipPawn with the new movement (Force based rather than vector) and the new Rotation (Torque to apply Angular Velocity) and keep all the old setup that currently works (even though not optimized) for Alpha release to get it out sooner?…
Either way, I hate writing about these failures, so in the next brief I’ll talk about the successes in developing a global Anim Graph/Blueprints for all Turrets to allow them to rotate. Teaser: Beforehand in 4.23 and earlier, you had to make an Anim graph for each skeleton and cache their poses for each direction update (and doing so on the root with a child actor in 4.24 and later caused level load crashes! aarrgg!).
I hope you all enjoyed this “Brief” and look behind the clothing to see the development warts and all. Now I’m going to put some clothes back on and get back to work. I’ve set an alert now to post these everyone Monday/Wednesday/Friday, so feel free to bug me over on Discord on those days to keep you guys updated.
God speed Warden,
-Kami