tsg grant Default Weapon Released
A script module used for granting units weapons without any customization applied to them.
Written by Okom on Nov 23, 2024 in Halo. Last edited: Nov 23, 2024.What is it?
tsg grantDefaultWeapon is a script module that grants the requesting unit (such as a player) the desired weapon type with the default customization applied. Normally when initially picking up a weapon in Halo Infinite, the player's weapon customization is applied to the weapon model. A downside of this is that weapon variants such as a "Legendary" Sniper Rifle become indistinguishable from the normal variant as they both get the same customization applied upon pickup. This script solves that issue.
How does it work?
Weapon and vehicle customization is determined by the preferences of the unit who interacts with the item first. The tsg grantDefaultWeapon module grants the requested weapon type first to a cloned player before granting that weapon to the unit who requested it. As a cloned player is a default biped that has no customization preferences, no customization will be applied to the weapon, and it will persist no matter who picks it up afterwards.
Creating the weapon carrier clone
A random, alive player is cloned at Gameplay Start and the clone is put into a stasis at the coordinates X: 0, Y: 0, Z: -9460. From there, the clone will fall into the "deload zone" beginning Z: -9462.6 and will become unable to move or make any actions. At this point the clone is ready to act as a temporary weapon carrier.
Requesting a weapon
When a weapon is requested by a unit, the desired weapon type is set in an object-scoped Weapon Type variable for the unit and the code for requesting the weapon is executed. The desired weapon type is given to the weapon carrier clone with the weapon addition method of Replace All, resulting in the clone's inventory being replaced with said weapon.
Granting the weapon
As the weapon is given to a clone instead of the requesting unit and the script should work for multiple units at the same time, units are put in a request queue in order to reliably track who each weapon should be granted to.
Clone dropping the weapon
In order to get the desired weapon away from the clone and into the hands of the requesting unit, it must not be in the clone's inventory. We can achieve this by forcing the clone to drop the weapon. An efficient way to do this is by replacing the clone's primary weapon with a dummy weapon.
After the weapon is dropped, the unit first in the request queue is gathered, removed from the queue and granted the weapon. An attempt is made to grant the requested weapon with the If Room method if the unit has room in their inventory so the requested weapon becomes their primary and their existing primary their secondary.
Dropping the requesting unit's secondary weapon
Regardless of whether the unit had one or two weapons at the time of request, the unit's current secondary weapon is temporarily dropped and teleported to stasis at X: 0, Y: 0, Z: -9500 so the drop action isn't noticeable. The unit is then granted the requested weapon (again, if the If Room grant worked) and the ammo adjustment is done.
Ammo adjustment
The ammo adjustment is done by pulling the previously stored number for how much percentage the ammo should be adjusted by and applying that to the requested weapon once it's in the player's inventory. If the value is positive, that value is used as-is to adjust the ammo count by. If the value is negative, the player's ammo is emptied and then the absolute of the adjustment value is used to add more ammo for the player, resulting in less ammo than default after a reload. The default ammo adjustment value of 0.00 will result in no action.
Cleanup
After the ammo adjustment is finished, their ammo adjustment value is reset back to 0.00, the unit's secondary weapon is granted back and the process is finished for the current unit who requested the weapon.
Usage
To use the script module, recreate the code shown in the image, set the desired weapon type and adjust the number in the global custom event for how the ammo should be adjusted. 0.00 is default. The trigger for the event can be anything where the unit/player can be extracted from; On Player Mark used in the example.
The idea
When designing the custom weapons for the Scripter's Guild Halo 5 Warzone recreation for Halo Infinite, me and Implied Skill ran into the issue of the weapon combinations not being easily distinguishable due to the player's weapon skins making all the variants of one base weapon type (such as an S7 Sniper Rifle) look the same.
The only ways to determine whether a weapon was not the default variant were:
- The weapon name (only for Legendary variants such as "S7 Flexfire")
- The reticle shape
- The weapon icon on the bottom left
- Firing the weapon
Out of these only the reticle shape was immediately noticeable, which would lead to players being confused about which weapon they were holding.
Discovered by accident
By accident while I was writing another piece of code to spawn a separate weapon when a specific grunt died, I noticed that the pattern I used for creating that weapon resulted in it having no customization on it. That pattern was similar to what later evolved into tsg grantDefaultWeapon.
We had a discussion about the possibility of integrating such a weapon granting feature into our code for tsg Warzone with Implied Skill and came to the conclusion that it would be a great jump in the weapon readability for our players, as long as it wasn't too heavy on the scripting budget.
Testing
After confirming my hypothesis to be true on how it would work, I made a test map where I would test the worst-case usage scenario. This scenario consisted of giving a specific weapon from a selection of 8 with a preset ammo adjustment to 9 players (8 bots and myself) as fast as the game allows.
I would track which of the 8 random loadouts got granted to each player by attaching a number value to them with a nav marker. This way I could compare the weapon they got granted with the number value to confirm whether everything was working or not.
Surprisingly much of the logic worked as intended, but one issue I had to fight for a while was the ammo adjustment value being from different loadouts. After narrowing down the causes and realizing it didn't happen when I was only granting weapons to one player, I realized it was something to do with multiple weapons being granted quickly.
In the end I changed when the current unit in the queue was being removed from the unitsRequestingWeapon list to be right at the beginning instead of at the end of the function and that fixed the issue. To me it's not fully intuitive to remove the requesting unit from the list before they have the weapon in their hands, but it seems to work and I haven't ran into any issues after a large amount of validation testing.