An overlay is information that is added, i.e., overlayed, on top of each captured Allsky image. This often includes the time the image was taken, the sensor temperature, and the exposure length, but can include any other text or images you want.

Allsky has always had the ability to add text to the captured image but in a very limited way. There a new method to add an overlay. You choose the method via the Overlay Method setting in the WebUI's Allsky Settings page.

  1. The module method has many new features and is significantly more flexible than the older method. For example, you can add an overlay ONLY to the live image but not to saved images. You can also easily add images and text using a drag-and-drop method.
  2. The legacy method allows only text text to be placed in a single location on an image with limited formatting.
    This page focuses on the module method.
The module method is the default and will be the ONLY method in the next version of Allsky.
We suggest you start using this method now.

Features

The module method allows almost any information to be added to the captured Allsky image. Some of the key features of this method include:

  • Overlay Editor - this is the web page for creating and managing overlays and supports:
    • Drag and Drop interface - Fields can be dragged around the screen to position them.
    • Customisable Interface - The Overlay Editor user interface can be highly customised.
    • Font Manager - You can upload any TrueType font and use it in the overlays or use any font already on your Pi.
    • Variable Manager - Provides a library of fields that you can add to the image. You can also add your own fields.
    • Image Manager - Allows you to upload and manage images you wish to add to the image.
  • Text Fields - This allows text to be added to the image.: Key features include:
    • Ability to add any data from Allsky to the image
    • Ability to add custom (extra) data to the image
    • Any TrueType font can be used
    • Text can be any colour or size
    • Text can be rotated
  • Image Fields - This allows images to be added to the image:
    • Any image can be uploaded
    • Images can be scaled and rotated and their opacity changed

How overlays work

The Overlay Editor web page is used to define what information you want on the captured images and where it should go. Once you have specified that information, you won't use the editor again until you want to change something in the overlay, which typically isn't done very often.
The Overlay Module program is invoked every time an image is captured and places the information you specified in the Overlay Editor onto the image. This module is one of several modules that can be invoked after every image is captured.

In order to use the the Overlay Module you must enable it by going to the WebUI and clicking on the Allsky Settings link, then selecting module in the Image Overlay setting. This disables all the remaining settings in the Image overlay settings section; you will specify those items in the Overlay Editor instead.

In the Overlay Editor you specify what information you want to go where, and what it should look like. For example, you want the date and time the image was taken to be in blue, 12 point font in the upper left of the image and a compass rotated 20 degrees so it's pointing north in the upper right of the image. You also have a graph of weather information you want on the bottom of the image, but because it will hide some of the image you want it to be partially transparent.

After Allsky captures an image it passes that image as well as information about the image to the Overlay Module, including the time the image was taken, the exposure length, and the gain. This information is put into System Variables that can be used per you configuration in the Overlay Editor, which then:

  1. Replaces the system variables with their values and adds them to the overlay.
  2. Replaces any other variables with their values and adds them to the overlay.
  3. Adds any images you specified to the overlay.

Fields and Variables

Fields are the heart of the Overlay Editor. They are distinct items that are added to an overlay and each field has its own properties like color, size, rotation, etc. Most people have several fields on their overlays - date and time the image was taken, the exposure length, etc.

Variables are parts of a field whose value is determined when an image is saved. A common variable is ${TIME} which is replaced by the time the image was taken and changes every image. Some variables rarely or never change, for example ${CAMERA_MODEL} displays the model of the camera used to take the image, like "HQ" or "ASI290MM". It only changes if you change cameras.
See the Variable names section for details on variable names.

There are two types of fields:

  1. Text fields contain text and/or variables, for example, Exposure: ${sEXPOSURE}, which adds the word Exposure: followed by the image's exposure time to the overlay.
  2. Image fields contain pictures, graphics, or any image you want and are often used are logos, weather graphs, and compasses.

Variable names:

  • Must begin with a letter a - z or A - Z.
  • The remaining characters may contain any number of letters, number 0 - 9, or the underscore character _.
  • Should be prefixed with a string that's unique to you like your initials, to avoid conflicting with the names of Allsky system variables. This prefix can be anything except AS_ and ALLSKY_.
  • Should make sense to you. You are more likely to remember what ${MY_AMBIENT_TEMP} means than ${MY_AT}.
  • By convention are UPPERCASE, but you can mix case, however, variable names are case-sensitive, so ${MY_ABIENT_TEMP} and ${MY_ABIENT_temp} are different variables.

A variable is a variable name enclosed within ${}, for example, ${sEXPOSURE}.

If you see a variable displayed on the overlay as ??? it usually means the variable is undefined - either it's not in the Variable Manager at all (could be a typo), or is only in the All Variables tab. The variable needs to be defined and copied to the Allsky Variables tab.
Undefined variables will have a line in /var/log/allsky.log like: ERROR: ${T2} has no variable type.

If a variable is displayed as ?? it usually means the variable's formatting is incorrect, for example, you tried to display a number as a date. Make sure the formatting is valid for the type of variable - click on the [?] icon to see valid formats for each type of variable.
Incorrectly formatted variables will have a line in /var/log/allsky.log like: ERROR: Cannot use format '%a' on Number variables like ${GAIN}..

Some example text fields are:

Field Example Output Description
${DATE} 24/10/2023 Displays the date from the DATE system variable. The date can be formatted in a variety of ways.
This example field contains only a variable.
Date: ${DATE} Date: 24/10/2023 Displays the text "Date: " then the date the image was taken from the DATE system variable. As above, the date can be formatted in a variety of ways.
This field contains text and a variable.
Date: ${DATE} ${TIME} Date: 24/10/2023 23:12:34 Displays the date and time the image was taken from the DATE and TIME system variables, respectively. Both variables can be formatted in a variety of ways.
This field contains text and two variables. You can have any number of variables you want.
Date: DATE TIME Date: DATE TIME Because this field doesn't have any variables, it simply displays "Date: DATE TIME".
This field contains only text.

Variables come from a variety of sources:

  1. Allsky - The main Allsky application generates many variables.
  2. Modules - Any module can create variables.
  3. Extra Data - Typically created by an application external to Allsky.

1. Allsky variables

The table below shows the most commonly used Allsky variables; a complete list can be found in the Variable Manager.

Variable Example Data Description
${DATE} 20230228 The date the image was taken.
${TIME} 221623 The time the image was taken.
${GAIN} 4.692540 The gain used for the image. If auto-gain was disabled, this value will be what you set in the Gain setting in the WebUI, otherwise it's the value the auto-gain algorithm used.
${AUTOGAIN} 1 1 if auto-gain was enabled, 0 if disabled. Taken from the Auto-Gain WebUI setting.
${sAUTOGAIN} (auto) A string containing either (auto) if auto-gain was enabled, or blank. Useful to put after the gain, e.g., Gain: ${GAIN} ${sAUTOGAIN}.
${EXPOSURE_US} 218000 The exposure of the image in micro seconds. If auto-exposure was disabled, this value will be what you set in the Manual Exposure setting in the WebUI, otherwise it's the value the auto-exposure algorithm used.
${sEXPOSURE} 218 ms (0.2 sec) The exposure of the image in a human readable format. The format changes depending on the exposure time, for example, very short exposures may be 218.48 ms (0.2 sec) whereas a long exposure may be 45.3 sec.
${AUTOEXPOSURE} 1 1 if auto-exposure was enabled, 0 if auto-exposure was disabled. Taken from the Auto-Exposure WebUI setting.
${sAUTOEXPOSURE} (auto) A string containing either (auto) or blank - similar to ${sAUTOGAIN}.
${TEMPERATURE_C} and ${TEMPERATURE_F} 36 The temperature of the camera sensor, if available. This does NOT include the C or F for Centigrade or Fahrenheit so you'll need to add them yourself, e.g., Sensor Temp: ${TEMPERATURE_C} C.
${MEAN} 0.108564 The mean brightness value for the image. Values for ZWO cameras are from 0 (pure black) to 255 (pure white). Values for RPi cameras are from 0.0 (pure black) to 1.0 (pure white).

2. Module variables

Any module can create variables for use in the Overlay Module. For this reason it's important that the Overlay Module runs as late as possible within the module flow. As an example, the Star Count Module creates a variable called ${STARCOUNT} and passes it to the next module.

Please refer to the documentation on each module for the variables they make available.

3. Extra Data variables - advanced topic

Additional, i.e., "extra" data (text and images) can be added to overlays by defining their attributes in "extra" files.

This is an advanced topic that requires an understanding of the Linux file system and how to manage files within it. The Linux Basics page should provide the understanding you need.

As an example, assume you want to add weather data to your images. You first need to create or obtain a program that gathers that data and writes it to a file. How you obtain that file is outside the scope of this documentation, but the program needs to write the data in a specific format in a file called ~/allsky/config/overlay/extra/xxxxx (replace the xxxxx with an appropriate name).

The "extra" file can be either a simple .txt file or preferably a .json file since it provides much more flexibility. You can have multiple "extra" files with different names; this can be useful if you want to add different types of data to the overlay, and each type has its own program to gather the data. A typical example is weather data and dew heater status.

Dates

When adding dates to any extra data files please ensure that the date is formatted in the same format as the Time Format setting in WebUI

Text Files

Text files must end with a .txt extension. The format is a simple name=value structure, with anything after the = being the value, as shown below:

Line in File Resulting Variable
AG_TEMP=14.3 ${AG_TEMP}
AG_LOCATION=South Pole ${AG_LOCATION}
AG_HUMIDITY=67.2 ${AG_HUMIDITY}

The data in these files could become old if the application creating them fails or is not running. To have Allsky detect this you tell it to ignore "extra" files when they are over a certain age. For .txt files there is a single value which is specified in the Overlay Editor settings dialog box. See the next section for how to specify the expiration time for .json files.

JSON Files

.json files are more complex in their structure but provide a lot more flexibility to add your own variables and even control the attributes of a field.

The .json file below will produce exactly the same variables as the .txt file described above. The data will expire as defined in the Overlay Editor settings dialog box. This .json file includes an expiry time (in seconds) for the temperature and humidity, which change often, so those times will be used. The location doesn't specify an expiry time since the location never changes, so the one in the Overlay Editor dialog expiry setting will be used. This .json file, which has been truncated for brevity, includes all of the attributes that a field can set. It also adds an image.
{
"AG_TEMP": {
"value": "14.3"
},
"AG_LOCATION": {
"value": "South Pole",
},
"AG_HUMIDITY": {
"value": "67.2",
},
}
{
"AG_TEMP": {
"value": "14.3",
"expires": 600
},
"AG_LOCATION": {
"value": "South Pole",
},
"AG_HUMIDITY": {
"value": "67.2",
"expires": 600,
},
}
{
"AG_TEMP": {
"value": "14.3",
"format": "{:.0f}",
"x": 800,
"y": 200,
"fill": "#333333",
"font": "ledsled",
"fontsize": 40,
"opacity": 0.2,
"stroke": "#000000",
"strokewidth": 1,
},
"AG_SCOPE": {
"image": "crosshair.png",
"x": 300,
"y": 400,
"scale": 0.1,
"expires": 6000,
"opacity": 0.5
}
}
A note on the expires field:
  • Instead of specifying an expiry time on two variables and not the third one as shown above, you could instead specify a value for the third field and use the Overlay Editor default expiry setting for the other two. This works well if you only have one "extra" file.
  • If you have multiple "extra" files it's probably best to specify an expiry time for ALL fields in all files, rather than using the Overlay Editor default expiry setting for fields that don't explicity set one. If a field shouldn't have an expiry time, use "expires": 0, which disables its expiry time.
This example demonstrates some important points:
  • The attributes of a variable can be used to control how the variable appears, so for example if the temperature is close to the dew point then some text could be displayed in a highlighted colour. Note that this makes the variable a 'Field' and can only be used where a single variable is used within a field.
  • Images can by dynamically added to the captured image. So if you wanted to control when an image is added or not added, the program that creates the "extra" file can simply add the image's json code, or not add it, to the file.

The "extra" files must be created by an application you provide and there are a few things to consider when creating these files:

  • Variable names must be prefixed with a string that's unique to you, e.g., your initials, to avoid conflicting with the names of Allsky variables. The variables in the examples above are prefixed with AG_. You can use anything except AS_ and ALLSKY_.
  • Variable values should generally not include units of measure. For example ${DOME_TEMPERATURE} should be 20.72, not 20.72° C because 20.72 is a "Numeric" variable that can be formated (e.g., to 20.7) whereas 20.72° C is a "Text" string that can't be formatted. If you want ° C to appear on the overlay, add it in the field itself: Dome temperature: ${DOME_TEMPERATURE}° C.
    Note that ° adds the degree symbol °.
  • Permissions - You must ensure that the "extra" files can be read by the web server. Adding chmod 644 file ... to the programs that create the files should suffice. The Overlay Module will silently ignore any files it cannot read.

The Overlay Editor User Interface

The Overlay Editor web page consists of two key areas:

  1. The toolbar contains icons that perform actions or bring up dialog boxes.
  2. The working area contains the overlay and the current image in the background.
NOTE: The Overlay Editor will only start if Allsky is capturing images. If Allsky is not capturing a warning is displayed and the Overlay Editor will wait until Allsky start capturing.
New fields are initially added to the upper left corner of the overlay but can be moved anywhere you want - just drag and drop!
If you added a field by mistake, delete it by clicking on the icon (4) before doing anything else.

Here is a typical top portion of the editor, with numbers added to identify the icons:

The Main Overlay Window
Annotation Icon Description
1 Save The Current Configuration

This is enabled and turns green when any changes have been made that require saving. The word "Modified" is also appended to the tab label, i.e., "Overlay Editor - Modified".

This icon is only enabled when leaving certain fields. For example if you change a field label you must click out of the field before this icon will be enabled.
2 Add New Text Field

Click to add a new field with text and/or variables to the overlay.

3 Add Existing Image Field

Click to add an existing image to the overlay. The image must have previously been uploaded using the Image Manager.

4 Delete The Selected Field

Click to delete the selected field. The "del" or "delete" keys on the keyboard can also be used. The icon is only enable turns green when a field is selected.

5 Variable Manager

Click to add a pre-defined field from the Variable Manager. See the Variable Manager section for more details.

6 Display Sample Data

Click to display sample data in each of the fields. This is useful to see what actual data will look like on the overlay so you can better align fields.

7 Zoom In

Click to zoom in on the image.

8 Zoom Out

Click to zoom out of the image.

9 View Full Size

Click to zoom to the full size of the image.

10 Fit to Window

Click to zoom to fit the image on the screen.

11 Overlay Manager

Displays the Overlay Manager.

12 Field Errors

Only displayed if any fields are detected that are off the screen. Selecting this icon will display a dialog allowing the off-screen fields to be deleted or fixed. Fixing the field will move it into the visible portion of the overlay editor allowing you to move it to the exact position required.

13 Font Manager

Displays the Font Manager. See the Font Manager section for more details.

14 Image Manager

Displays the Image Manager. See the Image Manager section for more details.

15 Layout and App Options

Displays the Overlay Editor settings dialog which allows you to change settings of the manager itself. See the Overlay Editor Settings section for more details.

16 Working Area

The main working area. The image displayed is the last one captured by Allsky.

It's best to create overlays when Allsky is running since you'll see the latest image. You can create overlays when Allsky is not running but in mind that Notification images (e.g., "Allsky is starting") are usually smaller than those captured by your camera so you may not be using all of the available screen area.

Ideally you will create overlays after you've set any resize and crop options and the captured image's size is finalized.


Using The Overlay Editor

This sub-section details the basic operation of the Overlay Editor and how to manage fields and their contents.

The Overlay Manager  

The Overlay Manager is used to create and enable overlays for day and nighttime capture.

The Overlay Manager comes pre installed with several overlays for common cameras. The Allsky team maintain these overlays. During installation the most appropriate overlay for your camera will have been selected, the Overlay Manager allows you to use these overlays or create a new one.

The Allsky maintained overlays cannot be edited, you must create a new overlay if you wish to edit it. The new overlay can be copied from any exising overlay
During an upgrade from a previous version of Allsky the Module Manager will attempt to convert any of your customised overlays into the module manager format
The Main Overlay Manager Window

The Overlay Manager

To open the Overlay Manager select the icon from the main toolbar

The Main Overlay Manager Window

The Overlay Manager main tab

1 Overlay Selects the main overlay manager tab

2 Config Displays the tab to allow overlays to be activated

3 Overlay Selects the overlay to display/edit. When selecting an overlay the overlay will be displayed in the main overlay editor If you select an overlay that cannot be edited then a warning is displayed in the main overlay editor Overlay Manager Warning

4 Add Overlay Adds a new overlay

5 Delete Overlay Deletes an overlay. NOTE: Allsky maintained overlays cannot be deleted

The remaining options on the Overlay Manager apply to the currently selected overlay, selected in 3

When making any changes in this section you must use the main save button on the Overlay Editor toolbar, this will be highlighted in green if there are any changes to save

6 Overlay Name The name of the overlay, this is used to identify the overlay in a human readable format

7 Overlay Description The name of the overlay description

8 Camera Brand The camera brand the overlay applies to

9 Camera Model The camera model the overlay applies to

10 Image Width The width of the captured image, after any cropping

11 Image Height The height of the captured image, after any cropping

12 Available For The Time of Day the overlay should be used for

The Main Overlay Manager Window

The Overlay Manager options tab

1 Daytime Overlay Selects the overlay to use when capturing daytime images

2 Nightime Overlay Selects the overlay to use when capturing nightime images

Selecting an overlay for Day/Night time capture

To select the overlays to use open the Overlay Manager and switch to the Options Tab. Here you can select the appropriate overlay to use.

Overlays can be limited to daytime, nighttime capture ot both. Only the available overlays for day / nighttime capture will be displayed in the drop downs

Creating a new overlay

To create a new overlay click the icon (4). A new dialog will be displayed allowing you to create the new overly.

The Main Overlay Add Window

1 Select Template Selects the overlay you wish to use as a starting point or select 'Blank Overlay' for an empty overlay

2 Name Enter a Human Readable name for the overlay

3 Description Enter a Human Readable name for the overlay

4 Available For Select the time of day you wish this overlay to be used in

5 Activate After Creation If selected then the overlay will be activated after it has been created. If not selected the overlay will be saved as a draft and you will have to manually activate it.

By default when an overlay is created it is activated for day/night or both as defined by the 'Available For' dropdown. If you DO NOT want the overlay to be activated by default then select 'No' in the 'Activate After Creation' option.
The Main Overlay Add Advanced Window
You will only need to make changes on this tab if you are creating an empty overlay. If you are copying an existing overlay then all of the fields will be defaulted from the copied overlay.

1 Filename This is for informatio only and is the filename of the overlay that will be used to store it on the Pi

2 Camera Brand The camera brand the overlay applies to

3 Camera Model The camera model the overlay applies to

4 Image Width The width of image the overlay applies to. This will default to the width of the last captured image

5 Image Height The height of image the overlay applies to. This will default to the width of the last captured image

Once you have completed the required fields in the dialog select the 'Ok' button and the new overlay will be displayed allowing you to edit it.

Deleting an overlay

To delete an overlay select the required overlay and click the delete buttton.

NOTE: You cannot delete an overlay if it is currenty active. You must activate another overlay before deleting it.

The Variable Manager  

The Variable Manager is used to store variables and text that can be used in fields.

The Variable Manager provides a quick method for storing details of the available variables and adding them to the overlay. The manager comes preinstalled with a set of system variables that can be modified but not deleted. You can also add your own variables to the manager; typically these will come from modules or "extra" data files.

The manager consists of two tabs:

  1. The Allsky Variables tab contains the variables that have been defined and hence can be added to the overlay.
  2. The All Variables tab contains all variables including ones that have not been defined and hence cannot be added to the overlay.

Allsky Variables tab

Variable Manager
  • The icon adds the associated variable in a new text field to the overlay. The Text Properties dialog box will also be displayed and populated with the relevant data for the variable.
  • The icon edits the variable. If the variable is a system variable then only certain fields can be changed.
  • The icon deletes a variable. You can only delete variables that you added; there are none shown in the screenshot above.

The Add Variable brings up the "Add Variable" dialog box that allows you to add your own variable and set the variable's Type and other attributes.

This button does NOT add the variable to the overlay; instead, it adds it to the end of the Allsky Variables list so it can be added to the overlay.

The search option in the top right can be used to quickly search for a variable by name. Searches are not case sensitive.


All Variables tab

Variable Manager All

This tab lists every variable that Allsky can see and the last value it had, if any. These variables only have a Name as well as possibly their last value. They are not yet defined, i.e., they have no attributes like data Type, Description, Format, or Sample Data.

  • Click the icon to define the variable's attributes and then add the variable to the Allsky Variables tab making it available for use on overlays. Note that doing this does not put the variable on the overlay - it just makes it available to be put on the overlay.
  • If this button is disabled then the variable is already in the Allsky Variables tab.

The Add Variable button does the same thing as the same button in the Allsky Variables tab.


The "Add Variable" and "Edit Variable" dialog boxes

Clicking on the Add Variable button or the icon above brings up a dialog box to add or edit a variable. It's the same dialog box in either case, just with a different title. Editing a System Variable will display a message as shown in the image below.

Edit variable
  • Variable Name - The name of the variable enclosed within ${}. Allsky variables' names cannot be changed. See the Variable names section for details on valid variable names.
  • Description - A description of the variable. This is only for reference and is displayed in the Variable Manager.
  • Format - The optional formatting used to display the variable.
  • Sample Data - Sample data that is used when displaying sample data in the Overlay Editor.
  • Type - Each variable has a type that is used to determine what formatting to use. The variable types are:
    • Date - A variable that holds a date
    • Time - A variable that holds a time
    • Number - A number with, or without a decimal point
    • Text - Any string of characters
    • Bool - A variable that holds a boolean value - on/off, yes/no, true/false.

The Font Manager  

The Font Manager supports all mainstream browser fonts and allows you to upload any TrueType font for use in text fields.

Font Manager

1 Installed Fonts - Lists all the fonts that can be used. System Fonts are marked as such in the Path column.

2 Delete Button - Deletes a font.

It is not possible to delete a System Font and they will not have a delete icon as shown for the first several fonts above.
If a font is in use when deleted then any fields using the font will revert to the default font as specified in the overlay settings.

3 Use/Delete Button - Enables the font for use in this overlay or removes it from the overlay

4 The Add Font button adds a font from daFont.com by entering a URL. See below.

5 The Upload Font button uploads a zip file to install fonts. See below.

To use a font it must first be installed in the Font Manager and there are two ways to do this:

  1. Add font from daFont.com
    In a separate browser window, navigate to the font page on daFont.com that you wish to install, for example www.dafont.com/led-sled.font. Copy the font URL to the clipboard. Click the Add Font button and enter the font URL. The font will be installed and the installed fonts list 1 refreshed.
  2. Upload font via a zip file
    First ensure that the font(s) you wish to installed are contained within a zip file. You can create the zip file yourself or download from a place like fonts.google.com/. Click the Upload Font button and browse to the zip file. The fonts will be extracted from the zip file and installed.

    NOTE: If you receive an error when uploading a font please check the php max file upload size. By default this is 2 MB which may be too small for some font zip files

    The php configuration file is normally /etc/php/8.2/cgi/php.ini but will vary depending upon the version of php you have install. Edit this file and locate the line containing upload_max_filesize = and change the value. So if the exiting line says upload_max_filesize = 2MB change it to upload_max_filesize = 20MB

    Following this change restart the web server:
    sudo systemctl restart lighttpd

The Image Manager  

The Image Manager allows you to upload images for use on overlays. Allsky comes with several basic images.

Image Manager
  • 1     Add Selected Image - Adds the selected image to the overlay. The selected image has a red border like the 3rd image above.
  • 2     Delete The Selected Image - Deletes the selected image from the overlay. Images that are grayed out like the 4th one above are in use in an overlay and cannot be deleted.
    When deleting an image it will also be deleted from the Pi. If you want the image to remain on the Pi, select its field in the Overlay Editor and delete it.
  • 3   Uploaded images area - Previously uploaded images that can be selected. Not all images need to be used on an overlay.
  • 4   File upload area - Either click on this area to upload a new image or drag an image onto it.

Adding fields to the overlay

There are three ways to add fields to the overlay, two for text fields and one for images.

  1. Add a new text field
    Click the Add New Text Field icon () on the toolbar to display the Text Properties editor. Enter text and/or variables in the Item field of the editor, and set its properties as desired. The property editors are described below.
  2. Add a pre-defined variable in a new field
    Click the Variable Manager icon () to display the Allsky Variables list which contains variables you can add to the overlay by clicking the button. The field will start off with just the variable you selected; you can add text or other variables to the field later. See the Variable Manager section for information on the All Variables tab in the Variable Manager.
  3. Add a pre-defined image in a new field
    Click the Add Existing Image Field icon () to display the Image Properties editor. Select the image you want from the drop down and then move it to the overlay, resizing and rotating as required. The image must have first been uploaded via the Image Manager as described above.
Before a field can be displayed it MUST be defined in the 'Allsky Variables' tab. If the field is not defined in this tab then it will not be displayed by the overlay manager

The property editors

The property editors allow modifying properties of text and image fields.

Text Properties Editor

Text Properties Editor
The properties in this editor are:
  • Item - The text for the field, including any variables.
  • Format - Certain variable types allow for formatting, including dates, times, numbers, and booleans. Details of the formats that can be entered are covered in the formatting text section and can also be viewed by clicking on the [?] icon.
  • Sample - A value that is displayed when the "Display Sample Data" icon () is selected. This property is useful if the variables in the field do not have inbuilt sample values.
    If there are multiple variables in the field you can have multiple Sample values by separating them by commas or enclosing each Sample in { }. See the screenshot above for an example of separating by commas.
  • Empty Value - By default, if ALL the variables in a field have no value then the the field is not displayed. However, if this property has something in it then the whole field is displayed with the empty variable(s) replaced by this property.
    If there are multiple variables in the field you can have multiple Empty Values by separating them by commas or enclosing each Empty Value in { }. See the screenshot above for an example of separating by braces.
    If a field doesn't appear on the overlay and you're not sure why, look in /var/log/allsky.log for messages like Adding text field T1: ${T1} failed no variable data available
  • X - The 'x' position of the field in pixels from the left of the image. If setting manually you need to take into account the width of the field and the resolution of the image so it doesn't go off the right side.
  • Y - The 'y' position of the field in pixels from the top of the image. If setting manually you need to take into account the height of the field and the resolution of the image so it doesn't go off the bottom of the captured image.
  • Rotation - The rotation of the text in degrees, from 0 to 360. Increasing numbers rotate the field clock wise.
  • Name - The font to use for the field.
  • Size - The font size.
  • Opacity - The font opacity, from 0 (transparent) to 1 (opaque).
  • Colour - The font colour.
  • Stroke Size - The size in pixels for applying a stroke to the field. A stroke can be useful to distinguish the text from the background. Setting to 0 disables the stroke.
  • Stroke Colour - The stroke colour to use for the font.
When using "extra" files in JSON format all of the attributes above can be overridden in the file allowing for external control of how fields appear. For example, you may want the CPU temperature to turn red if it gets too hot.

Image Properties Editor

Image Properties Editor
The properties in this editor are:
  • Image - Select the image to add from the dropdown. Images will only appear in the drop down after they have been added via the Image Manager.
  • X - The 'x' position of the field in pixels from the left of the captured image. If setting manually you need to take into account the width of the image and resolution of the captured image so it doesn't go off the right side.
  • Y - The 'y' position of the field in pixels from the top of the captured image. If setting manually you need to take into account the height of the image and resolution of the captured image so it doesn't go off the bottom of the captured image.
  • Rotation - The rotation of the image in degrees, from 0 to 360. Increasing numbers rotate the image clock wise.
  • Opacity - The image opacity, from 0 (transparent) to 1 (opaque).
  • Scale - Allows the image to be scaled and resized, from 0 (image hidden) to 10 times the native resolution. Images that are scaled a lot can look jagged and you may want to consider getting a higher-resolution version.

Formatting Variables

Date, Time, Number, and Boolean fields can be formatted to alter their appearance. Each field type has a different set of codes for formatting.

Properties Help

The tables below show the more common formats that can be used. A more detailed and up-to-date list can be found by clicking on the help icon ([?]) in the Text Properties dialog box to view the window below. After you have set a format click the "Display Sample Data" icon on the toolbbar to show the formatted result.

Whilst the Overlay Editor is displaying sample data, changing the Format field will update the sample.

The number formats are based upon the formating options available in python.

Formats Help

Clicking the help icon shown above will display the "Format Help" window. This window can be moved around the screen as required. If you close the properties dialog then the formats window will automatically be hidden.

  • 1 - Selecting an entry will display the available formats for that variable type.
  • 2 - These buttons are used to amend the variable's format:
    •   This button replaces the format on the current field with the selected format. This is most useful when working with number formats.
    •   This button appends the selected format to the format field. This is most useful when working with date formats.

Bool formats

Format Description Output Format
%yes Outputs "Yes" if the variable is equal to 1, otherwise "No". Yes
%on Outputs "On" if the variable is equal to 1, otherwise "Off". Yes
%true Outputs "True" if the variable is equal to 1, otherwise "False". Yes
%1 Outputs "1" if the variable is equal to 1, otherwise "0". Yes
Bool formats must be lowercase.

Date and Time formats

Format Description Output Format
%a Abbreviated weekday name. Sun, Mon, ...
%A Full weekday name. Sunday, Monday, ...
%w Weekday as a decimal number. 0, 1, ..., 6
%d Day of the month as a zero added decimal. 01, 02, ..., 31
%-d Day of the month as a decimal number. 1, 2, ..., 31
%b Abbreviated month name. Jan, Feb, ..., Dec
%B Full month name. January, February, ...
%m Month as a zero added decimal number. 01, 02, ..., 12
%-m Month as a decimal number. 1, 2, ..., 12
%y Year without century as a zero added decimal number. 00, 01, ..., 99
%-y Year without century as a decimal number. 0, 1, ..., 99
%Y Year with century as a decimal number. 2013, 2019 etc.
%H Hour (24-hour clock) as a zero added decimal number. 00, 01, ..., 23
%-H Hour (24-hour clock) as a decimal number. 0, 1, ..., 23
%I Hour (12-hour clock) as a zero added decimal number. 01, 02, ..., 12
%-I Hour (12-hour clock) as a decimal number. 1, 2, ..., 12
%p Locale's AM or PM. AM, PM
%M Minute as a zero added decimal number. 00, 01, ..., 59
%-M Minute as a decimal number. 0, 1, ..., 59
%S Second as a zero added decimal number. 00, 01, ..., 59
%-S Second as a decimal number. 0, 1, ..., 59
%f Microsecond as a decimal number, zero added on the left. Please note that Allsky's times are only to the nearest second. 000000 ... 999999
%z UTC offset in the form +HHMM or -HHMM. +0100
%Z Time zone name. Europe/London
%j Day of the year as a zero added decimal number. 001, 002, ..., 366
%-j Day of the year as a decimal number. 1, 2, ..., 366
%U Week number of the year (Sunday as the first day of the week). All days in a new year preceding the first Sunday are considered to be in week 0. 00, 01, ..., 53
%W Week number of the year (Monday as the first day of the week). All days in a new year preceding the first Monday are considered to be in week 0. 00, 01, ..., 53

Number formats

Format Description Output Format
{:.0f} Formats a number to 0 decimal places. 2
{:.1f} Formats a number to 1 decimal places. Other numbers can be used as well, such as 2, 3, ... 2.0
{:,} Use comma for thousands separator. 86,000
{:n} Use locale for thousands separator. 86.000

Field FAQ's

Answers to some common issues with overlays and fields.

Fields have been added to the overlay but are not appearing, the same set of fields appear no matter what changes are mode in the Overlay Manager Please ensure that the overlay method is set to 'module' in the main Allsky settings
No overlays are added Please ensure that the overlay module has been added to the relevant flow, day or night and that its enabled
I have added a field but its not appearing There are several possible reasons for this
  • The field is not in the 'Allsky Variables' tab. Please ensure that the variable has been added
  • There is no data available for the field. This is most likely due to an external data file not being available. The Allsky debug logs, see below, will contain a warning if this is the case
  • There is a problem with the formatting options for a field. The Allsky debug logs, see below, will contain a warning if this is the case
The 'Field Errors' toobar icon is pulsing red. This means that the Overlay Manager has detected fields that are outside of the image. Clicking the button will allow you to move the fields into the image and then reposition them as rquired.

Checking the Allsky debug log

If you need to look for issue in the Allsky log then first set the debug level to 4 in the main Allsky settings. After Allsky has restrted the logfile can be found in /var/log/allsky.log

Its is not recommend to leave the debug level set to 4 for any extended period of time unlessed asked to do so by the Allsky Team

Layout and App Options  

Clicking on the Layout and App Options icon in the toolbar brings up the Overlay Editor Options dialog box to manage settings for overlays and the Overlay Editor itself. The dialog box has two tabs, as detailed below.

Layout Defaults tab

These settings apply to overlay layouts.

Layout Settings

1 Default Image Opacity - The default opacity for new images.

2 Default Image Rotation- The default rotation for new images.

3 Default Font - The default font for new text fields.

4 Default Font Size - The default font size for new text fields.

5 Default Font Opacity - The default font opacity for new text fields.

6 Default Font Colour - The default font color for new text fields.

7 Default Text Rotation - The default rotation for new text fields.

8 Default Stroke Colour - The default colour used for the font stroke.

9 Default Extra Data Expiry - The default expiration time in seconds for "extra" data files that do not specify an expiry time. This applies to all variables in .txt files and entries in .json files that don't have an "expires" attribute.

10 Expiry Text - The default text used when a field has expired.

11 Norad ID's - A comma-separated list of NORAD IDs for generating satellite data.

12 Include Planets - When enabled, data for the planets' positions will be generated as variables.

12 Include Sun - When enabled, data for the Sun's position will be generated as variables.

14 Include Moon - When enabled, data for the Moon's position will be generated as variables.

The Norad satellite and Planet options can be CPU intensive and are disabled by default. When enabling these please use the Module Manager's "Debug Mode" to ensure these settings are not causing an issue with the performance of the image capture process. Details of how to use the Module Manager's "Debug Mode" are covered in the Module Manager page.

Editor Settings tab

The editor settings apply to the Overlay Editor.

Editor Settings

1 Show Grid - When enabled, displays a grid for easier alignment of fields on the overlay. The grid is used to 'snap' fields making their placement easier.

2 Grid Size - The size of the grid in pixels.

3 Grid Colour - The colour to use for the grid.

4 Grid Brightness - The grid brightness. Values range from 0 (lowest brightness) to 100 (brightest).

5 Show Snap Rectangle - When enabled, moving a field will cause a rectangle to be displayed showing where the field will snap to if dropped.

6 Add List Page Size - The number of variables to show per page in the Variable Manager.

7 Add Field Brightness - When adding a new field all other fields will be set to this brightness to make the new field easier to see. Values range from 0 (darkest) to 100 (each field's full brightness).

8 Select Field Brightness - When selecting a field all other fields will be set to this opacity to make the new field easier to see. Values range from 0 (darkest) to 100 (each field's full brightness).

9 Zoom with Mouse Wheel - When enabled, scrolling the mouse wheel will zoom the overlay.

10 Background Image Brightness - Brightness of the captured image being overlayed. Lower this if the captured image is bright to make it easier to see the overlay fields. Values range from 0 (black background) to 100 (full brightness of captured image).

When changing the brightness settings you may need to click somewhere in the overlay in order for the change to take affect.

Editor Settings Overlays tab

The editor settings Overlay displays available overlays and allows them to be viewed or edited.

Editor Settings Overlays

1 Available Overlays - Displays a table showing all of the overlays available.

2 View Overlay - This icon is displayed when the overlay is not editable, these are overlays provided by the Allsky team. Clicking the button will view the overlay but not allow it to be edited

3 Edit Overlay - This icon is displayed when the overlay is editable. Clicking the button will view the overlay and allow it to be edited

When changing the brightness settings you may need to click somewhere in the overlay in order for the change to take affect.


Sun / Moon / Planets / Satellites

The Overlay Module can generate data for celestial bodies. All calculations are based upon the Latitude and Longitude in the WebUI.

Because creating this data is CPU intensive, satellite data is only created if at least one entry is in the NORAD ID setting in the Layout Defaults tab of the Overlay Editor Options window, or for the Sun, Moon, and planets, if their associated Include checkboxes are selected in that same window.
Sun, Moon, and ISS variables always appear in the Layout Defaults tab of the Overlay Editor Options window, even if their associated Include checkboxes are NOT selected. Their values will not appear in the overlay until the checkboxes are enabled.

The Sun

Various data are generated for sunrise/sunset etc. All Sun times during daytime capture are for the current day. During nighttime capture:

  • Before midnight, the sunset times are for the current date and the sunrise times are for the next date.
  • After midnight the sunset times are for the prior date and the sunrise times are for the current date.

The following Sun-related variables are available in the Variable Manager:

Variable Description
${SUN_DAWN} The date and time of dawn.
${SUN_SUNRISE} The date and time of sunrise.
${SUN_NOON} The date and time of noon.
${SUN_SUNSET} The date and time sunset ends.
${SUN_DUSK} The date and time of dusk.
${SUN_AZIMUTH} The Azimuth of the Sun.
${SUN_ELEVATION} The Elevation of the Sun.

All times are formatted using the format specified in the Time Format setting in the WebUI. This format can be overriden in the Date Time format field of the Overlay Module settings in the Module Manager.
See the screenshot below for this field.

Overlay Module settings

The Moon

The following Moon-related variables are available in the Variable Manager:

Variable Example Value Description
${MOON_ELEVATION} -24.65 Elevation of the Moon in degrees.
${MOON_AZIMUTH} 262 Azimuth of the Moon in degrees.
${MOON_ILLUMINATION} 7.3 Illumination of the Moon in %.
${MOON_SYMBOL} Using this variable in the "moon_phases" font will display a symbol of the current phase of the Moon.

The planets

The following planet-related variables are available in the Variable Manager:

Variable Example Value Description
${MERCURYALT} -27deg 06' 55.2" The altitude of Mercury in degrees.
${MERCURYAZ} 292deg 07' 41.6" The azimuth of Mercury.
${MERCURYVISIBLE} No Yes/No to indicate if Mercury is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${VENUSALT} -25deg 03' 52.8" The altitude of Venus in degrees.
${VENUSAZ} 282deg 23' 21.9" The azimuth of Venus.
${VENUSVISIBLE} No Yes/No to indicate if Venus is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${MARSALT} 03deg 56' 06.7" The altitude of Mars in degrees.
${MARSAZ} 55deg 12' 53.7" The azimuth of Mars.
${MARSVISIBLE} Yes Yes/No to indicate if Mars is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${JUPITERALT} 29deg 49' 30.9" The altitude of Jupiter in degrees.
${JUPITERAZ} 142deg 19' 20.8" The Azimuth of Jupiter.
${JUPITERVISIBLE} Yes Yes/No to indicate if Jupiter is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${SATURNALT} 20deg 50' 21.6" The altitude of Saturn in degrees.
${SATURNAZ} 187deg 21' 15.3" The Azimuth of Saturn.
${SATURNVISIBLE} Yes Yes/No to indicate if Saturn is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${URANUSALT} 21deg 21' 51.3" The altitude of Uranus in degrees.
${URANUSAZ} 90deg 10' 23.5" The azimuth of Uranus.
${URANUSVISIBLE} Yes Yes/No to indicate if Uranus is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${NEPTUNEALT} 29deg 43' 44.2" The altitude of Neptune in degrees.
${NEPTUNEAZ} 150deg 24' 55.8" The azimuth of Neptune.
${NEPTUNEVISIBLE} Yes Yes/No to indicate if Neptune is visible. This does NOT mean its visible to the naked eye just that its above the horizon.
${PLUTOALT} 10deg 07' 14.9" The altitude of Pluto in degrees.
${PLUTOAZ} 207deg 49' 18.1" The azimuth of Pluto.
${PLUTOVISIBLE} Yes Yes/No to indicate if Pluto is visible. This does NOT mean its visible to the naked eye just that its above the horizon.

Satellites (including the ISS and Hubble)

The Overlay Module can generate position elements for the International Space Station (ISS), the Hubble Space Telescope, and other satellites if their NORID IDs are entered in the Overlay Editor's Norad IDs setting. IDs must be comma-separated.

To find NORAD IDs browse to the Celestrak website and search for the desired objects.

Satellite Settings

This example has two Norad IDs:

  • 25544 - The International Space Station.
  • 20580 - The Hubble Space telescope.

This will generate the following variables that can be used in overlays. Other NORAD IDs would produce similar variables starting with IDs.

Variable Example Value Description
${25544ALT} -32deg 41' 34.3" The Altitude of the ISS in Degrees.
${25544AZ} 58deg 46' 59.3" The Azimuth of the ISS in Degrees.
${25544VISIBLE} No Yes/No to indicate if the ISS is above the horizon (it may or may not be visible to the naked eye).
${20580ALT} -32deg 41' 34.3" The Altitude of the Hubble in Degrees.
${20580AZ} 58deg 46' 59.3" The Azimuth of the Hubble in Degrees.
${20580VISIBLE} No Yes/No to indicate if the Hubble is above the horizon (it may or may not be visible to the naked eye).