Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| en:dev:tailcontrol-command-protocol [2025/10/19 14:28] – [Automatic Actions] darkgrue | en:dev:tailcontrol-command-protocol [2025/11/04 16:46] (current) – darkgrue | ||
|---|---|---|---|
| Line 9: | Line 9: | ||
| **IMPORTANT NOTICE:** TailControl and the TailControl Protocol is still under development. Some commands and features described here relate to a future release and are subject to change. | **IMPORTANT NOTICE:** TailControl and the TailControl Protocol is still under development. Some commands and features described here relate to a future release and are subject to change. | ||
| </ | </ | ||
| + | |||
| ===== Bluetooth Low Energy (BLE) ===== | ===== Bluetooth Low Energy (BLE) ===== | ||
| Line 46: | Line 47: | ||
| For tail-series (MiTail, MiTail Mini, and FlutterWings) v3.6 controller hardware, the battery charging characteristic is unset (charging state is not available). | For tail-series (MiTail, MiTail Mini, and FlutterWings) v3.6 controller hardware, the battery charging characteristic is unset (charging state is not available). | ||
| </ | </ | ||
| + | |||
| ===== TailControl Device Indicators ===== | ===== TailControl Device Indicators ===== | ||
| + | |||
| ==== Blue LED ==== | ==== Blue LED ==== | ||
| Line 60: | Line 63: | ||
| - **Blink fast three times** when the button is held for more than 3 seconds (but less than 13), indicates the device is ready to power off when the button is released. | - **Blink fast three times** when the button is held for more than 3 seconds (but less than 13), indicates the device is ready to power off when the button is released. | ||
| - **Blink fast continuously** when the button is held for more than 13 seconds, indicates the device is ready to factory reset when the button is released. | - **Blink fast continuously** when the button is held for more than 13 seconds, indicates the device is ready to factory reset when the button is released. | ||
| + | |||
| ==== Red LED ==== | ==== Red LED ==== | ||
| Line 81: | Line 85: | ||
| **Note:** Unlike the DIGITAiL, MiTail, MiTail Mini, and FlutterWings devices **can** be used while charging. | **Note:** Unlike the DIGITAiL, MiTail, MiTail Mini, and FlutterWings devices **can** be used while charging. | ||
| + | |||
| ==== Green LED ==== | ==== Green LED ==== | ||
| Line 95: | Line 100: | ||
| ==== Automatic Actions ==== | ==== Automatic Actions ==== | ||
| - | TailControl will automatically shut down the device if there is no BLE connection for `currConfig.minsToSleep` (default 0) minutes. This behavior is suspended if a PD-capable adapter is attached (to allow for charging and/or operating from a external battery) **OR** if the firmware is compiled with a compile-time option to disable the timer (to facilitate wired serial console control where BLE connectivity is not used). | + | TailControl will automatically shut down the device if there is no BLE connection for '' |
| Additional automatic actions are described in [[en: | Additional automatic actions are described in [[en: | ||
| Line 156: | Line 161: | ||
| | **STOPTILT** (or **ENDTILTMODE**) | Stops Tilt Mode ([[#Tilt Mode|see below]]), returns '' | | **STOPTILT** (or **ENDTILTMODE**) | Stops Tilt Mode ([[#Tilt Mode|see below]]), returns '' | ||
| | **TILTMODE** (or **TILTMODE START**) | Starts Tilt Mode ([[#Tilt Mode|see below]]), returns '' | | **TILTMODE** (or **TILTMODE START**) | Starts Tilt Mode ([[#Tilt Mode|see below]]), returns '' | ||
| + | |||
| ===== RGB LED Commands ===== | ===== RGB LED Commands ===== | ||
| Line 169: | Line 175: | ||
| | **RGBTST** | **RGB** **TE**s**T**; | | **RGBTST** | **RGB** **TE**s**T**; | ||
| | **SETRGB** | **SET** **RGB** configuration; | | **SETRGB** | **SET** **RGB** configuration; | ||
| + | |||
| ===== Other Commands ===== | ===== Other Commands ===== | ||
| Line 195: | Line 202: | ||
| | **UNSETHOLDONSTOP** | **UNSET** servo **HOLD** when the servos **STOP** (servo PWM is dropped when not moving, default for tail-based devices); returns '' | | **UNSETHOLDONSTOP** | **UNSET** servo **HOLD** when the servos **STOP** (servo PWM is dropped when not moving, default for tail-based devices); returns '' | ||
| | **SETHOME** | **SET** **HOME** position (0 through 8) for each servo (e.g., '' | | **SETHOME** | **SET** **HOME** position (0 through 8) for each servo (e.g., '' | ||
| + | | **SETLISTENMOVES** | **SET** internal **LISTEN** Mode **MOVES** to play on a listen event in addition to sending event notifications; | ||
| + | | **UNSETLISTENMOVES** | **UNSET** internal **LISTEN** Mode **MOVES** to play on a listen event, only an event notification will be sent and it is the responsibility of the connected application to send commands to react to events; returns '' | ||
| + | | **SETTILTMOVES** | **SET** internal **LISTEN** Mode **MOVES** to play on a tilt event in addition to sending event notifications; | ||
| + | | **UNSETTILTMOVES** | **UNSET** internal **LISTEN** Mode **MOVES** to play on a listen event, only an event notification will be sent and it is the responsibility of the connected application to send commands to react to events; returns '' | ||
| | **OTA** | Starts firmware **O**ver **T**he **A**ir update process (e.g., '' | | **OTA** | Starts firmware **O**ver **T**he **A**ir update process (e.g., '' | ||
| | **FORMATNVS** | **FORMAT** **NVS** (erase all contents of the default NVS partition, including BLE bonds), returns '' | | **FORMATNVS** | **FORMAT** **NVS** (erase all contents of the default NVS partition, including BLE bonds), returns '' | ||
| Line 200: | Line 211: | ||
| | **REBOOT** | **REBOOT**; returns '' | | **REBOOT** | **REBOOT**; returns '' | ||
| | **TASKU** | Prints to the hardware serial console the minimum amount of remaining stack space that was available to the task since the task started executing (high water mark), returns '' | | **TASKU** | Prints to the hardware serial console the minimum amount of remaining stack space that was available to the task since the task started executing (high water mark), returns '' | ||
| + | |||
| + | |||
| ===== Directly Set Servo Position ===== | ===== Directly Set Servo Position ===== | ||
| Line 221: | Line 234: | ||
| * Parameters can be separated by any character that is not a number or a letter (e.g., space, comma, semicolon). However, the letters themselves act as separators, and it is recommended that no additional characters are used, as the serial buffer has a limited capacity and may not be able to store the whole instruction. | * Parameters can be separated by any character that is not a number or a letter (e.g., space, comma, semicolon). However, the letters themselves act as separators, and it is recommended that no additional characters are used, as the serial buffer has a limited capacity and may not be able to store the whole instruction. | ||
| * Depending on the tail and position, it can sag out of the commanded position when servo power is released at the end of the DSSP move. This may cause a visual defect of jerking back into the previous position when the next move starts. | * Depending on the tail and position, it can sag out of the commanded position when servo power is released at the end of the DSSP move. This may cause a visual defect of jerking back into the previous position when the next move starts. | ||
| + | |||
| ==== DSSP Example ==== | ==== DSSP Example ==== | ||
| Line 267: | Line 281: | ||
| {{: | {{: | ||
| + | |||
| ==== USERMOVE Examples ==== | ==== USERMOVE Examples ==== | ||
| + | |||
| === Example 1 – Slow Wag 1 (same as the '' | === Example 1 – Slow Wag 1 (same as the '' | ||
| Line 286: | Line 302: | ||
| * **L75L75** Position 2 is reached in 75 * 20 ms = 1.5 s; return to Position 1 in the same time | * **L75L75** Position 2 is reached in 75 * 20 ms = 1.5 s; return to Position 1 in the same time | ||
| * **H1** Home at end of move | * **H1** Home at end of move | ||
| + | |||
| === Example 2 – Test Servos === | === Example 2 – Test Servos === | ||
| Line 306: | Line 323: | ||
| Because no easing parameters ('' | Because no easing parameters ('' | ||
| </ | </ | ||
| + | |||
| ==== USERLEDS Examples ==== | ==== USERLEDS Examples ==== | ||
| + | |||
| === Example 1 – Beacon (same as the '' | === Example 1 – Beacon (same as the '' | ||
| Line 333: | Line 352: | ||
| * **A0A8** Start off, finish at full brightness | * **A0A8** Start off, finish at full brightness | ||
| * **L100L100** Each brightness point is reached in 100 * 20 ms = 2 s | * **L100L100** Each brightness point is reached in 100 * 20 ms = 2 s | ||
| - | |||
| - | |||
| - | ===== Autonomous Mode ===== | ||
| - | |||
| - | Defines a sequence of random moves, selected from any of three groups as below; interval between moves varies randomly | ||
| - | from T1 to T2. | ||
| - | |||
| - | **AUTOMODE G< | ||
| - | |||
| - | The tail will select a random move from the specified group(s), pausing for a random number of seconds between each move (min and max specified by the first and second '' | ||
| - | |||
| - | Autonomous Mode is ended (after completing any ongoing move) if a BLE connection is made. | ||
| - | |||
| - | ^ Group ^ Move Group Name ^ Move List ^ | ||
| - | | 1 | Calm and Relaxed | Slow Wag 1, Slow Wag 2, Slow Wag 3 | | ||
| - | | 2 | Fast and Excited | Fast Wag, Short Wag, Happy Wag, Erect | | ||
| - | | 3 | Frustrated and Tense | Tremble 1, Tremble 2, Tremble Erect, High Wag | | ||
| - | |||
| - | The parameter order is not important, except that the three '' | ||
| - | |||
| - | ^ Prefix | ||
| - | | **G** | Move Group (see table above) | <1 ... 3> | | ||
| - | | **T1** | Minimum random pause between moves in 1-second increments | <1 ... 240> (1 s ... 4 min) | | ||
| - | | **T2** | Maximum random pause between moves in 1-second increments | <1 ... 240> (1 s ... 4 min) | | ||
| - | | **T3** | Total duration in 15-second increments | <1 ... 240> (15 s ... 60 min); <251 ... 254> are reserved, see [[en: | ||
| - | |||
| - | **STOPAUTO** | ||
| - | |||
| - | '' | ||
| Line 373: | Line 363: | ||
| <WRAP round important 90%> | <WRAP round important 90%> | ||
| - | Do NOT attempt to use Conference Mode on TailControl firmware prior to 5.3.0, or a condition requiring repair of the control board can occur.</ | + | Do **NOT** attempt to use Conference Mode on TailControl firmware prior to 5.3.0, or a condition requiring repair of the control board can occur.</ |
| + | |||
| ==== Enabling Conference Mode (Pairing and Binding) ==== | ==== Enabling Conference Mode (Pairing and Binding) ==== | ||
| Line 381: | Line 373: | ||
| The device will then reboot after 3 seconds. Conference Mode is then enabled, and pairing proceeds. The user's phone (or other device) will prompt for the passkey (which was set earlier), and the bond will be established on both devices. After that, the passkey or a previous bond (up to 3 can be stored) will be required to connect to the device. | The device will then reboot after 3 seconds. Conference Mode is then enabled, and pairing proceeds. The user's phone (or other device) will prompt for the passkey (which was set earlier), and the bond will be established on both devices. After that, the passkey or a previous bond (up to 3 can be stored) will be required to connect to the device. | ||
| + | |||
| ==== Disabling Conference Mode ==== | ==== Disabling Conference Mode ==== | ||
| Line 389: | Line 382: | ||
| The device will then reboot after 3 seconds. If the bond needs to be removed or reset, see [[en: | The device will then reboot after 3 seconds. If the bond needs to be removed or reset, see [[en: | ||
| + | |||
| ==== Unbinding ==== | ==== Unbinding ==== | ||
| Line 409: | Line 403: | ||
| </ | </ | ||
| - | |||
| - | |||
| - | ===== iOS Casual Mode ===== | ||
| - | |||
| - | <WRAP round todo 90%> | ||
| - | This feature is pending removal in a future release. | ||
| - | </ | ||
| - | |||
| - | Because the CRUMPET application is not currently permitted to manage the tail while the iOS application is in the background, the application uses the '' | ||
| - | |||
| - | **AUTOMODEG1 | ||
| - | |||
| - | Note that the '' | ||
| - | |||
| - | Important! The minimum random pause cannot be less that 15 seconds. | ||
| - | |||
| - | ==== iOS Casual Mode Example ==== | ||
| - | |||
| - | **AUTOMODE T15T60T240 G1G2** | ||
| - | |||
| - | * **T15** 15-second minimum random pause between moves | ||
| - | * **T60** 60-second (1 minute) maximum random pause between moves | ||
| - | * **T240** 3600-second (240 * 15 = 3600 s = 1 hour) total duration of Autonomous Mode | ||
| - | * **G1G2** Randomly select a move from groups 1 and 2 | ||
| Line 449: | Line 419: | ||
| ===== No-phone Mode ===== | ===== No-phone Mode ===== | ||
| - | No-phone mode is a feature exclusive | + | Perform random moves while disconnected from a BLE client, selected from any of three groups as below; interval between moves varies randomly from T1 to T2. This feature is comparable to Casual Mode in the app. |
| - | **AUTOMODE G< | + | **AUTOMODE G< |
| + | |||
| + | The tail will select a random move from the specified group(s), pausing for a random number of seconds between each move (min and max specified by the first and second '' | ||
| + | |||
| + | No-phone Mode is suspended (after completing any ongoing move) if a BLE connection is made. It will resume after BLE is disconnected. | ||
| + | |||
| + | ^ Group ^ Move Group Name ^ Move List ^ | ||
| + | | 1 | Calm and Relaxed | Slow Wag 1, Slow Wag 2, Slow Wag 3 | | ||
| + | | 2 | Fast and Excited | Fast Wag, Short Wag, Happy Wag, Erect | | ||
| + | | 3 | Frustrated and Tense | Tremble 1, Tremble 2, Tremble Erect, High Wag | | ||
| + | |||
| + | The parameter order is not important, except that the three '' | ||
| + | |||
| + | ^ Prefix | ||
| + | | **G** | Move Group (see table above) | <1 ... 3> | | ||
| + | | **T1** | Minimum random pause between moves in 1-second increments | <1 ... 240> (1 s ... 4 min) | | ||
| + | | **T2** | Maximum random pause between moves in 1-second increments | <1 ... 240> (1 s ... 4 min) | | ||
| + | | **T3** | Delay to wait for BLE connection before starting NPM | <25**1** ... 25**4**> (1 ... 4 min) | | ||
| No-phone Mode (NPM) will cause the tail to delay one to four minutes (based on the setting of the third '' | No-phone Mode (NPM) will cause the tail to delay one to four minutes (based on the setting of the third '' | ||
| Line 460: | Line 447: | ||
| Stops No-phone mode and disables it in NVS configuration. | Stops No-phone mode and disables it in NVS configuration. | ||
| + | |||
| + | |||
| + | ==== No-phone Mode Example ==== | ||
| + | |||
| + | **AUTOMODE T15T60T243 G1G2** | ||
| + | |||
| + | * **T15** 15-second minimum random pause between moves | ||
| + | * **T60** 60-second (1 minute) maximum random pause between moves | ||
| + | * **T240** 3600-second (240 * 15 = 3600 s = 1 hour) total duration of Autonomous Mode | ||
| + | * **G1G2** Randomly select a move from groups 1 and 2 | ||