Purpose

  • The GRILLDISExample project is an demo project for the GRILL DIS for Unity plugin, showing how to utilize features of the plugin.

Get Started

  • This example project utilizes Unity 2021.3.11f1.
  • [Clone this repository](# Cloning This Repository)
  • Open the GRILLDISUnityExample project using Unity 2021.3.11f1 and allow it to build needed files.

Cloning This Repository

This repository includes a submodule that may be updated frequently. If you have cloned this repository with git clone you must also run the command git submodule update --init --recursive to ensure that the submodule code is cloned. However, you can skip this step by cloning this repository with the command git clone [URL] --recurse-submodule

If the submodule has already been added to the project but needs to be updated to the most recent state, run the command git submodule update --remote --merge

  • NOTE: The submodule is separate from the GRILL DIS for Unity plugin that is on the Unity Asset store. This project should use the submodule. NOT the plugin on the Asset store.

Usage - Update 'Game.ini' information

  • Before opening the project, verify the file CesiumIonInfo.txt in the [root folder]/Assets/Resources/ folder contains the following
{
    "WorldTerrainCesiumURL": "",
    "WorldTerrainCesiumIonToken": "",
    "WorldTerrainCesiumIonAssetID": 1,
    "RasterOverlayCesiumURL": "",
    "RasterOverlayCesiumIonToken": "",
    "RasterOverlayCesiumIonAssetID": 2
}

  • Cesium Ion keys will need to be created and set to be able to utilize Cesium. To do so:

    • Set up a Cesium Ion account
    • Access the created token in your Cesium Ion account and copy the token into the CesiumIonInfo.txt file created above into the following entries:
      • WorldTerrainCesiumIonToken
      • RasterOverlayCesiumURL
    • The asset IDs can be changed based on what is needed. Asset IDs can be found on the Cesium Ion webpage under the 'My Assets' tab.
  • Note: If the URL is set, the Token and AssetID will be ignored

DISEnumMappingsUAsset

DISEnumMappingsSettings

  • Once the project is open, verify that DIS Enumeration mappings exist.

    • Click on the DISManager in the 'DIS_DemoLevel' level and locate the DIS Enumeration Mapping asset that is currently set to the DIS Enumeration Mapping variable.
      • Open up the Asset and then expand the 'Entity Type Mappings' dropdown.
      • Add desired actors to DIS Enumeration mappings.
        • NOTE: Refer to the GRILL DIS for Unity plugin readme for more information on the DISGameManager.
    • NOTE: If desired, a new DIS Enumeration Mapping asset can be created. To do so, click on the 'Assets' tab, hover 'Create', hover 'GRILL DIS', and then select the 'DIS Enumeration Mapping' asset option. Once created, populate the mappings, and then replace the Enumeration Mapping in the DISGameManager actor with the new created mapping. Refer to the GRILL DIS for Unreal plugin readme for more information.
  • After DIS Enumeration mappings are created, click on play.

DISOptionsButton

DISVisualOptions

  • Click on the 'DIS Options' button on the menu that appears on start.
    • Change the visuals as desired.
      • Entity Labels: An overhead icon for the DIS Entities showing their marking, distance from user, and altitude (if applicable).
        • Entity labels can be clicked on to show additional information on the entity.
      • Entity Icons: An icon that will appear to represent the entity when the user is a certain distance away.
        • Entity icons are currently all the same, but they could be updated to show MIL STD icons for example.
      • Entity Ribbon Trails: Trails that appear behind the DIS Entities to show the path that they have taken.
        • NOTE: These visuals are buggy with Cesium if relocating the origin is enabled.

DISNetworkingOptions

  • Change the network settings as desired.

    • Exercise ID/Site ID/Application ID: DIS specific settings.
      • NOTE: Exercise ID needs to match that of what is being sent on the network in order to handle the received packets.
    • Connect Recv Socket: Whether or not to connect a receive socket.
    • Receive Use Multicast: Whether or not the receive socket being connected will use multicast.
      • NOTE: If enabled, the Receive IP Address should be a multicast address.
    • Receive Loopback: Whether or not the receive socket should listen for loopback traffic (i.e. traffic from local machine).
    • Receive IP Address: Address to receive DIS packets on.
      • NOTE: A receive IP address of 0.0.0.0 will listen to all DIS packets on the network.
    • Receive Port: The port to receive DIS packets on.
    • Connect Send Socket: Whether or not to connect a send socket.
    • Send Connection Type: The connection type to use for the send socket.
      • Current types supported are Multicast, Broadcast, and Unicast.
    • Send IP Address: The IP address to send DIS packets on.
    • Send IP Address: The port to send DIS packets on.
  • Click on Connect to connect to the network (opens a UDP socket)

  • Once all desired options are set, hit 'Apply & Close'. Then click on 'Start' if haven't already.

InGameMenu

  • If DIS packets are being sent across the network and DIS mappings have been set, then DIS entities should start appearing in the world.
    • NOTE: If custom DIS packets are desired to be sent by the sim, refer to the Modifying section below.
  • Click on the 'Entities' button in the top right hand corner of the screen to see available DIS Entities in the world.
    • The DIS Entities labels in the listing can be selected to view at various camera angles.
    • Either double click on an entity to go to direct view or select an entity and change the camera dropdown on the bottom right.
      • NOTE: Once the camera dropdown is changed away from 'Free Flying', just clicking on an entity will change the camera view to that entity.
      • The available camera options are:
        • Free Flying: Not attached to an entity. User controlled. See the below 'Movement' section for details on controlling it.
        • Direct View: A fixed direct view out the front of the entity. Moves and rotates with the entity.
        • Orbital View - Local: An orbital view of the entity. Moves and rotates with the entity, but can be further rotated around the entity in an orbital perspective. See the below 'Movement' section for details on controlling it.
        • Orbital View - World: An orbital view of the entity. Moves with the entity, but does not rotate with it. It be rotated around the entity in an orbital perspective. See the below 'Movement' section for details on controlling it.

DISEntityViewer

DISEntityCameraOptions

Movement

  • Free Flying Camera movement:
    • Click & Hold & Drag inside the Viewport to look around.
    • W, A, S, D to move.
    • Scrollwheel to increase/decrease speed.
  • Orbital View Camera movement:
    • Click & Hold & Drag inside the Viewport to look around.

Modifying

DISEntities

  • Handling of DIS packets is performed by the each individual DIS Entity.
    • Open up one of the 'DISEntity_BPBase' game object located in the '\Assets\DISEntities' folder to view how receiving is being performed.
    • Open up the 'DISEntity_ExampleSending' game object located in the '\Assets\DISEntities' folder to view how sending is being performed.
    • Additional DIS packet processing is performed by the GRILL DIS for Unity plugin. Refer to its README for additional details.
  • Handling of UDP connections is performed in the 'DISManager' game object located in the '\Assets\GRILL_DIS\DISPluginContent' folder.

DISGameState

Troubleshooting

  • If no DIS entities are appearing in the game, try the below steps:
    • Look at the 'Hierarchy' panel and check if the DIS Entities show there under the 'EntityContainer' child in the 'CesiumGeoreference' game object.
      • If so, try enabling DIS labels if not enabled already to locate them in the world.
    • Look at the 'Console Log' or Log File and see if there are warning messages being printed out from the DISGameManager stating that 'No mapping found for: ...'
      • If so, double check the DIS Enumeration mappings that were setup ealier and verify they were setup appropriately.
    • Verify DIS packets are being sent on the network. This can be done via Wireshark.
    • If working on a standalone network, verify that the Windows Firewall is not discarding the packets.
      • Even if packets are seen in Wireshark, the Windows Firewall may still block the UDP DIS traffic.
      • This can be fixed a few different ways. The below list is not all inclusive:
        • Make the Network Profile 'Private' in Windows
        • Add in needed rules into the Firewall to allow the packets through
        • Disable the Windows Firewall. Should be a last resort.