ATAK Plugin
Android Team Awareness Kit (TAK) is a US Government situational awareness application, available for free on Android (ATAK). The civilian version is available for free on the Google Play store.
ATAK-CIV https://play.google.com/store/apps/details?id=com.atakmap.app.civ
Requirements
ATAK (CIV or MIL)
A CloudRF account or a SOOTHSAYER server
A network connection
Our plugin is signed by the TAK Product Center (TPC) which at the time of writing means it should work on Civilian and Government flavours.
Plugin installation
Install ATAK on your phone/tablet and then download the latest APK file from https://cloudrf.com/atak-plugin
At the time of writing, v1.5 (March 2025) is the latest.
You can download it directly from the device with a browser, send the file to the device via email/IM or copy it over via USB.
Before you attempt installation of the APK, ensure ATAK is running. If it is not running, installation will fail which is expected behaviour.
Within ATAK, open the plugin manager (jigsaw icon) and you should see the SOOTHSAYER plugin listed as available but not loaded. At this point you need to check the central status box to load the plugin. This is also where ATAK will check compatibility.
Validating the plugin version
To see details about the plugin version, click the report icon to the right. It should specify the required Android OS (10 in our case) and ATAK version (4.8.1.CIV) as well as the signature validity which for a TPC signed plugin should be valid:
Adding a shortcut in ATAK
Once installed the plugin will be available within ATAK. To add it to the quick menu, click the pencil marker adjacent to the “Tools” label above the icons. This opens up the navigation bar to editing so you can drag your new plugin up there.
Logging in to your account
Press the new SOOTHSAYER button to open the plugin. You should have a list select and a top row of buttons.
The plugin needs a CloudRF or SOOTHSAYER account to function. To login to your account, press the corner settings button and then navigate to the account login page via the account button at the bottom.
Enter your server’s address starting with https://
Enter your username and password then click ‘Login’.
A successful login will redirect you back to the plugin start page and synchronise RF templates from your account to your device.
Using the plugin
To add a radio to the map, choose the system from the drop down list, then click the SOOTHSAYER button above it. A marker will be added to the middle of the map.
To trigger a calculation, you can press the green Play button or press and then drag the marker to the desired location using a “long press”.
Settings
Coverage layer
Single site mode places each radio coverage as a separate image layer. This can get cluttered with many radios but can be managed via the native layer manager.
Multisite (GPU) mode is a more powerful capability which models all radios together to show network coverage. This updates one “MULTISITE” layer only.
Multisite requires a server with a GPU or a premium CloudRF subscription.
Show coverage
This checkbox will show or hide RF coverage. This can be useful to save bandwidth if the interest is links.
Show links
This checkbox will show or hide RF links between radios. This uses less bandwidth than coverage layers, and is faster.
A multisite layer is a single layer which is available in the ATAK layers menu under the “SOOTHSAYER” category. It can be hidden or deleted to suit.
Polygon tool
The polygon tool allows focused studies of distant areas using the “bounds” parameter in the API. This allows faster, smaller, higher resolution calculations which reduce bandwidth and memory consumption in the viewer whilst keeping the wider map clear.
To use it, click the polygon button and draw a shape upon the map. This shape will be referenced for all future calculations.
Editing a transmitter
Transmitter settings can be edited once they’re on the map.
Select the transmitter to open the menu then click the pencil to edit the settings. An edit form will open which supports Height, Power, Frequency, Azimuth, Bandwidth and Noise. Click recalculate to apply any change(s). Template files are unaffected and multiple azimuths are supported separated by commas.
Other template settings can be edited in the .json template file on the SD card.
Satellite tool
The Satellite coverage feature lets you test an area for line-of-sight to a GS satellite. It offers a high resolution study beyond basic sat-finder apps which will recommend a shot through a mountain.
Select your satellite and time of day, resolution and finally drag the marker to test that area. A high resolution will reduce the study area to produce the layer quicker.
Satellite TLE data is updated periodically on CloudRF from public sources and SOOTHSAYER server customers can manage their TLE data and source via their admin dashboard.
KMZ export
Layers generated with the plugin are saved as KMZ on the SD card in the atak/SOOTHSAYER/KMZ/ folder. You can load them into ATAK as standard KMZ overlays using the “Local import” dialog or export them to another viewer such as WinTAK or TAK-X. When prompted for a choice of the import method, choose “Image Overlay File”.
To send a KMZ to another TAK user, load it onto your map to validate it’s the right one, then using ATAK’s native send functionality, click the 3 bars to the right of the selected layer to open the send dialog. From here you can choose to send it to a contact, server or third party app eg. Bluetooth or Google Drive.
Radio Templates
Templates are synchronised after you login with your account.
To add local radio systems, place your CloudRF/SOOTHSAYER JSON templates in the atak/SOOTHSAYER/templates folder. You can also download templates as .json files from the top left corner in the CloudRF/SOOTHSAYER web interface.
A template can be edited within any text editor and must conform to the CloudRF API specification detailed at https://cloudrf.com/documentation/developer/
Example DMR template
This template is for a 700MHz handheld radio with 2W of RF power, a GPU engine (engine: 1) with the General Purpose model (#10), Deygout diffraction (#4), a 3km radius and 4m resolution and buildings data.
{
"version": "CloudRF-API-v3.8.2",
"reference": "https://cloudrf.com/documentation/developer/",
"template": {
"name": "Motorola DMR 2W",
"service": "CloudRF https://api.cloudrf.com",
"created_at": "2023-04-12T06:35:40+00:00",
"owner": 1,
"bom_value": 0
},
"site": "Site",
"network": "MOTO",
"engine": 1,
"coordinates": 1,
"transmitter": {
"lat": 51.96403,
"lon": -2.113952,
"alt": 2,
"frq": 700,
"txw": 2,
"bwi": 0.1,
"powerUnit": "W"
},
"receiver": {
"lat": 0,
"lon": 0,
"alt": 1,
"rxg": 2,
"rxs": -100
},
"feeder": {
"flt": 1,
"fll": 0,
"fcc": 0
},
"antenna": {
"mode": "template",
"txg": 2.15,
"txl": 0,
"ant": 39,
"azi": 0,
"tlt": 0,
"hbw": 1,
"vbw": 1,
"fbr": 2.15,
"pol": "v"
},
"model": {
"pm": 10,
"pe": 2,
"ked": 4,
"rel": 70
},
"environment": {
"clt": "Minimal.clt",
"elevation": 1,
"landcover": 1,
"buildings": 1,
"obstacles": 0
},
"output": {
"units": "m",
"col": "LTE.dBm",
"out": 2,
"ber": 1,
"mod": 0,
"nf": -124,
"res": 4,
"rad": 3
}
}
Example GPU ‘line of sight’ template
This template uses the more powerful GPU engine (engine: 1) to model line of sight out to 3km at 2m resolution (if your area of interest has 2m LiDAR).
{
"version": "CloudRF-API-v3.8.2",
"reference": "https://cloudrf.com/documentation/developer/",
"template": {
"name": "LOS_3km_2m_GPU",
"service": "SOOTHSAYER https://185.11.204.106",
"created_at": "2023-05-05T15:43:42+00:00",
"owner": 8,
"bom_value": 0
},
"site": "Site",
"network": "TALON",
"engine": 1,
"coordinates": 1,
"transmitter": {
"lat": 50.806335,
"lon": -1.112032,
"alt": 2,
"frq": 1250,
"txw": 2,
"bwi": 0.1,
"powerUnit": "W"
},
"receiver": {
"lat": 38.913,
"lon": 1.45,
"alt": 1,
"rxg": 2,
"rxs": -90
},
"feeder": {
"flt": 1,
"fll": 0,
"fcc": 0
},
"antenna": {
"mode": "template",
"txg": 2,
"txl": 0,
"ant": 39,
"azi": 0,
"tlt": 0,
"hbw": 1,
"vbw": 1,
"fbr": 2,
"pol": "v"
},
"model": {
"pm": 7,
"pe": 2,
"ked": 0,
"rel": 50
},
"environment": {
"clm": 0,
"cll": 0,
"clt": "Temperate.clt"
},
"output": {
"units": "m",
"col": "GREEN.dBm",
"out": 2,
"ber": 1,
"mod": 0,
"nf": -124,
"res": 2,
"rad": 3
}
}
Template limits
As a server based system, limits for APIs and accounts are set at the server. For premium users this means a 500km / 310Mi radius and a resolution between 1m / 3ft. The combination of these two will determine the resulting file size. The API will automatically reduce unreasonable parameters to fit within memory.
As well as memory, a large layer needs more bandwidth to communicate and is generally not recommended. You should be aiming for smaller layers which can be generated and communicated quickly. You can still do a large radius eg. > 100km, but will need to offset your resolution to keep the total size less than 1 mega pixels (1000 x 1000px).
As a rule of thumb, multiply the radius in km by 2 to get the resolution in metres
The following guide is recommend for practical 1MP ATAK templates:
Desired radius km |
Recommended max resolution m |
---|---|
1 |
2 |
2 |
4 |
5 |
10 |
10 |
20 |
20 |
40 |
50 |
100 |
100 |
200 |
150 |
300 |
Giant airborne calculations
The API can model out to 500km radius for aircraft. If you set 500km as the radius with 100m resolution you are generating a 10k x 10k image measuring 100 mega pixels! This will take a long time to make, a long time to download and then will crash ATAK, and any other Android map for that matter. To do this scale of calculation, use a resolution of 300m which makes a more digestible 11MP image. Better still reduce the radius to the radio horizon which is 357km for an aircraft at 10,000m (33,000ft).
Custom icons
You can insert a small custom icon into a JSON template as a base64 encoded PNG with the “custom_icon” value. The example JSON template below has a name of CUSTOM_ICON with a PNG radio icon and a GPU engine defined at the top level of the template. Keep the PNG images small (~ 48x48px) to keep memory use down.
{
"custom_icon": "",
"template": {
"name": "CUSTOM_ICON",
"service": "CloudRF https://api.cloudrf.com",
"created_at": "2023-09-05T20:40:56+00:00"
},
"site": "Site",
"network": "DTC",
"engine": 1,
...