Eden Editor: Entity Context Menu: Difference between revisions

From Bohemia Interactive Community
(added information about uiNamespace variables and added syntax highlighting)
No edit summary
Line 106: Line 106:
|}
|}


==Useful Variables==
==Useful Variable==
* When working with the context menu it can be handy to work with some uiNamespace variables.
* One the the menu was opened, the following variable can be accessed.
<syntaxhighlight lang="cpp">
<syntaxhighlight lang="cpp">
_menuData = (uiNamespace getVariable "bis_fnc_3DENEntityMenu_data");
_menuData = (uiNamespace getVariable "bis_fnc_3DENEntityMenu_data");

Revision as of 16:56, 11 January 2018

Create a custom Entity Context Menu entry

  • Entries for the Context Menu are defined in the class Display3DEN.
  • The menu has multiple levels, the first level for example contains options like "Go Here" or folders like "Log". Those folders on the other hand can have another level, level 2.

A3 3DEN contextMenu.jpg

class ctrlMenu;//First we need to load the base class of the menu
class Display3DEN
{
	class ContextMenu: ctrlMenu
	{
	    class Items
	    {
			class Log//The easiest way to add an entry is to use one of the already available folders, here we use the class '''Log''' '''(Level 1)'''
			{
				picture = "someLogo.paa";//Icon used for the entry called '''Log'''
				items[] +=//Here we list all items we want to add to the '''Log''' class. 
				{
					"TAG_ShowSomeText"
				};
			};
			class TAG_ShowSomeText//Now we need to define the entry itself which will be inside the '''Log''' folder '''(Level 2)'''
			{
				text = $STR_TAG_contextMenu_showSomeText;//Name of the entry, ideally localised
				action = "systemChat 'Showing some text.'";//The code which is executed when the entry was selected
				conditionShow = "hoverObject";//The Condition, see below
			};
		};
	};
};


Conditions

  • Context menu entries can have different conditions which need to be true in order for the entry to appear.
  • The condition is defined by the conditionShow config entry.
class YourEntry
{
	action = "call BIS_fnc_someFunction"; // Can be any kind of expression defined as string
	text = "Delete Crew"; // Name shown in the context menu
	conditionShow = "hoverObjectVehicle"; // Condition
};

The condition is a Simple Expression and can use one of the variables below:

Condition Description
selected True when an Eden entity is selected
hoverObjectBrain True when hovering over an object with simulation "soldier" or "UAVpilot"
hoverObjectVehicle True when hovering over a vehicle
hoverObject True when hovering over any object
hoverGroup True when hovering over any group
hoverTrigger True when hovering over any trigger
hoverWaypoint True when hovering over any waypoint
hoverLogic True when hovering over any logic
hoverMarker True when hovering over any marker
isMultiplayer True when editing in multiplayer environment
hoverObjectUav True when hovering over an UAV
isEditList True when the menu is opened from entity menu
hoverLayer True when hovering over a Layer
hoverObjectCanFly True when hovering an object which can fly
hoverObjectFlying True when hovering an object which is flying
selectedObject True when an object is selected
selectedWaypoint True when a waypoint is selected
selectedLogic True when a logic is selected
selectedMarker True when a Marker is selected

Useful Variable

  • One the the menu was opened, the following variable can be accessed.
_menuData = (uiNamespace getVariable "bis_fnc_3DENEntityMenu_data");
_pos3D = _menuData select 0;//Is the position of the entity in 3D coordinates
_entity = _menuData select 1;//Is the entity which was right clicked at.