Skip to content

Commit

Permalink
Implemented: [LVGL] Add "screen stack control" property to Change Scr…
Browse files Browse the repository at this point in the history
…een action #649
  • Loading branch information
mvladic committed Nov 27, 2024
1 parent bac9a9f commit a528d07
Show file tree
Hide file tree
Showing 13 changed files with 82 additions and 44 deletions.
2 changes: 2 additions & 0 deletions help/en-US/components/LVGLWidget.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

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.

## Code identifier [EMPTY]

## Left unit

The following options are available:
Expand Down
1 change: 1 addition & 0 deletions help/en-US/components/actions/LVGL.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ List of actions to be executed. The following actions are available:
- *Fade mode*: Selection of animation when moving from the previous page to a new page
- *Speed*: Animation duration in milliseconds
- *Delay*: Delay in milliseconds before the animation starts.
- *Use stack*: Put active screen on the stack.

- **Change to Previous Screen**: Change to the previous screen
- *Fade mode*: Selection of animation when moving from the previous page to a new page
Expand Down
4 changes: 4 additions & 0 deletions help/en-US/components/widgets/Checkbox (LVGL).md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@

Label displayed next to the checkbox.

## Text type

Here we can choose whether the `Text` property will be calculated from the Expression.

# INPUTS [EMPTY]

# OUTPUTS [EMPTY]
Expand Down
2 changes: 2 additions & 0 deletions help/en-US/components/widgets/Terminal.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ Style used when rendering of the Widget.

# INPUTS [EMPTY]

## clear

# OUTPUTS [EMPTY]

## onData
Expand Down
2 changes: 1 addition & 1 deletion packages/project-editor/flow/runtime/cpp/eez-framework
38 changes: 19 additions & 19 deletions packages/project-editor/flow/runtime/lvgl_runtime_v8.3.js
Original file line number Diff line number Diff line change
Expand Up @@ -969,25 +969,25 @@ function dbg(text) {
// === Body ===

var ASM_CONSTS = {
1036816: ($0) => { startToDebuggerMessage($0); },
1036848: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1036923: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1036998: ($0) => { finishToDebuggerMessage($0); },
1037031: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
1037085: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
1037139: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
1037192: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
1037245: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
1037298: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
1037331: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
1037367: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
1037412: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
1037518: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
1037554: ($0, $1) => { return eez_mqtt_connect($0, $1); },
1037591: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
1037631: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
1037688: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
1037747: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
1036832: ($0) => { startToDebuggerMessage($0); },
1036864: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1036939: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1037014: ($0) => { finishToDebuggerMessage($0); },
1037047: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
1037101: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
1037155: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
1037208: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
1037261: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
1037314: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
1037347: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
1037383: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
1037428: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
1037534: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
1037570: ($0, $1) => { return eez_mqtt_connect($0, $1); },
1037607: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
1037647: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
1037704: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
1037763: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
};


Expand Down
Binary file modified packages/project-editor/flow/runtime/lvgl_runtime_v8.3.wasm
Binary file not shown.
38 changes: 19 additions & 19 deletions packages/project-editor/flow/runtime/lvgl_runtime_v9.0.js
Original file line number Diff line number Diff line change
Expand Up @@ -969,25 +969,25 @@ function dbg(text) {
// === Body ===

var ASM_CONSTS = {
1031664: ($0) => { startToDebuggerMessage($0); },
1031696: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1031771: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1031846: ($0) => { finishToDebuggerMessage($0); },
1031879: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
1031933: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
1031987: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
1032040: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
1032093: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
1032146: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
1032179: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
1032215: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
1032260: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
1032366: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
1032402: ($0, $1) => { return eez_mqtt_connect($0, $1); },
1032439: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
1032479: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
1032536: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
1032595: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
1031680: ($0) => { startToDebuggerMessage($0); },
1031712: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1031787: ($0, $1, $2) => { writeDebuggerBuffer($0, new Uint8Array(Module.HEAPU8.buffer, $1, $2)); },
1031862: ($0) => { finishToDebuggerMessage($0); },
1031895: ($0, $1) => { return getLvglScreenByName($0, UTF8ToString($1)); },
1031949: ($0, $1) => { return getLvglObjectByName($0, UTF8ToString($1)); },
1032003: ($0, $1) => { return getLvglGroupByName($0, UTF8ToString($1)); },
1032056: ($0, $1) => { return getLvglStyleByName($0, UTF8ToString($1)); },
1032109: ($0, $1) => { return getLvglImageByName($0, UTF8ToString($1)); },
1032162: ($0, $1, $2) => { lvglObjAddStyle($0, $1, $2); },
1032195: ($0, $1, $2) => { lvglObjRemoveStyle($0, $1, $2); },
1032231: ($0, $1) => { lvglSetColorTheme($0, UTF8ToString($1)); },
1032276: ($0, $1, $2, $3, $4, $5) => { return eez_mqtt_init($0, UTF8ToString($1), UTF8ToString($2), $3, UTF8ToString($4), UTF8ToString($5)); },
1032382: ($0, $1) => { return eez_mqtt_deinit($0, $1); },
1032418: ($0, $1) => { return eez_mqtt_connect($0, $1); },
1032455: ($0, $1) => { return eez_mqtt_disconnect($0, $1); },
1032495: ($0, $1, $2) => { return eez_mqtt_subscribe($0, $1, UTF8ToString($2)); },
1032552: ($0, $1, $2) => { return eez_mqtt_unsubscribe($0, $1, UTF8ToString($2)); },
1032611: ($0, $1, $2, $3) => { return eez_mqtt_publish($0, $1, UTF8ToString($2), UTF8ToString($3)); }
};


Expand Down
Binary file modified packages/project-editor/flow/runtime/lvgl_runtime_v9.0.wasm
Binary file not shown.
14 changes: 12 additions & 2 deletions packages/project-editor/lvgl/actions-catalog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,11 @@ registerAction({
name: "delay",
type: "integer",
helpText: "Delay in milliseconds before the animation starts."
},
{
name: "useStack",
type: "boolean",
helpText: "Put active screen on the stack."
}
],
defaults: {
Expand All @@ -41,12 +46,17 @@ registerAction({
delay: 0
},
label: (
[screen, fadeMode, speed, delay],
[_1, _2, speedLabel, delayLabel]
[screen, fadeMode, speed, delay, useStack],
[_1, _2, speedLabel, delayLabel, useStackLabel]
) => (
<>
{screen} {fadeMode} <i>{speedLabel}</i>={speed} <i>{delayLabel}</i>=
{delay}
{useStack !== "ON" && (
<>
<i> {useStackLabel}</i>={useStack}
</>
)}
</>
),
helpText: "Change the screen to the specified screen"
Expand Down
10 changes: 10 additions & 0 deletions packages/project-editor/lvgl/actions.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -1440,6 +1440,16 @@ export class LVGLActionComponent extends ActionComponent {
break;
}
}

for (const actionJs of objectJs.actions) {
if (
actionJs.action == "changeScreen" &&
actionJs.useStack === undefined
) {
actionJs.useStack = true;
actionJs.useStackType = "literal";
}
}
},
icon: (
<img src="" />
Expand Down
13 changes: 11 additions & 2 deletions resources/eez-framework-amalgamation/eez-flow.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Autogenerated on November 19, 2024 2:46:06 PM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
/* Autogenerated on November 27, 2024 11:49:28 AM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
/*
* eez-framework
*
Expand Down Expand Up @@ -4244,7 +4244,16 @@ ACTION_START(changeScreen)
INT32_PROP(fadeMode);
UINT32_PROP(speed);
UINT32_PROP(delay);
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
if (properties.count > 4) {
BOOL_PROP(useStack);
if (useStack) {
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
} else {
eez::flow::replacePageHook(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
}
} else {
eez_flow_push_screen(screen, (lv_scr_load_anim_t)fadeMode, speed, delay);
}
ACTION_END
ACTION_START(changeToPreviousScreen)
INT32_PROP(fadeMode);
Expand Down
2 changes: 1 addition & 1 deletion resources/eez-framework-amalgamation/eez-flow.h
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Autogenerated on November 19, 2024 2:46:06 PM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
/* Autogenerated on November 27, 2024 11:49:28 AM from eez-framework commit 4b8ceca59dc6b0b34fefb219390e79e89c719da2 */
/*
* eez-framework
*
Expand Down

0 comments on commit a528d07

Please sign in to comment.