[FL-84] iButton app, dallas emulate + cyfral read, cyfral emulate (#253)
* maxim crc function * one wire template device and ds1990 classes * 3 fields for addr * cyfral emulator lib * add cyfral read mode, refract rendering and events * add ADC1_IN14, add adc interrupt * cyfral read mode * rename and move api-hal includes folder * build onewire libs only if we build app * start in mode 0
This commit is contained in:
@@ -1,59 +1,56 @@
|
||||
#pragma once
|
||||
#include "ibutton.h"
|
||||
#include "one_wire_slave_gpio.h"
|
||||
#include "one_wire_device_ds_1990.h"
|
||||
|
||||
class AppiButtonModeDallasEmulate : public AppTemplateMode<AppiButtonState, AppiButtonEvent> {
|
||||
public:
|
||||
const char* name = "dallas emulate";
|
||||
AppiButton* app;
|
||||
OneWireGpioSlave* onewire_slave;
|
||||
DS1990 key;
|
||||
|
||||
void event(AppiButtonEvent* event, AppiButtonState* state);
|
||||
void render(CanvasApi* canvas, AppiButtonState* state);
|
||||
void acquire();
|
||||
void release();
|
||||
|
||||
AppiButtonModeDallasEmulate(AppiButton* parent_app) {
|
||||
AppiButtonModeDallasEmulate(AppiButton* parent_app)
|
||||
: key(1, 2, 3, 4, 5, 6, 7) {
|
||||
app = parent_app;
|
||||
|
||||
// TODO open record
|
||||
const GpioPin* one_wire_pin_record = &ibutton_gpio;
|
||||
onewire_slave = new OneWireGpioSlave(one_wire_pin_record);
|
||||
onewire_slave->attach(key);
|
||||
};
|
||||
};
|
||||
|
||||
void AppiButtonModeDallasEmulate::event(AppiButtonEvent* event, AppiButtonState* state) {
|
||||
if(event->type == AppiButtonEvent::EventTypeTick) {
|
||||
app->blink_red();
|
||||
/*if(onewire_slave->emulate(state->dallas_address, 8)) {
|
||||
onewire_slave->detach(key);
|
||||
memcpy(key.id_storage, state->dallas_address[state->dallas_address_index], 8);
|
||||
onewire_slave->attach(key);
|
||||
|
||||
if(onewire_slave->emulate()) {
|
||||
app->blink_green();
|
||||
} else {
|
||||
|
||||
}*/
|
||||
}
|
||||
} else if(event->type == AppiButtonEvent::EventTypeKey) {
|
||||
if(event->value.input.state && event->value.input.input == InputUp) {
|
||||
app->decrease_dallas_address();
|
||||
}
|
||||
|
||||
if(event->value.input.state && event->value.input.input == InputDown) {
|
||||
app->increase_dallas_address();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void AppiButtonModeDallasEmulate::render(CanvasApi* canvas, AppiButtonState* state) {
|
||||
canvas->set_font(canvas, FontSecondary);
|
||||
canvas->draw_str(canvas, 2, 25, "< dallas emulate");
|
||||
canvas->draw_str(canvas, 2, 37, "unimplemented");
|
||||
{
|
||||
const uint8_t buffer_size = 32;
|
||||
char buf[buffer_size];
|
||||
snprintf(
|
||||
buf,
|
||||
buffer_size,
|
||||
"%x:%x:%x:%x:%x:%x:%x:%x",
|
||||
state->dallas_address[0],
|
||||
state->dallas_address[1],
|
||||
state->dallas_address[2],
|
||||
state->dallas_address[3],
|
||||
state->dallas_address[4],
|
||||
state->dallas_address[5],
|
||||
state->dallas_address[6],
|
||||
state->dallas_address[7]);
|
||||
canvas->draw_str(canvas, 2, 50, buf);
|
||||
}
|
||||
canvas->draw_str(canvas, 2, 25, "< Dallas emulate >");
|
||||
|
||||
app->render_dallas_list(canvas, state);
|
||||
}
|
||||
|
||||
void AppiButtonModeDallasEmulate::acquire() {
|
||||
|
||||
Reference in New Issue
Block a user