[FL-1363] BLE GUI tests (#505)
* bt: introduce bt CLI commands * api-hal-bt: add get rssi * bt: fix cli commands * bt: fix typos * bt: refacrote bt test names * ble gui continue * bt: rework carrier test gui * bt: rework send packets test gui * bt: rework receive packets test * api-hal-bt: change rssi return * bt: refactore bt gui Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com> Co-authored-by: SG <who.just.the.doctor@gmail.com>
This commit is contained in:
176
applications/bt/bt_views.c
Normal file → Executable file
176
applications/bt/bt_views.c
Normal file → Executable file
@@ -1,30 +1,49 @@
|
||||
#include "bt_views.h"
|
||||
|
||||
void bt_view_test_tone_tx_draw(Canvas* canvas, void* model) {
|
||||
BtViewTestToneTxModel* m = model;
|
||||
void bt_view_test_carrier_draw(Canvas* canvas, void* model) {
|
||||
BtViewTestCarrierModel* m = model;
|
||||
canvas_clear(canvas);
|
||||
canvas_set_font(canvas, FontSecondary);
|
||||
canvas_draw_str(canvas, 0, 12, "Performing continous TX test");
|
||||
if(m->type == BtStatusToneTx) {
|
||||
canvas_draw_str(canvas, 0, 24, "Manual control mode");
|
||||
} else {
|
||||
canvas_draw_str(canvas, 0, 24, "Hopping mode");
|
||||
canvas_draw_str(canvas, 0, 12, "Performing Cattier test");
|
||||
if(m->type == BtStateCarrierTx) {
|
||||
canvas_draw_str(canvas, 0, 24, "Manual Carrier TX");
|
||||
} else if(m->type == BtStateHoppingTx) {
|
||||
canvas_draw_str(canvas, 0, 24, "Carrier TX Hopping mode");
|
||||
} else if(m->type == BtStateCarrierRxRunning) {
|
||||
canvas_draw_str(canvas, 0, 24, "Manual Carrier RX");
|
||||
}
|
||||
char buffer[32];
|
||||
snprintf(buffer, sizeof(buffer), "Channel:%d MHz", m->channel * 2 + 2402);
|
||||
canvas_draw_str(canvas, 0, 36, buffer);
|
||||
snprintf(buffer, sizeof(buffer), "Power:%d dB", m->power - BtPower0dB);
|
||||
if(m->type == BtStateCarrierTx || m->type == BtStateHoppingTx) {
|
||||
snprintf(buffer, sizeof(buffer), "Power:%d dB", m->power - BtPower0dB);
|
||||
} else if(m->type == BtStateCarrierRxRunning) {
|
||||
snprintf(buffer, sizeof(buffer), "RSSI: %3.1f dB", m->rssi);
|
||||
}
|
||||
canvas_draw_str(canvas, 0, 48, buffer);
|
||||
}
|
||||
|
||||
void bt_view_test_tone_rx_draw(Canvas* canvas, void* model) {
|
||||
BtViewTestRxModel* m = model;
|
||||
void bt_view_test_packet_rx_draw(Canvas* canvas, void* model) {
|
||||
BtViewTestPacketRxModel* m = model;
|
||||
canvas_clear(canvas);
|
||||
canvas_set_font(canvas, FontSecondary);
|
||||
canvas_draw_str(canvas, 0, 12, "Performing continous RX test");
|
||||
canvas_draw_str(canvas, 0, 12, "Performing packets RX test");
|
||||
if(m->type == BtStatePacketSetup) {
|
||||
canvas_draw_str(canvas, 0, 24, "Setup parameters. Ok to start");
|
||||
} else {
|
||||
canvas_draw_str(canvas, 0, 24, "Receiving packets ...");
|
||||
}
|
||||
char buffer[32];
|
||||
snprintf(buffer, sizeof(buffer), "Channel:%d MHz", m->channel * 2 + 2402);
|
||||
canvas_draw_str(canvas, 0, 24, buffer);
|
||||
canvas_draw_str(canvas, 0, 36, buffer);
|
||||
snprintf(buffer, sizeof(buffer), "Datarate:%d Mbps", m->datarate);
|
||||
canvas_draw_str(canvas, 0, 48, buffer);
|
||||
if(m->type == BtStatePacketSetup) {
|
||||
snprintf(buffer, sizeof(buffer), "%d packets received", m->packets_received);
|
||||
} else {
|
||||
snprintf(buffer, sizeof(buffer), "RSSI: %3.1f dB", m->rssi);
|
||||
}
|
||||
canvas_draw_str(canvas, 0, 60, buffer);
|
||||
}
|
||||
|
||||
void bt_view_test_packet_tx_draw(Canvas* canvas, void* model) {
|
||||
@@ -32,18 +51,20 @@ void bt_view_test_packet_tx_draw(Canvas* canvas, void* model) {
|
||||
canvas_clear(canvas);
|
||||
canvas_set_font(canvas, FontSecondary);
|
||||
canvas_draw_str(canvas, 0, 12, "Packets send TX test");
|
||||
if(m->type == BtStatusPacketSetup) {
|
||||
canvas_draw_str(canvas, 0, 24, "Setup parameters");
|
||||
canvas_draw_str(canvas, 0, 36, "Press OK to send packets");
|
||||
if(m->type == BtStatePacketSetup) {
|
||||
canvas_draw_str(canvas, 0, 24, "Setup parameters. Ok to start");
|
||||
} else {
|
||||
canvas_draw_str(canvas, 0, 24, "Sending packets");
|
||||
canvas_draw_str(canvas, 0, 36, "Packets parameters:");
|
||||
canvas_draw_str(canvas, 0, 24, "Sending packets ...");
|
||||
}
|
||||
char buffer[32];
|
||||
snprintf(buffer, sizeof(buffer), "Channel:%d MHz", m->channel * 2 + 2402);
|
||||
canvas_draw_str(canvas, 0, 36, buffer);
|
||||
snprintf(buffer, sizeof(buffer), "Datarate:%d Mbps", m->datarate);
|
||||
canvas_draw_str(canvas, 0, 48, buffer);
|
||||
snprintf(buffer, sizeof(buffer), "Daterate:%d Mbps", m->datarate);
|
||||
canvas_draw_str(canvas, 0, 60, buffer);
|
||||
if(m->packets_sent && m->type == BtStatePacketSetup) {
|
||||
snprintf(buffer, sizeof(buffer), "%d packets sent", m->packets_sent);
|
||||
canvas_draw_str(canvas, 0, 60, buffer);
|
||||
}
|
||||
}
|
||||
|
||||
void bt_view_app_draw(Canvas* canvas, void* model) {
|
||||
@@ -73,16 +94,16 @@ BtTestChannel bt_switch_channel(InputKey key, BtTestChannel inst_chan) {
|
||||
return arr[0];
|
||||
}
|
||||
|
||||
bool bt_view_test_tone_tx_input(InputEvent* event, void* context) {
|
||||
bool bt_view_test_carrier_input(InputEvent* event, void* context) {
|
||||
furi_assert(event);
|
||||
furi_assert(context);
|
||||
Bt* bt = context;
|
||||
if(event->type == InputTypeShort) {
|
||||
if(event->key == InputKeyBack) {
|
||||
if(osTimerIsRunning(bt->hopping_mode_timer)) {
|
||||
osTimerStop(bt->hopping_mode_timer);
|
||||
if(osTimerIsRunning(bt->update_param_timer)) {
|
||||
osTimerStop(bt->update_param_timer);
|
||||
}
|
||||
BtMessage m = {.type = BtMessageTypeStopTestToneTx};
|
||||
BtMessage m = {.type = BtMessageTypeStopTestCarrier};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
view_dispatcher_switch_to_view(bt->view_dispatcher, VIEW_NONE);
|
||||
return true;
|
||||
@@ -98,16 +119,20 @@ bool bt_view_test_tone_tx_input(InputEvent* event, void* context) {
|
||||
bt->state.param.power -= 2;
|
||||
}
|
||||
} else if(event->key == InputKeyOk) {
|
||||
if(bt->state.type == BtStatusToneTx) {
|
||||
bt->state.type = BtStatusHoppingTx;
|
||||
osTimerStart(bt->hopping_mode_timer, 2000);
|
||||
if(bt->state.type == BtStateCarrierTx) {
|
||||
bt->state.type = BtStateHoppingTx;
|
||||
osTimerStart(bt->update_param_timer, 2000);
|
||||
} else if(bt->state.type == BtStateHoppingTx) {
|
||||
osTimerStop(bt->update_param_timer);
|
||||
bt->state.type = BtStateCarrierRxStart;
|
||||
osTimerStart(bt->update_param_timer, 200);
|
||||
} else {
|
||||
bt->state.type = BtStatusToneTx;
|
||||
osTimerStop(bt->hopping_mode_timer);
|
||||
osTimerStop(bt->update_param_timer);
|
||||
bt->state.type = BtStateCarrierTx;
|
||||
}
|
||||
}
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStartTestToneTx,
|
||||
.type = BtMessageTypeStartTestCarrier,
|
||||
.param.channel = bt->state.param.channel,
|
||||
.param.power = bt->state.param.power};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
@@ -117,29 +142,6 @@ bool bt_view_test_tone_tx_input(InputEvent* event, void* context) {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool bt_view_test_tone_rx_input(InputEvent* event, void* context) {
|
||||
furi_assert(event);
|
||||
furi_assert(context);
|
||||
Bt* bt = context;
|
||||
if(event->type == InputTypeShort) {
|
||||
if(event->key == InputKeyRight || event->key == InputKeyLeft) {
|
||||
bt->state.param.channel = bt_switch_channel(event->key, bt->state.param.channel);
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStartTestRx, .param.channel = bt->state.param.channel};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
return true;
|
||||
} else if(event->key == InputKeyBack) {
|
||||
BtMessage m = {.type = BtMessageTypeStopTestRx};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
view_dispatcher_switch_to_view(bt->view_dispatcher, VIEW_NONE);
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool bt_view_test_packet_tx_input(InputEvent* event, void* context) {
|
||||
furi_assert(event);
|
||||
furi_assert(context);
|
||||
@@ -150,15 +152,15 @@ bool bt_view_test_packet_tx_input(InputEvent* event, void* context) {
|
||||
if(event->key == InputKeyRight || event->key == InputKeyLeft) {
|
||||
bt->state.param.channel = bt_switch_channel(event->key, bt->state.param.channel);
|
||||
} else if(event->key == InputKeyUp) {
|
||||
if(bt->state.param.datarate < BtDateRate2M) {
|
||||
if(bt->state.param.datarate < BtDataRate2M) {
|
||||
bt->state.param.datarate += 1;
|
||||
}
|
||||
} else if(event->key == InputKeyDown) {
|
||||
if(bt->state.param.datarate > BtDateRate1M) {
|
||||
if(bt->state.param.datarate > BtDataRate1M) {
|
||||
bt->state.param.datarate -= 1;
|
||||
}
|
||||
}
|
||||
bt->state.type = BtStatusPacketSetup;
|
||||
bt->state.type = BtStatePacketSetup;
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeSetupTestPacketTx,
|
||||
.param.channel = bt->state.param.channel,
|
||||
@@ -167,7 +169,11 @@ bool bt_view_test_packet_tx_input(InputEvent* event, void* context) {
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
return true;
|
||||
} else if(event->key == InputKeyOk) {
|
||||
bt->state.type = BtStatusPacketTx;
|
||||
if(bt->state.type == BtStatePacketSetup) {
|
||||
bt->state.type = BtStatePacketStart;
|
||||
} else if(bt->state.type == BtStatePacketStart) {
|
||||
bt->state.type = BtStatePacketSetup;
|
||||
}
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStartTestPacketTx,
|
||||
.param.channel = bt->state.param.channel,
|
||||
@@ -177,7 +183,63 @@ bool bt_view_test_packet_tx_input(InputEvent* event, void* context) {
|
||||
return true;
|
||||
} else if(event->key == InputKeyBack) {
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStopTestPacketTx,
|
||||
.type = BtMessageTypeStopTestPacket,
|
||||
};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
view_dispatcher_switch_to_view(bt->view_dispatcher, VIEW_NONE);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool bt_view_test_packet_rx_input(InputEvent* event, void* context) {
|
||||
furi_assert(event);
|
||||
furi_assert(context);
|
||||
Bt* bt = context;
|
||||
if(event->type == InputTypeShort) {
|
||||
if(event->key < InputKeyOk) {
|
||||
// Process InputKeyUp, InputKeyDown, InputKeyLeft, InputKeyRight
|
||||
if(event->key == InputKeyRight || event->key == InputKeyLeft) {
|
||||
bt->state.param.channel = bt_switch_channel(event->key, bt->state.param.channel);
|
||||
} else if(event->key == InputKeyUp) {
|
||||
if(bt->state.param.datarate < BtDataRate2M) {
|
||||
bt->state.param.datarate += 1;
|
||||
}
|
||||
} else if(event->key == InputKeyDown) {
|
||||
if(bt->state.param.datarate > BtDataRate1M) {
|
||||
bt->state.param.datarate -= 1;
|
||||
}
|
||||
}
|
||||
bt->state.type = BtStatePacketSetup;
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeSetupTestPacketRx,
|
||||
.param.channel = bt->state.param.channel,
|
||||
.param.datarate = bt->state.param.datarate,
|
||||
};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
return true;
|
||||
} else if(event->key == InputKeyOk) {
|
||||
if(bt->state.type == BtStatePacketSetup) {
|
||||
bt->state.type = BtStatePacketStart;
|
||||
osTimerStart(bt->update_param_timer, 200);
|
||||
} else if(bt->state.type == BtStatePacketRunning) {
|
||||
bt->state.type = BtStatePacketSetup;
|
||||
osTimerStop(bt->update_param_timer);
|
||||
}
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStartTestPacketRx,
|
||||
.param.channel = bt->state.param.channel,
|
||||
.param.datarate = bt->state.param.datarate,
|
||||
};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
return true;
|
||||
} else if(event->key == InputKeyBack) {
|
||||
if(osTimerIsRunning(bt->update_param_timer)) {
|
||||
osTimerStop(bt->update_param_timer);
|
||||
}
|
||||
BtMessage m = {
|
||||
.type = BtMessageTypeStopTestPacket,
|
||||
};
|
||||
furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
|
||||
view_dispatcher_switch_to_view(bt->view_dispatcher, VIEW_NONE);
|
||||
|
Reference in New Issue
Block a user