You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
**+ Configurable navigation controls, radio type independent**
@@ -18,8 +16,7 @@
18
16
**+ Minified script files, shrinked down to 75% the size of 1.3.0** (thanks to [mathiasbynens/luamin](https://github.com/mathiasbynens/luamin))
19
17
20
18
## Notes
21
-
22
-
I wanted to explore the potential of the popular betaflight-tx-lua-scripts a bit, as I wasn't quit satisfied with a few things. Came up with this mod and it upgraded the UX for me so well, that I decided to share it with the community. Runs nique smooth on my FrSky Taranis Q X7, but I wasn't able to do tests with any *Horus* or other model than *FrSky Taranis* so far.
19
+
Wanted to explore the potential of the popular betaflight-tx-lua-scripts a bit, as I wasn't quit satisfied with a few things. Came up with this mod and it upgraded the UX for me so well, that I decided to share it with the community. Runs nique smooth on my FrSky Taranis Q X7, but I wasn't able to do tests with any other models than FrSky so far.
23
20
24
21
Install and use this modified version just the way you're used to. First time users should have a glimpse at the [install instructions](#installing).
25
22
@@ -35,31 +32,37 @@ Prepend `-- ` to the line to hide a page (e.g. rescue.lua and gps.lua, if you do
35
32
Use relative pathnames to refer external templates.
36
33
If you add or edit pages, keep in mind that the radios internal memory isn't endless.
37
34
38
-
### Navigation controls
39
-
The code wich handles the user events was extracted from `ui.lua` into a table `ctrlSchema = { ... }` and placed in each `SCRIPTS/BF/[platform]/[platform]pre.lua` file.
35
+
> *If you have TBS Crossfire, you can try*`../../../CROSSFIRE/crossfire.lua`*. The Page seems to load, but tell me if it's actually working.*
36
+
37
+
### Mapping navigation controls
38
+
The code wich handles the user events was abstracted from `ui.lua` into a table `ctrlSchema = { ... }` and placed in each `SCRIPTS/BF/[platform]/[platform]pre.lua` file.
40
39
The assignment of radio inputs to script actions depends now on this platform specific config.
41
40
42
41
For instance: if you want to have switching pages on the [DIAL WHEEL] input, change the condition of `ctrlSchema.display.prevPage` to `dial.left` and `ctrlSchema.display.nextPage` to `dial.right`.
43
42
44
-
To add a radio control schema based on its platform, just overwrite the affected table fields below the schema table (see overrides for X9E in `SCRIPTS/BF/X9/x9pre.lua` for example).
43
+
To add a transmitter control schema based on its platform, just overwrite the affected table fields below the schema table (see overrides for X9E in `SCRIPTS/BF/X9/x9pre.lua`[for example](https://github.com/Matze-Jung/betaflight-tx-lua-scripts-mod/blob/7c4463aec29757763e8eb7aea49905e677711ef7/src/SCRIPTS/BF/X9/x9pre.lua#L101)).
45
44
46
-
### Memory warning
47
-
If you just copied the files, launched the script and a `not enough memory` warning appears, probably restarting the radio is the only thing to do here. If OpenTX still complains, try to delete all `.luac` files (compiled them with LUAC 5.3, don't know if that's a problem with some radios).
45
+
This concept should have the potential to implement new coming radios much easier and be handled separately from the core ui code.
If you just copied the files, launched the script and a `not enough memory` warning appears, probably restarting the radio is the only thing to do here. If OpenTX still complains, try to delete all `.luac` files (compiled with LUAC 5.3.5, don't know if that's a problem with some devices).
53
49
54
-
> *Any feedback about testing on different hardware welcome.*
50
+
## Test environment
51
+
* OpenTX v2.2.3 on Taranis Q X7, Betaflight 4.0.3 on OmnibusF4, R-XSR
> *Any [feedback](https://github.com/Matze-Jung/betaflight-tx-lua-scripts-mod/issues/new/choose) about testing on different hardware welcome.*
57
55
56
+
## Download
58
57
Please go to the [releases page](https://github.com/Matze-Jung/betaflight-tx-lua-scripts-mod/releases) to download the latest files.
59
58
59
+
## Building from source
60
+
- Be sure to have `LUA 5.2`and `Node.js` installed
61
+
- Run `npm install` from the root folder to install node modules
62
+
- Run `npm start`, `make` or `./bin/build.sh min` from the root folder with appropriate privileges (omit the `min` switch to build without minifying)
63
+
- Compiled/minified files will be created at the `obj` folder. Copy the files to your transmitter as instructed in the [Installing section](#installing) below as if you unzipped from a downloaded file.
60
64
61
65
## Control schema layout
62
-
63
66
| State | Action | Condition (X7) |
64
67
| - | - | - |
65
68
| display | prevPage |*longPress.page*|
@@ -77,10 +80,9 @@ Please go to the [releases page](https://github.com/Matze-Jung/betaflight-tx-lua
77
80
|| next |*dial.right*|
78
81
|| cnfrm |*release.enter*|
79
82
|| exit |*release.exit* or *release.menu*|
80
-
83
+
> *Action `func()` is fired when condition is true and in application state.*
81
84
82
85
## User events
83
-
84
86
| Action | Name |
85
87
| - | - |
86
88
| press | minus |
@@ -102,11 +104,9 @@ Please go to the [releases page](https://github.com/Matze-Jung/betaflight-tx-lua
102
104
|| left |
103
105
|| right |
104
106
105
-
106
107
---
107
108
108
-
109
-
# betaflight-tx-lua-scripts
109
+
# betaflight-tx-lua-scripts 1.3.0
110
110
111
111
### Important:
112
112
@@ -119,11 +119,6 @@ For now, the recommendation is for users wanting to update OpenTX from 2.2.0 to
119
119
- Crossfire - v2.11 or greater
120
120
- FrSky - While most receivers work fine, it's recommended to update the XSR family of receivers to their most recent firmware version to correct any known bugs in SmartPort telemetry.
121
121
122
-
## Building from source
123
-
- Be sure to have `LUA 5.2` installed in the path
124
-
- Run `./bin/build.sh` from the root folder
125
-
- Compiled files will be created a the `obj` in the root folder. Copy the files to your transmitter as instructed in the `Installing` section below as if you unzipped from a downloaded file.
126
-
127
122
## Installing
128
123
129
124
!! IMPORTANT: DON'T COPY THE CONTENTS OF THIS REPOSITORY ONTO YOUR SDCARD !!
0 commit comments