Skip to content

Commit a528d07

Browse files
committed
Implemented: [LVGL] Add "screen stack control" property to Change Screen action #649
1 parent bac9a9f commit a528d07

File tree

13 files changed

+82
-44
lines changed

13 files changed

+82
-44
lines changed

help/en-US/components/LVGLWidget.md

+2
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,8 @@
44

55
Widget name. We reference the Widget within the project by its name, for example in the LVGL action. For each Widget, we must choose a unique name within the entire project. This field is optional and does not need to be set if we do not need to reference the Widget.
66

7+
## Code identifier [EMPTY]
8+
79
## Left unit
810

911
The following options are available:

help/en-US/components/actions/LVGL.md

+1
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@ List of actions to be executed. The following actions are available:
1313
- *Fade mode*: Selection of animation when moving from the previous page to a new page
1414
- *Speed*: Animation duration in milliseconds
1515
- *Delay*: Delay in milliseconds before the animation starts.
16+
- *Use stack*: Put active screen on the stack.
1617

1718
- **Change to Previous Screen**: Change to the previous screen
1819
- *Fade mode*: Selection of animation when moving from the previous page to a new page

help/en-US/components/widgets/Checkbox (LVGL).md

+4
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,10 @@
1010

1111
Label displayed next to the checkbox.
1212

13+
## Text type
14+
15+
Here we can choose whether the `Text` property will be calculated from the Expression.
16+
1317
# INPUTS [EMPTY]
1418

1519
# OUTPUTS [EMPTY]

help/en-US/components/widgets/Terminal.md

+2
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,8 @@ Style used when rendering of the Widget.
1414

1515
# INPUTS [EMPTY]
1616

17+
## clear
18+
1719
# OUTPUTS [EMPTY]
1820

1921
## onData

packages/project-editor/flow/runtime/lvgl_runtime_v8.3.js

+19-19
Original file line numberDiff line numberDiff line change
@@ -969,25 +969,25 @@ function dbg(text) {
969969
// === Body ===
970970

971971
var ASM_CONSTS = {
972-
1036816: ($0) => { startToDebuggerMessage($0); },
973-
1036848: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
974-
1036923: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
975-
1036998: ($0) => { finishToDebuggerMessage($0); },
976-
1037031: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
977-
1037085: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
978-
1037139: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
979-
1037192: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
980-
1037245: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
981-
1037298: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
982-
1037331: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
983-
1037367: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
984-
1037412: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
985-
1037518: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
986-
1037554: ($0, $1) => { return eez_mqtt_connect($0, $1); },
987-
1037591: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
988-
1037631: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
989-
1037688: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
990-
1037747: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
972+
1036832: ($0) => { startToDebuggerMessage($0); },
973+
1036864: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
974+
1036939: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
975+
1037014: ($0) => { finishToDebuggerMessage($0); },
976+
1037047: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
977+
1037101: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
978+
1037155: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
979+
1037208: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
980+
1037261: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
981+
1037314: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
982+
1037347: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
983+
1037383: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
984+
1037428: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
985+
1037534: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
986+
1037570: ($0, $1) => { return eez_mqtt_connect($0, $1); },
987+
1037607: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
988+
1037647: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
989+
1037704: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
990+
1037763: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
991991
};
992992

993993

Binary file not shown.

packages/project-editor/flow/runtime/lvgl_runtime_v9.0.js

+19-19
Original file line numberDiff line numberDiff line change
@@ -969,25 +969,25 @@ function dbg(text) {
969969
// === Body ===
970970

971971
var ASM_CONSTS = {
972-
1031664: ($0) => { startToDebuggerMessage($0); },
973-
1031696: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
974-
1031771: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
975-
1031846: ($0) => { finishToDebuggerMessage($0); },
976-
1031879: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
977-
1031933: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
978-
1031987: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
979-
1032040: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
980-
1032093: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
981-
1032146: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
982-
1032179: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
983-
1032215: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
984-
1032260: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
985-
1032366: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
986-
1032402: ($0, $1) => { return eez_mqtt_connect($0, $1); },
987-
1032439: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
988-
1032479: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
989-
1032536: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
990-
1032595: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
972+
1031680: ($0) => { startToDebuggerMessage($0); },
973+
1031712: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
974+
1031787: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
975+
1031862: ($0) => { finishToDebuggerMessage($0); },
976+
1031895: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
977+
1031949: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
978+
1032003: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
979+
1032056: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
980+
1032109: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
981+
1032162: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
982+
1032195: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
983+
1032231: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
984+
1032276: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
985+
1032382: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
986+
1032418: ($0, $1) => { return eez_mqtt_connect($0, $1); },
987+
1032455: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
988+
1032495: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
989+
1032552: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
990+
1032611: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
991991
};
992992

993993

Binary file not shown.

packages/project-editor/lvgl/actions-catalog.tsx

+12-2
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,11 @@ registerAction({
3333
name: "delay",
3434
type: "integer",
3535
helpText: "Delay in milliseconds before the animation starts."
36+
},
37+
{
38+
name: "useStack",
39+
type: "boolean",
40+
helpText: "Put active screen on the stack."
3641
}
3742
],
3843
defaults: {
@@ -41,12 +46,17 @@ registerAction({
4146
delay: 0
4247
},
4348
label: (
44-
[screen, fadeMode, speed, delay],
45-
[_1, _2, speedLabel, delayLabel]
49+
[screen, fadeMode, speed, delay, useStack],
50+
[_1, _2, speedLabel, delayLabel, useStackLabel]
4651
) => (
4752
<>
4853
{screen} {fadeMode} <i>{speedLabel}</i>={speed} <i>{delayLabel}</i>=
4954
{delay}
55+
{useStack !== "ON" && (
56+
<>
57+
<i> {useStackLabel}</i>={useStack}
58+
</>
59+
)}
5060
</>
5161
),
5262
helpText: "Change the screen to the specified screen"

packages/project-editor/lvgl/actions.tsx

+10
Original file line numberDiff line numberDiff line change
@@ -1440,6 +1440,16 @@ export class LVGLActionComponent extends ActionComponent {
14401440
break;
14411441
}
14421442
}
1443+
1444+
for (const actionJs of objectJs.actions) {
1445+
if (
1446+
actionJs.action == "changeScreen" &&
1447+
actionJs.useStack === undefined
1448+
) {
1449+
actionJs.useStack = true;
1450+
actionJs.useStackType = "literal";
1451+
}
1452+
}
14431453
},
14441454
icon: (
14451455
<img src="" />

resources/eez-framework-amalgamation/eez-flow.cpp

+11-2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
/* Autogenerated on November 19, 2024 2:46:06 PM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
1+
/* Autogenerated on November 27, 2024 11:49:28 AM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
22
/*
33
* eez-framework
44
*
@@ -4244,7 +4244,16 @@ ACTION_START(changeScreen)
42444244
INT32_PROP(fadeMode);
42454245
UINT32_PROP(speed);
42464246
UINT32_PROP(delay);
4247-
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
4247+
if (properties.count > 4) {
4248+
BOOL_PROP(useStack);
4249+
if (useStack) {
4250+
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
4251+
} else {
4252+
eez::flow::replacePageHook(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
4253+
}
4254+
} else {
4255+
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
4256+
}
42484257
ACTION_END
42494258
ACTION_START(changeToPreviousScreen)
42504259
INT32_PROP(fadeMode);

resources/eez-framework-amalgamation/eez-flow.h

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
/* Autogenerated on November 19, 2024 2:46:06 PM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
1+
/* Autogenerated on November 27, 2024 11:49:28 AM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
22
/*
33
* eez-framework
44
*

0 commit comments

Comments
 (0)