-
Notifications
You must be signed in to change notification settings - Fork 3
Data Schema::Mech
The following is the description for the main Unit variables that must be filled out for any unit to be used in battleMETAL. These values are set in the Unit's ini function, and are called first when a Unit will be spawned in.
void() data_ini_balaket_={
.data_idx = float : unique unit id
.vec_size = float : 1, 2, or 3
.vec_name = string : name.
.max_health = float : the Center Torso's max health.
.mins = vector : '-X -Y -Z' = X is Left/Right | Y is Up/Down | Z is Forward/Back, negative values are for mins.
.maxs = vector : 'X Y Z' = X is Left/Right | Y is Up/Down | Z is Forward/Back.
.energyMax = float : Max amount of Energy the unit can charge up to.
.energyRate = float : Run every server tic, amount of Energy to increase the current energy by.
.shieldMax = float : Max amount of Shield points the unit can charge their shields up to.
.shieldRate = float : Run every server tic, amount of Shield to increase current Shields by.
.radar_range = float : Range of Unit's ACTIVE radar, PASSIVE is Active / 2. this is in 3D Game Units.
.w_firetime = float : Number of Seconds it takes to acquire a Target Lock onto the selected Target.
.spreadDefault = enum : Base Accuracy rating for the Unit, select 1 of the following-
- ACCURACY_PRIMITVE : really bad accuracy.
- ACCURACY_LOWTECH : mediocre, but workable.
- ACCURACY_SKIRMISH : the 'default'.
- ACCURACY_MARKSMAN : a notch above the default.
- ACCURACY_SNIPER : really good.
.data_speed_forward = float : Unit's Forward speed, not 1:1 to Game Units, play around with the value.
.data_speed_strafe = float : Unit's Strafing speed, not 1:1 to Game Units, play around with the value.
.data_speed_backward = float : Unit's Backward speed, not 1:1 to Game Units, play around with the value.
.data_speed_accel = float : Unit's Sprint multiplier.
.yaw_speed = float : [AI Only] How quickly can the Unit rotate around its Y-axis.
.turret_yaw_speed = float : [AI Only] How quickly can the Unit's Turret rotate around the Turret's Y-axis.
data_ini_camera_( vector ); : Give the 3D offset-from-unit-origin for the Camera object.
data_ini_torso_center_( string , float, vector );
- string : path to model.
- float : health amount for this part.
- vector : 3D offset-from-unit-origin for the piece.
data_ini_torso_left_( string , float, vector );
data_ini_torso_right_( string , float, vector );
data_ini_arm_left_( string , float, vector );
data_ini_arm_right_( string , float, vector );
data_ini_legs_( string , float, vector );
Just registers the mech piece on the server. data_ini_unitHardpoint_1( enum, vector, vector, float, bit flags );
-
enum : which part to attach this hardpoint to -
- M_TOR_CENTER
- M_TOR_LEFT
- M_TOR_RIGHT
- M_ARM_LEFT
- M_ARM_RIGHT
- vector : 3D offset-from-unit-origin.
- vector : Pitch / Yaw / Roll angle adjustment for weapon in hardpoint.
- float : Weapon Size restriction.
- bit flags : See Game Data - Damage and Effect Types. max of 9 weapon hardpoints allowed.
It roughly matches how parts are made on the Server, but there's an important difference when adding FL_CLIENT
arm hardpoint.
data_ini_unitHardpoint_1( enum, vector, vector, float, bit flags );
-
enum : which part to attach this hardpoint to -
- M_TOR_CENTER
- M_TOR_LEFT
- M_TOR_RIGHT
- M_ARM_LEFT
- M_ARM_RIGHT
- vector : 3D offset-from-unit-origin.
- vector : Pitch / Yaw / Roll angle adjustment for weapon in hardpoint.
- float : Weapon Size restriction.
- bit flags : See Game Data - Damage and Effect Types. max of 9 weapon hardpoints allowed.
note: Client arms can aim up and down, so we bolt the weapons directly to the parent. see client/network/receive_sendent_player.predraw_player_weapon()
.pitchMax = float : max upward pitch angle for player view.
.pitchMin = **float ** : downward pitch limit, use a negative (-) number.
.weaponmodel = string : path to hud model (replaces the Quake-style weapon model)
.hud_rollangle = string : [float] roll angle of player view when they are strafing Left / Right.
.hud_bob = string : [float] view bobbing amount.
.hud_bob_cycle = string : [float] view bobbing speed.
.hud_bob_up = string; [float] view bobbing adjustment that makes the up/down swing of the bob last longer.
.hud_bob_model = "1"; 1 or 0 (True/False) whether to have the viewmodel bob up-and-down.
.hud_bob_side = "0.09"; [float] bobbing sideways sway amount.
.hud_bob_speed = "6"; [float] view bobbing speed of viewmodel.
.abbrev = string .description = string : displays fluff text of the unit in the UI menus. use '| |' for line breaks, and the menu will wrap text as well.
.icon = string : path to unit image for UI menus.
};