Take On Helicopters CfgBase: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "};</syntaxhighlight>" to "}; </syntaxhighlight>")
m (Text replacement - "pedia\.org\/([^w])" to "pedia.org/wiki/$1")
 
(3 intermediate revisions by the same user not shown)
Line 9: Line 9:
{
{
//--- Heliport name (visible in menus)
//--- Heliport name (visible in menus)
displayName = $STR_HSIM_CfgBase_United_States_H;
displayName = "$STR_HSIM_CfgBase_United_States_H";
//--- Script executed every time heliport is loaded
//--- Script executed every time heliport is loaded
init = "\hsim\Modules_H\base\United_States_H\init.sqf";
init = "\hsim\Modules_H\base\United_States_H\init.sqf";
//--- Starting date of heliport. Every completed mission adds one day
//--- Starting date of heliport. Every completed mission adds one day
initDate[] = {2013,8,5,10,0};
initDate[] = { 2013, 8, 5, 10, 0 };
//--- Starting money
//--- Starting money
initMoney = 1985;
initMoney = 1985;
Line 20: Line 20:
class Mission
class Mission
{
{
...
// ...
};
};
class Helicopters
class Helicopters
{
{
...
// ...
};
};
...etc...
 
// etc
};
};
};
};
Line 32: Line 33:


Following params are shared for Missions, Helicopters (including components), Staff and Upgrades.
Following params are shared for Missions, Helicopters (including components), Staff and Upgrades.
{{Columns|3|
* scope
* scope
* show
* show
Line 41: Line 43:
* price
* price
* forced
* forced
 
}}


=== Mission ===
=== Mission ===
Line 63: Line 65:
{
{
//--- Name visible in mission list on heliport
//--- Name visible in mission list on heliport
displayName = $STR_HSIM_CfgBase_United_States_H_Missions_Visit;
displayName = "$STR_HSIM_CfgBase_United_States_H_Missions_Visit";
//--- List of helicopter classes used as default. One of them is selected randomly.
//--- List of helicopter classes used as default. One of them is selected randomly.
helicoptersDefault[] = {MISSION_HELICOPTERS_LM};
helicoptersDefault[] = {MISSION_HELICOPTERS_LM};
Line 74: Line 76:
//--- Classes of missions required before mission is displayed in menu
//--- Classes of missions required before mission is displayed in menu
requiredMissions[] = {
requiredMissions[] = {
US_C_01
"US_C_01"
};
};
//--- Helicopter tags required for mission to be enabled in menu
//--- Helicopter tags required for mission to be enabled in menu
requiredHelicopters[] = {
requiredHelicopters[] = {
{light,medium}
{ "light", "medium" }
};
};
//--- Helicopter component required for mission to be enabled in menu
//--- Helicopter component required for mission to be enabled in menu
requiredHelicopterUpgrades[] = {
requiredHelicopterUpgrades[] = {
doors
"doors"
};
};
//--- Company logo displayed in heliport menu
//--- Company logo displayed in heliport menu
Line 98: Line 100:
vehicle = "Heli_Light01_H";
vehicle = "Heli_Light01_H";
//--- Name displayed in heliportmenu
//--- Name displayed in heliportmenu
displayName = $STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_H0;
displayName = "$STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_H0";
//--- Description displayed in heliport menu
//--- Description displayed in heliport menu
libTextDesc = $STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_ARMORY;
libTextDesc = "$STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_ARMORY";
//--- Purchase price (negative value means amount is removed)
//--- Purchase price (negative value means amount is removed)
price = -320000;
price = -320000;
Line 112: Line 114:
forced = 1;
forced = 1;
//--- Tags
//--- Tags
types[] = {"light"};
types[] = { "light" };


//--- Component category class
//--- Component category class
Line 118: Line 120:
{
{
//--- Category name displayed in menu
//--- Category name displayed in menu
displayName = $STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior;
displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior";
//--- Component class
//--- Component class
class Doors
class Doors
{
{
//--- Component name displayed in menu
//--- Component name displayed in menu
displayName = $STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors;
displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors";
//--- Component description displayed in menu
//--- Component description displayed in menu
libTextDesc = $STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors_desc;
libTextDesc = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors_desc";
//--- Model selections which component enables
//--- Model selections which component enables
components[] = {"AddDoors"};
components[] = { "AddDoors" };
//--- Component purchase price
//--- Component purchase price
price = -1000;
price = -1000;
//--- Tags which component enables
//--- Tags which component enables
types[] = {"doors"};
types[] = { "doors" };
//--- Weight added to total helicopter weight
//--- Weight added to total helicopter weight
weight = 10;
weight = 10;
Line 145: Line 147:
class CargoHook
class CargoHook
{
{
displayName = $STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook;
displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook";
libTextDesc = $STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook;
libTextDesc = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook";
components[] = {};
components[] = {};
//--- Component is added automatically
//--- Component is added automatically
Line 152: Line 154:
//--- Condition for removing the component from owned ones
//--- Condition for removing the component from owned ones
hide = "myCounter > 42";
hide = "myCounter > 42";
types[] = {"cargoHook"};
types[] = { "cargoHook" };
};
};
};
};
Line 165: Line 167:
class Benches
class Benches
{
{
types[] = {"benches","posSide"};
types[] = { "benches", "posSide" };
};
};
class Camera
class Camera
{
{
types[] = {"camera","posSide","posFrame"};
types[] = { "camera", "posSide", "posFrame" };
};
};
</syntaxhighlight>
</syntaxhighlight>
Line 175: Line 177:
However, ''posSide'' is virtual tag and makes sure that camera cannot be enabled at the same time as benches (as both occupy similar position).
However, ''posSide'' is virtual tag and makes sure that camera cannot be enabled at the same time as benches (as both occupy similar position).


=== Tags ===


=== Tags ===
Every helicopter or component is marked with tags, and missions can require helicopters or components with such tags to be owned by player before they can be played.
Every helicopter or component is marked with tags, and missions can require helicopters or components with such tags to be owned by player before they can be played.
Otherwise "Show Requirements" button is active instead of "Play" in heliport mission selection. Clicking on the button will display tag descriptions defined in this class.
Otherwise "Show Requirements" button is active instead of "Play" in heliport mission selection. Clicking on the button will display tag descriptions defined in this class.
Line 186: Line 188:
{
{
//--- Name visible in 'Show Requirements' message box
//--- Name visible in 'Show Requirements' message box
displayName = $STR_HSIM_CfgBase_United_States_H_tags_Light;
displayName = "$STR_HSIM_CfgBase_United_States_H_tags_Light";
};
};
};
};
</syntaxhighlight>
</syntaxhighlight>


=== Factions ===
=== Factions ===
Line 201: Line 202:
{
{
//--- Name visible in Contracts menu
//--- Name visible in Contracts menu
displayName = $STR_HSIM_CfgBase_United_States_H_Factions_CORE;
displayName = "$STR_HSIM_CfgBase_United_States_H_Factions_CORE";
//--- Unique faction id, used for mission categoriting (see Missions paragraph above)
//--- Unique faction id, used for mission categoriting (see Missions paragraph above)
id = 0;
id = 0;
Line 209: Line 210:
};
};
</syntaxhighlight>
</syntaxhighlight>


=== Staff ===
=== Staff ===
Line 215: Line 215:


=== Upgrades ===
=== Upgrades ===
Heliport upgrades are compositions placed on heliport itself, like hangar, tools, tables etc. However, it can also include environment objects further away from heliport, like cargo ship wreck.
Heliport upgrades are compositions placed on heliport itself, like hangar, tools, tables etc. However, it can also include environment objects further away from heliport, like cargo ship wreck.


Line 228: Line 229:
composition = "heliport_hangarDefault";
composition = "heliport_hangarDefault";
//--- Composition position
//--- Composition position
positions[] = {"hangar00"};
positions[] = { "hangar00" };
forced = 1;
forced = 1;
};
};
Line 243: Line 244:
{
{
//--- Zone position
//--- Zone position
position[] = {2018.7,45494.7,0};
position[] = { 2018.7, 45494.7, 0 };
//--- Zone area (matches triggerArea format))
//--- Zone area (matches triggerArea format))
area[] = {4500,3000,90,1};
area[] = { 4500, 3000, 90, 1 };
//--- Zone type (see below)
//--- Zone type (see below)
type = 2;
type = 2;
Line 252: Line 253:
</syntaxhighlight>
</syntaxhighlight>


Zone types (simplified representation of [http://en.wikipedia.org/wiki/Airspace_class airspace classes]):
Zone types (simplified representation of {{Link|https://en.wikipedia.org/wiki/Airspace_class|airspace classes}}):
* 0 - Airport (Class D Airspace)
* 0 - Airport (Class D Airspace)
* 1 - International Airport (Class B Airspace)
* 1 - International Airport (Class B Airspace)

Latest revision as of 22:13, 11 April 2023

Every world is allowed to have one heliport. All settings are placed in CfgBase under classname matching those of CfgWorlds class (and returned value worldName).

class CfgBase
{
	//--- World name (matches CfgWorlds class)
	class United_States_H
	{
		//--- Heliport name (visible in menus)
		displayName = "$STR_HSIM_CfgBase_United_States_H";
		//--- Script executed every time heliport is loaded
		init = "\hsim\Modules_H\base\United_States_H\init.sqf";
		//--- Starting date of heliport. Every completed mission adds one day
		initDate[] = { 2013, 8, 5, 10, 0 };
		//--- Starting money
		initMoney = 1985;

		//--- Subclasses (see below)
		class Mission
		{
			// ...
		};
		class Helicopters
		{
			// ...
		};

		// etc
	};
};

Following params are shared for Missions, Helicopters (including components), Staff and Upgrades.

  • scope
  • show
  • hide
  • enable
  • enableText
  • displayName
  • libTextDesc
  • price
  • forced

Mission

Includes mission.sqm of heliport mission. Used mainly dor debugging object positions in case the mission was not loaded previously.

class Mission
{
	#include "\hsim\Missions_H\campaign\missions\United_States_H.United_States_H\mission.sqm"
};

Missions

Procedural missions (Contracts).

class Missions
{
	class Visit
	{
		//--- Name visible in mission list on heliport
		displayName = "$STR_HSIM_CfgBase_United_States_H_Missions_Visit";
		//--- List of helicopter classes used as default. One of them is selected randomly.
		helicoptersDefault[] = {MISSION_HELICOPTERS_LM};
		//--- When 1, replaying the mission will still earn player money
		repeat = 1;
		//--- Faction ID
		faction = 2;
		//--- Mission reward
		price = 15000;
		//--- Classes of missions required before mission is displayed in menu
		requiredMissions[] = {
			"US_C_01"
		};
		//--- Helicopter tags required for mission to be enabled in menu
		requiredHelicopters[] = {
			{ "light", "medium" }
		};
		//--- Helicopter component required for mission to be enabled in menu
		requiredHelicopterUpgrades[] = {
			"doors"
		};
		//--- Company logo displayed in heliport menu
		overviewLogo = "hsim\ui_h\data\logos\logo_larkin_ca.paa";
	};
};

Helicopters

class HeliLight
{
	//--- Helicopter vehicle class (from CfgVehicles)
	vehicle = "Heli_Light01_H";
	//--- Name displayed in heliportmenu
	displayName = "$STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_H0";
	//--- Description displayed in heliport menu
	libTextDesc = "$STR_HSIM_CFGVEHICLES_HELI_LIGHT01_BASE_ARMORY";
	//--- Purchase price (negative value means amount is removed)
	price = -320000;
	//--- Condition for showing the helicopter in menu (default is "true")
	show = "random 1 > 0.5";
	//--- Condition for enabling the helicopter in menu (it can be visible, but not purchasable) (default is "true")
	enable = "daytime > 12";
	//--- Text displayed in case enable returns false
	enableText = "Helicopters before noon are so ungentlemanlike.";
	//--- When 1, helicopter is added automatically once show and enable conditions are met
	forced = 1;
	//--- Tags
	types[] = { "light" };

	//--- Component category class
	class Exterior
	{
		//--- Category name displayed in menu
		displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior";
		//--- Component class
		class Doors
		{
			//--- Component name displayed in menu
			displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors";
			//--- Component description displayed in menu
			libTextDesc = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliLight_Exterior_Doors_desc";
			//--- Model selections which component enables
			components[] = { "AddDoors" };
			//--- Component purchase price
			price = -1000;
			//--- Tags which component enables
			types[] = { "doors" };
			//--- Weight added to total helicopter weight
			weight = 10;
		};
	};

	class Init 
	{
		displayName = "Init";
		//--- Private scope - category is not displayed in menu
		scope = 1;
				
		class CargoHook
		{
			displayName = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook";
			libTextDesc = "$STR_HSIM_CfgBase_United_States_H_Helicopters_HeliHeavy_Exterior_CargoHook";
			components[] = {};
			//--- Component is added automatically
			forced = 1;
			//--- Condition for removing the component from owned ones
			hide = "myCounter > 42";
			types[] = { "cargoHook" };
		};
	};
};

Component tags are unique, only on of the can be enabled at the same time. That means that if two component has for example tag "camera", enabling one of them will disable the other one. Only tags defined in class Tags are displayed in requirements, which mean you can use virtual tags to handle correct technical exclusion.

Example:

class Benches
{
	types[] = { "benches", "posSide" };
};
class Camera
{
	types[] = { "camera", "posSide", "posFrame" };
};

benches and camera are defined in class Tags and are displayed in mission requirements. However, posSide is virtual tag and makes sure that camera cannot be enabled at the same time as benches (as both occupy similar position).

Tags

Every helicopter or component is marked with tags, and missions can require helicopters or components with such tags to be owned by player before they can be played. Otherwise "Show Requirements" button is active instead of "Play" in heliport mission selection. Clicking on the button will display tag descriptions defined in this class.

class Tags
{
	class Light
	{
		//--- Name visible in 'Show Requirements' message box
		displayName = "$STR_HSIM_CfgBase_United_States_H_tags_Light";
	};
};

Factions

Factions serves as mission categories (e.g. Story, Government, Tutorials, ...).

class Factions
{
	class CORE
	{
		//--- Name visible in Contracts menu
		displayName = "$STR_HSIM_CfgBase_United_States_H_Factions_CORE";
		//--- Unique faction id, used for mission categoriting (see Missions paragraph above)
		id = 0;
		//--- Listbox icon
		image = "hsim\ui_h\data\igui_sidebriefing_civil_ca.paa";
	};
};

Staff

TBA

Upgrades

Heliport upgrades are compositions placed on heliport itself, like hangar, tools, tables etc. However, it can also include environment objects further away from heliport, like cargo ship wreck.

class Hangars
{
	displayName = "Hangars";
	class Hangar_default
 	{
		displayName = "Default Hangar";
		libTextDesc = "Larkin Aviation offices";
		//--- Composition class from CfgObjectCompositions
		composition = "heliport_hangarDefault";
		//--- Composition position
		positions[] = { "hangar00" };
		forced = 1;
	};
};

NoFlyZones

No-fly zones created automatically by BIS_fnc_noFlyZonesCreate.

class Factions
{
	class P51
	{
		//--- Zone position
		position[] = { 2018.7, 45494.7, 0 };
		//--- Zone area (matches triggerArea format))
		area[] = { 4500, 3000, 90, 1 };
		//--- Zone type (see below)
		type = 2;
	};
};

Zone types (simplified representation of airspace classes):

  • 0 - Airport (Class D Airspace)
  • 1 - International Airport (Class B Airspace)
  • 2 - Restricted zone