v1.3 - Echo signals a few times

This commit is contained in:
Derek Jamison 2023-07-11 18:18:08 -05:00
parent d931817ae5
commit 00480d1fc8
3 changed files with 16 additions and 1 deletions

View File

@ -5,7 +5,7 @@ App(
entry_point="rock_paper_scissors_app", entry_point="rock_paper_scissors_app",
requires=["gui", "subghz"], requires=["gui", "subghz"],
stack_size=2 * 1024, stack_size=2 * 1024,
fap_version=(1, 2), fap_version=(1, 3),
fap_icon="rock_paper_scissors.png", fap_icon="rock_paper_scissors.png",
fap_icon_assets="images", fap_icon_assets="images",
fap_icon_assets_symbol="rock_paper_scissors", fap_icon_assets_symbol="rock_paper_scissors",

View File

@ -990,6 +990,18 @@ static void rps_broadcast(GameContext* game_context, FuriString* buffer) {
// Wait a few milliseconds on failure before trying to send again. // Wait a few milliseconds on failure before trying to send again.
furi_delay_ms(20); furi_delay_ms(20);
} }
// Try to handle the case that *sometimes* a signal might not get through.
for(int i = 0; i < 3; i++) {
if(game_context->data->echo_duration > 0 && game_context->data->echo_duration < 50) {
furi_delay_ms(game_context->data->echo_duration + i * 5);
FURI_LOG_I(TAG, "Echoing message");
while(!subghz_tx_rx_worker_write(game_context->subghz_txrx, message, length)) {
// Wait a few milliseconds on failure before trying to send again.
furi_delay_ms(7);
}
}
}
} }
// Our GameEventSendCounter handler invokes this method. // Our GameEventSendCounter handler invokes this method.
@ -1088,6 +1100,7 @@ static void rps_broadcast_quit(GameContext* game_context) {
// @param game_context pointer to a GameContext. // @param game_context pointer to a GameContext.
static void rps_broadcast_join(GameContext* game_context) { static void rps_broadcast_join(GameContext* game_context) {
GameData* data = game_context->data; GameData* data = game_context->data;
data->echo_duration = 42;
unsigned int gameNumber = data->game_number; unsigned int gameNumber = data->game_number;
FURI_LOG_I(TAG, "Joining game %d.", gameNumber); FURI_LOG_I(TAG, "Joining game %d.", gameNumber);
@ -1109,6 +1122,7 @@ static void rps_broadcast_join(GameContext* game_context) {
// @param game_context pointer to a GameContext. // @param game_context pointer to a GameContext.
static void rps_broadcast_join_acknowledge(GameContext* game_context) { static void rps_broadcast_join_acknowledge(GameContext* game_context) {
GameData* data = game_context->data; GameData* data = game_context->data;
data->echo_duration = 12;
unsigned int gameNumber = data->game_number; unsigned int gameNumber = data->game_number;
FURI_LOG_I(TAG, "Acknowledge joining game %d.", gameNumber); FURI_LOG_I(TAG, "Acknowledge joining game %d.", gameNumber);

View File

@ -273,6 +273,7 @@ typedef struct {
int keyboard_row; int keyboard_row;
int keyboard_col; int keyboard_col;
int social_line; int social_line;
int echo_duration;
} GameData; } GameData;
// This is our application context. // This is our application context.