Skip to content

The following resources are common to all buttons.

Colors

Color can either be expressed by their name, as defined in the Python PILLOW package, or by a tuple of 3 or 4 values, representing red, green, blue, and optionally the transparency.

All values should be in the [0..255] range. For colors, 0 is black, 255 is pure color; for transparency, 0 is transparent, 255 is opaque.

    icon-color: (100, 40, 40, 200)
    label-color: darkorange
    text-color: mediumaquamarine

Named Colors

Named colors are defined at the highest aircraft level. They behave like a placeholder for a color, an alternate name.

Definition

In the main configuration file of the aircraft:

named-colors:
	COCKPIT_BACKGROUND: skyblue
	COCKPIT_NIGHT: slateblue
	HIGHLIGHT: coral

Usage

In a button definition attributes:

label-color: HIGHLIGHT

Number Formatting

Cockpitdecks uses the same convention as python number to text formatting.

Fonts

Font files available to all decks are in the deckconfig/resources/fonts folder.

Font files must be either Truetype fonts (TTF) or Opentype fonts (OTF).

The name of the file is used to designate the font.

Fonts are loaded on start up.

	text-font: DIN Condensed Black.otf

Cockpitdecks comes with a few fonts appropriate for aeronautical use: Standard formal fonts like DIN, fancier fonts like LED fonts, icon fonts like font-awesome and weather-icon.

For Truetype font, it is not necessary to add the .ttf extension. For Opentype fonts it is necessary to add the .otf extension.

About font files.

Fonts placed in the resources/fonts folder are available for images on decks. They are not necessarily available as « web fonts » available in web decks.
To be available directly, not through Cockpitdecks generated images, web decks fonts have to be made available in the asset folder and referenced in proper CSS files.

Cockpitdecks provides the following licensed fonts in its distribution:
- D-DIN (4 variants),
- Overpass, especially Overpass Mono,
- Segment7Standard,
- Split flaps Skyfont and SplitFlap-TV,
- Icon fonts Font Awesome and weathericons.

The following fonts are recommended:
- B612
- DSEG: Original 7-segment and 14-segment fonts

Any Truetype or OpenType font can be added to Cockpitdecks.

Icons

Icon image files available to all decks need to be placed in the deckconfig/resources/icons folder.

Image files must be either JPEG images (JPG, JPEG) or Portable Network Graphic (PNG).

The name of the file is used to designate the icon.

Icons are loaded on start up and optionally cached.

Typical icon size should be (square) 128 to 256 pixels.

Internally, Cockpitdecks use 256 pixel icons. Icons are resized to the deck requested size upon display.

	icon: OFF_WHITE_FRAMED

Sounds

Sounds files can be provided very much like icons. Valid sound file formats are wav and mp3. Other sound file format may be added in the future, provided they can be played in a browser.

Documentation

Documentation of the aircraft decks can be placed in the folder deckconfig/docs or in the folder deckconfig/resources in a textual form (including markdown), or as PDF.

Decks

A particular aircraft allows for definition of particular decks. The deck definition is a special Yaml file that describes the deck capabilities and, optionally, for web decks, the layout of the buttons on the deck.

Please refer to the particular section on Deck Types for details.

Yaml

All configuration files are Yaml formatted. Yaml is simple, structured, and readable.

Yaml is loaded and interpreted by the python Yaml parser. Users must be aware that some keywords are sometimes interpreted by some parser. To prevent this interpretation, keywords should be placed between quotes.

For example:

variable: on

will be interpreted as boolean value true.

variable: "on"

will be interpreted as string on.

The following keywords have been noticeably discovered:

on, off, true, false, yes, no (all mapped to Boolean values True or False).

Cockpitdecks uses a Yaml 1.2 compliant parser (ruamel.yaml) that refuse those interpretation as describe in the Yaml 1.2 specifications.