[FL-1237] Notifications app (#476)
* Notification app: init * Notification app: separate message sequences * Notification app: rename notifications to notification * Notification app: rework api * Notification app: new sequences for charger * Power app: add state for better led handling * Power app: NotificationSequence type, notification led process * Blink app: use notifications * Notification app: sound and vibro notifications * Notification app: note messages * Notification app: more messages * Notification app: update note message generator * Blink app: fix state counter * Notification app: fix delay event * App sd-filesystem: notifications * App notifications: headers c++ compatibility * App notifications: Cmaj success chord sequence * App iButton: use notifications * App notification: display backlight notifications * App notification: add "display on" message to success and error sequences * App accessor: use notifications * App ibutton: guard onewire key read * Lib-RFAL: remove api_hal_light usage * App notification: add blocking mode, rework display api * Cli led command: use internal notification instead of direc access to leds. * App unit test: use notifications * App lfrfid: use notifications * Apps: close notification record * App subghz: rough use of notifications * App notificaton: ignore reset flag * App strobe: removed * Lib irda decoder: fix nec decoding * App irda: fix assert, use notifications * Apps: use notifications * Fix IRDA tests * Cli: better var naming * App notification: readable sources Co-authored-by: Albert Kharisov <albert@flipperdevices.com> Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
@@ -27,6 +27,7 @@ void LfrfidApp::run(void) {
|
||||
|
||||
LfrfidApp::LfrfidApp() {
|
||||
api_hal_power_insomnia_enter();
|
||||
notification = static_cast<NotificationApp*>(furi_record_open("notification"));
|
||||
}
|
||||
|
||||
LfrfidApp::~LfrfidApp() {
|
||||
@@ -35,6 +36,8 @@ LfrfidApp::~LfrfidApp() {
|
||||
scenes.erase(it);
|
||||
}
|
||||
|
||||
furi_record_close("notification");
|
||||
|
||||
api_hal_power_insomnia_exit();
|
||||
}
|
||||
|
||||
@@ -97,25 +100,12 @@ LfrfidApp::Scene LfrfidApp::get_previous_scene() {
|
||||
|
||||
/***************************** NOTIFY *******************************/
|
||||
|
||||
void LfrfidApp::notify_init() {
|
||||
// TODO open record
|
||||
const GpioPin* vibro_record = &vibro_gpio;
|
||||
hal_gpio_init(vibro_record, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
|
||||
hal_gpio_write(vibro_record, false);
|
||||
}
|
||||
|
||||
void LfrfidApp::notify_green_blink() {
|
||||
api_hal_light_set(LightGreen, 0xFF);
|
||||
delay(10);
|
||||
api_hal_light_set(LightGreen, 0x00);
|
||||
notification_message(notification, &sequence_blink_green_10);
|
||||
}
|
||||
|
||||
void LfrfidApp::notify_green_on() {
|
||||
api_hal_light_set(LightGreen, 0xFF);
|
||||
}
|
||||
|
||||
void LfrfidApp::notify_green_off() {
|
||||
api_hal_light_set(LightGreen, 0x00);
|
||||
void LfrfidApp::notify_success() {
|
||||
notification_message(notification, &sequence_success);
|
||||
}
|
||||
|
||||
/*************************** TEXT STORE *****************************/
|
||||
|
@@ -15,6 +15,8 @@
|
||||
#include "helpers/rfid-reader.h"
|
||||
#include "helpers/rfid-timer-emulator.h"
|
||||
|
||||
#include <notification/notification-messages.h>
|
||||
|
||||
class LfrfidApp {
|
||||
public:
|
||||
void run(void);
|
||||
@@ -40,10 +42,8 @@ public:
|
||||
bool switch_to_previous_scene(uint8_t count = 1);
|
||||
Scene get_previous_scene();
|
||||
|
||||
void notify_init();
|
||||
void notify_green_blink();
|
||||
void notify_green_on();
|
||||
void notify_green_off();
|
||||
void notify_success();
|
||||
|
||||
char* get_text_store();
|
||||
uint8_t get_text_store_size();
|
||||
@@ -72,6 +72,7 @@ private:
|
||||
static const uint8_t text_store_size = 128;
|
||||
char text_store[text_store_size + 1];
|
||||
|
||||
NotificationApp* notification;
|
||||
RfidReader reader;
|
||||
RfidTimerEmulator emulator;
|
||||
RfidWriter writer;
|
||||
|
@@ -25,13 +25,13 @@ bool LfrfidSceneReadNormal::on_event(LfrfidApp* app, LfrfidEvent* event) {
|
||||
LfrfidKeyType type;
|
||||
|
||||
if(app->get_reader()->read(&type, data, data_size)) {
|
||||
app->notify_green_blink();
|
||||
|
||||
if(memcmp(last_data, data, data_size) == 0) {
|
||||
success_reads++;
|
||||
app->notify_green_blink();
|
||||
} else {
|
||||
success_reads = 1;
|
||||
memcpy(last_data, data, data_size);
|
||||
app->notify_success();
|
||||
}
|
||||
|
||||
switch(type) {
|
||||
|
@@ -31,7 +31,7 @@ bool LfrfidSceneWrite::on_event(LfrfidApp* app, LfrfidEvent* event) {
|
||||
app->get_writer()->start();
|
||||
app->get_writer()->write_em(em_data);
|
||||
app->get_writer()->stop();
|
||||
delay(100);
|
||||
delay(200);
|
||||
app->get_reader()->start(RfidReader::Type::Normal);
|
||||
} else {
|
||||
uint8_t data[LFRFID_KEY_SIZE];
|
||||
|
Reference in New Issue
Block a user