mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-18 16:53:45 +00:00
27bfe861d9
Available to configure: datarate, bandwidth and manchester decoding flag log ability added to unit_test app (it's very helpful when writing a unit_tests)
697 lines
24 KiB
C
697 lines
24 KiB
C
#include "../subghz_i.h"
|
|
#include <lib/toolbox/value_index.h>
|
|
|
|
#include <lib/subghz/protocols/raw.h>
|
|
|
|
#define TAG "SubGhzSceneReceiverConfig"
|
|
|
|
enum SubGhzSettingIndex {
|
|
SubGhzSettingIndexFrequency,
|
|
SubGhzSettingIndexHopping,
|
|
SubGhzSettingIndexModulation,
|
|
SubGhzSettingIndexDetectRaw,
|
|
SubGhzSettingIndexRSSIThreshold,
|
|
SubGhzSettingIndexSound,
|
|
SubGhzSettingIndexLock,
|
|
SubGhzSettingIndexRAWThesholdRSSI,
|
|
};
|
|
|
|
#define RAW_THRESHOLD_RSSI_COUNT 11
|
|
const char* const raw_theshold_rssi_text[RAW_THRESHOLD_RSSI_COUNT] = {
|
|
"-----",
|
|
"-85.0",
|
|
"-80.0",
|
|
"-75.0",
|
|
"-70.0",
|
|
"-65.0",
|
|
"-60.0",
|
|
"-55.0",
|
|
"-50.0",
|
|
"-45.0",
|
|
"-40.0",
|
|
|
|
};
|
|
const float raw_theshold_rssi_value[RAW_THRESHOLD_RSSI_COUNT] = {
|
|
-90.0f,
|
|
-85.0f,
|
|
-80.0f,
|
|
-75.0f,
|
|
-70.0f,
|
|
-65.0f,
|
|
-60.0f,
|
|
-55.0f,
|
|
-50.0f,
|
|
-45.0f,
|
|
-40.0f,
|
|
};
|
|
|
|
#define BANDWIDTH_COUNT 16
|
|
const char* const bandwidth_labels[BANDWIDTH_COUNT] = {
|
|
"58 kHz",
|
|
"68 kHz",
|
|
"81 kHz",
|
|
"102 kHz",
|
|
"116 kHz",
|
|
"135 kHz",
|
|
"162 kHz",
|
|
"203 kHz",
|
|
"232 kHz",
|
|
"270 kHz",
|
|
"325 kHz",
|
|
"406 kHz",
|
|
"464 kHz",
|
|
"541 kHz",
|
|
"650 kHz",
|
|
"812 kHz",
|
|
};
|
|
|
|
// Bandwidths values are ordered from F (58kHz) to 0 (812kHz)
|
|
#define BANDWIDTH_INDEX(value) ((uint8_t)15 - ((uint8_t)(value >> 4) & 0x0F))
|
|
|
|
#define MANCHESTER_FLAG_COUNT 2
|
|
const char* const manchester_flag_text[MANCHESTER_FLAG_COUNT] = {
|
|
"OFF",
|
|
"ON",
|
|
};
|
|
|
|
#define HOPPING_COUNT 2
|
|
const char* const hopping_text[HOPPING_COUNT] = {
|
|
"OFF",
|
|
"ON",
|
|
};
|
|
const uint32_t hopping_value[HOPPING_COUNT] = {
|
|
SubGhzHopperStateOFF,
|
|
SubGhzHopperStateRunnig,
|
|
};
|
|
|
|
#define DETECT_RAW_COUNT 2
|
|
const char* const detect_raw_text[DETECT_RAW_COUNT] = {
|
|
"OFF",
|
|
"ON",
|
|
};
|
|
|
|
#ifndef SUBGHZ_SAVE_DETECT_RAW_SETTING
|
|
const SubGhzProtocolFlag detect_raw_value[DETECT_RAW_COUNT] = {
|
|
SubGhzProtocolFlag_Decodable,
|
|
SubGhzProtocolFlag_Decodable | SubGhzProtocolFlag_RAW,
|
|
};
|
|
#endif
|
|
|
|
#define RSSI_THRESHOLD_COUNT 7
|
|
const char* const rssi_threshold_text[RSSI_THRESHOLD_COUNT] = {
|
|
"-72db",
|
|
"-67db",
|
|
"-62db",
|
|
"-57db",
|
|
"-52db",
|
|
"-47db",
|
|
"-42db",
|
|
};
|
|
|
|
const int rssi_threshold_value[RSSI_THRESHOLD_COUNT] = {
|
|
-72,
|
|
-67,
|
|
-62,
|
|
-57,
|
|
-52,
|
|
-47,
|
|
-42,
|
|
};
|
|
|
|
#define SPEAKER_COUNT 2
|
|
const char* const speaker_text[SPEAKER_COUNT] = {
|
|
"OFF",
|
|
"ON",
|
|
};
|
|
const uint32_t speaker_value[SPEAKER_COUNT] = {
|
|
SubGhzSpeakerStateShutdown,
|
|
SubGhzSpeakerStateEnable,
|
|
};
|
|
|
|
// Allow advanced edit only on specific preset
|
|
bool subghz_scene_receiver_config_can_edit_current_preset(SubGhz* subghz) {
|
|
SubGhzRadioPreset* preset = subghz->txrx->preset;
|
|
|
|
bool preset_name_allow_edit =
|
|
!strcmp(furi_string_get_cstr(preset->name), ADVANCED_AM_PRESET_NAME) ||
|
|
!strcmp(furi_string_get_cstr(preset->name), "CUSTOM");
|
|
|
|
return preset && preset_name_allow_edit &&
|
|
subghz_preset_custom_is_ook_modulation(preset->data, preset->data_size);
|
|
}
|
|
|
|
uint8_t subghz_scene_receiver_config_next_frequency(const uint32_t value, void* context) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
uint8_t index = 0;
|
|
for(uint8_t i = 0; i < subghz_setting_get_frequency_count(subghz->setting); i++) {
|
|
if(value == subghz_setting_get_frequency(subghz->setting, i)) {
|
|
index = i;
|
|
break;
|
|
} else {
|
|
index = subghz_setting_get_frequency_default_index(subghz->setting);
|
|
}
|
|
}
|
|
return index;
|
|
}
|
|
|
|
uint8_t subghz_scene_receiver_config_next_preset(const char* preset_name, void* context) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
uint8_t index = 0;
|
|
for(uint8_t i = 0; i < subghz_setting_get_preset_count(subghz->setting); i++) {
|
|
if(!strcmp(subghz_setting_get_preset_name(subghz->setting, i), preset_name)) {
|
|
index = i;
|
|
break;
|
|
} else {
|
|
// index = subghz_setting_get_frequency_default_index(subghz->setting);
|
|
}
|
|
}
|
|
return index;
|
|
}
|
|
|
|
// Advanced settings of preset may change if preset was changed.
|
|
// In that case - update values
|
|
static void subghz_scene_receiver_config_update_advanced(SubGhz* subghz) {
|
|
uint8_t value_index;
|
|
|
|
if(subghz->variable_item_bandwidth) {
|
|
value_index = BANDWIDTH_INDEX(subghz->txrx->raw_bandwidth);
|
|
variable_item_set_current_value_index(subghz->variable_item_bandwidth, value_index);
|
|
variable_item_set_current_value_text(
|
|
subghz->variable_item_bandwidth, bandwidth_labels[value_index]);
|
|
}
|
|
|
|
if(subghz->variable_item_datarate) {
|
|
variable_item_set_current_value_index(subghz->variable_item_datarate, 0);
|
|
|
|
char datarate_str[16] = {0};
|
|
subghz_preset_custom_printf_datarate(
|
|
subghz->txrx->raw_datarate, datarate_str, sizeof(datarate_str));
|
|
variable_item_set_current_value_text(subghz->variable_item_datarate, datarate_str);
|
|
}
|
|
|
|
if(subghz->variable_item_manchester) {
|
|
value_index = subghz->txrx->raw_manchester_enabled ? 1 : 0;
|
|
|
|
variable_item_set_current_value_index(subghz->variable_item_manchester, value_index);
|
|
variable_item_set_current_value_text(
|
|
subghz->variable_item_manchester, manchester_flag_text[value_index]);
|
|
}
|
|
}
|
|
|
|
// Apply advanced configuration to advanced am preset
|
|
static void subghz_scene_receiver_config_apply_advanced(SubGhz* subghz) {
|
|
if(subghz_scene_receiver_config_can_edit_current_preset(subghz)) {
|
|
SubGhzRadioPreset* preset = subghz->txrx->preset;
|
|
|
|
subghz_preset_custom_set_bandwidth(
|
|
preset->data, preset->data_size, subghz->txrx->raw_bandwidth);
|
|
|
|
subghz_preset_custom_set_machester_enable(
|
|
preset->data, preset->data_size, subghz->txrx->raw_manchester_enabled);
|
|
|
|
subghz_preset_custom_set_datarate(
|
|
preset->data, preset->data_size, subghz->txrx->raw_datarate);
|
|
}
|
|
}
|
|
|
|
uint8_t subghz_scene_receiver_config_hopper_value_index(
|
|
const uint32_t value,
|
|
const uint32_t values[],
|
|
uint8_t values_count,
|
|
void* context) {
|
|
furi_assert(context);
|
|
UNUSED(values_count);
|
|
SubGhz* subghz = context;
|
|
|
|
if(value == values[0]) {
|
|
return 0;
|
|
} else {
|
|
variable_item_set_current_value_text(
|
|
(VariableItem*)scene_manager_get_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig),
|
|
" -----");
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
#ifndef SUBGHZ_SAVE_DETECT_RAW_SETTING
|
|
uint8_t subghz_scene_receiver_config_detect_raw_value_index(
|
|
const SubGhzProtocolFlag value,
|
|
const SubGhzProtocolFlag values[],
|
|
uint8_t values_count) {
|
|
uint8_t index = 0;
|
|
for(uint8_t i = 0; i < values_count; i++) {
|
|
if(value == values[i]) {
|
|
index = i;
|
|
break;
|
|
}
|
|
}
|
|
return index;
|
|
}
|
|
#endif
|
|
|
|
uint8_t subghz_scene_receiver_config_rssi_threshold_value_index(
|
|
const int value,
|
|
const int values[],
|
|
uint8_t values_count) {
|
|
uint8_t index = 0;
|
|
for(uint8_t i = 0; i < values_count; i++) {
|
|
if(value == values[i]) {
|
|
index = i;
|
|
break;
|
|
}
|
|
}
|
|
return index;
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_frequency(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
if(subghz->txrx->hopper_state == SubGhzHopperStateOFF) {
|
|
char text_buf[10] = {0};
|
|
snprintf(
|
|
text_buf,
|
|
sizeof(text_buf),
|
|
"%lu.%02lu",
|
|
subghz_setting_get_frequency(subghz->setting, index) / 1000000,
|
|
(subghz_setting_get_frequency(subghz->setting, index) % 1000000) / 10000);
|
|
variable_item_set_current_value_text(item, text_buf);
|
|
subghz->txrx->preset->frequency = subghz_setting_get_frequency(subghz->setting, index);
|
|
subghz->last_settings->frequency = subghz->txrx->preset->frequency;
|
|
subghz_setting_set_default_frequency(subghz->setting, subghz->txrx->preset->frequency);
|
|
} else {
|
|
variable_item_set_current_value_index(
|
|
item, subghz_setting_get_frequency_default_index(subghz->setting));
|
|
}
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_preset(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
const char* preset_name = subghz_setting_get_preset_name(subghz->setting, index);
|
|
variable_item_set_current_value_text(item, preset_name);
|
|
//subghz->last_settings->preset = index;
|
|
|
|
subghz_preset_init(
|
|
subghz,
|
|
preset_name,
|
|
subghz->txrx->preset->frequency,
|
|
subghz_setting_get_preset_data(subghz->setting, index),
|
|
subghz_setting_get_preset_data_size(subghz->setting, index));
|
|
|
|
subghz_scene_receiver_config_update_advanced(subghz);
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_rssi_threshold(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
variable_item_set_current_value_text(item, rssi_threshold_text[index]);
|
|
subghz_protocol_decoder_raw_set_rssi_threshold(
|
|
subghz_receiver_search_decoder_base_by_name(
|
|
subghz->txrx->receiver, SUBGHZ_PROTOCOL_RAW_NAME),
|
|
rssi_threshold_value[index]);
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_detect_raw(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
//if(subghz->txrx->hopper_state == 0) {
|
|
variable_item_set_current_value_text(item, detect_raw_text[index]);
|
|
#ifdef SUBGHZ_SAVE_DETECT_RAW_SETTING
|
|
subghz->last_settings->detect_raw = index;
|
|
|
|
subghz_last_settings_set_detect_raw_values(subghz);
|
|
#else
|
|
subghz_receiver_set_filter(subghz->txrx->receiver, detect_raw_value[index]);
|
|
|
|
subghz_protocol_decoder_raw_set_auto_mode(
|
|
subghz_receiver_search_decoder_base_by_name(
|
|
subghz->txrx->receiver, SUBGHZ_PROTOCOL_RAW_NAME),
|
|
(index == 1));
|
|
#endif
|
|
/*} else {
|
|
variable_item_set_current_value_index(item, 0);
|
|
}*/
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_hopping_running(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
//if(subghz_receiver_get_filter(subghz->txrx->receiver) == SubGhzProtocolFlag_Decodable) {
|
|
variable_item_set_current_value_text(item, hopping_text[index]);
|
|
if(hopping_value[index] == SubGhzHopperStateOFF) {
|
|
char text_buf[10] = {0};
|
|
snprintf(
|
|
text_buf,
|
|
sizeof(text_buf),
|
|
"%lu.%02lu",
|
|
subghz_setting_get_default_frequency(subghz->setting) / 1000000,
|
|
(subghz_setting_get_default_frequency(subghz->setting) % 1000000) / 10000);
|
|
variable_item_set_current_value_text(
|
|
(VariableItem*)scene_manager_get_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig),
|
|
text_buf);
|
|
subghz->txrx->preset->frequency = subghz_setting_get_default_frequency(subghz->setting);
|
|
variable_item_set_current_value_index(
|
|
(VariableItem*)scene_manager_get_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig),
|
|
subghz_setting_get_frequency_default_index(subghz->setting));
|
|
} else {
|
|
variable_item_set_current_value_text(
|
|
(VariableItem*)scene_manager_get_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig),
|
|
" -----");
|
|
variable_item_set_current_value_index(
|
|
(VariableItem*)scene_manager_get_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig),
|
|
subghz_setting_get_frequency_default_index(subghz->setting));
|
|
}
|
|
|
|
subghz->txrx->hopper_state = hopping_value[index];
|
|
subghz_history_set_hopper_state(subghz->txrx->history, (index == 1));
|
|
/*} else {
|
|
variable_item_set_current_value_index(item, 0);
|
|
}*/
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_speaker(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
variable_item_set_current_value_text(item, speaker_text[index]);
|
|
subghz->txrx->speaker_state = speaker_value[index];
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_raw_threshold_rssi(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
|
|
variable_item_set_current_value_text(item, raw_theshold_rssi_text[index]);
|
|
subghz->txrx->raw_threshold_rssi = raw_theshold_rssi_value[index];
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_raw_ook_bandwidth(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
if(subghz_scene_receiver_config_can_edit_current_preset(subghz)) {
|
|
// update bandwidth value from selected index
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
subghz->txrx->raw_bandwidth = subghz_preset_custom_bandwidth_values[index];
|
|
|
|
subghz_scene_receiver_config_update_advanced(subghz);
|
|
} else {
|
|
furi_string_set(
|
|
subghz->error_str, "Read-only\nsetting!\nUse '" ADVANCED_AM_PRESET_NAME "'\npreset.");
|
|
view_dispatcher_send_custom_event(
|
|
subghz->view_dispatcher, SubGhzCustomEventSceneSettingError);
|
|
}
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_manchester_flag(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
if(subghz_scene_receiver_config_can_edit_current_preset(subghz)) {
|
|
// update enable flag from view
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
subghz->txrx->raw_manchester_enabled = index == 0 ? false : true;
|
|
|
|
subghz_scene_receiver_config_update_advanced(subghz);
|
|
} else {
|
|
furi_string_set(
|
|
subghz->error_str, "Read-only\nsetting!\nUse '" ADVANCED_AM_PRESET_NAME "'\npreset.");
|
|
view_dispatcher_send_custom_event(
|
|
subghz->view_dispatcher, SubGhzCustomEventSceneSettingError);
|
|
}
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_datarate_input_callback(void* context) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
|
|
float value = atoff(subghz->datarate_input_str);
|
|
if(value != 0 && value > 0) {
|
|
subghz->txrx->raw_datarate = value;
|
|
subghz_scene_receiver_config_update_advanced(subghz);
|
|
}
|
|
|
|
// show list view
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdVariableItemList);
|
|
}
|
|
|
|
static bool subghz_scene_receiver_config_datarate_input_validate(
|
|
const char* text,
|
|
FuriString* error,
|
|
void* context) {
|
|
UNUSED(context);
|
|
|
|
float value = atoff(text);
|
|
if(value == 0) {
|
|
furi_string_printf(error, "Cannot parse\r\nvalue");
|
|
} else if(value < 0) {
|
|
furi_string_printf(error, "Value\r\nshould be\r\ngreater\r\nthan 0");
|
|
} else {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_show_datarate_input(SubGhz* subghz) {
|
|
TextInput* text_input = subghz->text_input;
|
|
|
|
snprintf(
|
|
subghz->datarate_input_str,
|
|
sizeof(subghz->datarate_input_str),
|
|
"%.2f",
|
|
(double)subghz->txrx->raw_datarate);
|
|
|
|
text_input_set_header_text(text_input, "Datarate bauds (not kBauds)");
|
|
text_input_set_result_callback(
|
|
text_input,
|
|
subghz_scene_receiver_config_datarate_input_callback,
|
|
subghz,
|
|
subghz->datarate_input_str,
|
|
sizeof(subghz->datarate_input_str),
|
|
false);
|
|
|
|
text_input_set_validator(
|
|
text_input, subghz_scene_receiver_config_datarate_input_validate, NULL);
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdTextInput);
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_set_datarate(VariableItem* item) {
|
|
SubGhz* subghz = variable_item_get_context(item);
|
|
if(subghz_scene_receiver_config_can_edit_current_preset(subghz)) {
|
|
// reset value index in order to show '>' symbol always
|
|
variable_item_set_current_value_index(item, 0);
|
|
subghz_scene_receiver_config_show_datarate_input(subghz);
|
|
} else {
|
|
furi_string_set(
|
|
subghz->error_str, "Read-only\nsetting!\nUse '" ADVANCED_AM_PRESET_NAME "'\npreset.");
|
|
view_dispatcher_send_custom_event(
|
|
subghz->view_dispatcher, SubGhzCustomEventSceneSettingError);
|
|
}
|
|
}
|
|
|
|
static void subghz_scene_receiver_config_var_list_enter_callback(void* context, uint32_t index) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
if(index == SubGhzSettingIndexLock) {
|
|
view_dispatcher_send_custom_event(
|
|
subghz->view_dispatcher, SubGhzCustomEventSceneSettingLock);
|
|
}
|
|
}
|
|
|
|
void subghz_scene_receiver_config_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
VariableItem* item;
|
|
uint8_t value_index;
|
|
|
|
#ifdef FURI_DEBUG
|
|
FURI_LOG_D(
|
|
TAG,
|
|
"Last frequency: %ld, Preset: %ld",
|
|
subghz->last_settings->frequency,
|
|
subghz->last_settings->preset);
|
|
#endif
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Frequency:",
|
|
subghz_setting_get_frequency_count(subghz->setting),
|
|
subghz_scene_receiver_config_set_frequency,
|
|
subghz);
|
|
value_index =
|
|
subghz_scene_receiver_config_next_frequency(subghz->txrx->preset->frequency, subghz);
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReceiverConfig, (uint32_t)item);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
char text_buf[10] = {0};
|
|
snprintf(
|
|
text_buf,
|
|
sizeof(text_buf),
|
|
"%lu.%02lu",
|
|
subghz_setting_get_frequency(subghz->setting, value_index) / 1000000,
|
|
(subghz_setting_get_frequency(subghz->setting, value_index) % 1000000) / 10000);
|
|
variable_item_set_current_value_text(item, text_buf);
|
|
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Modulation:",
|
|
subghz_setting_get_preset_count(subghz->setting),
|
|
subghz_scene_receiver_config_set_preset,
|
|
subghz);
|
|
value_index = subghz_scene_receiver_config_next_preset(
|
|
furi_string_get_cstr(subghz->txrx->preset->name), subghz);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(
|
|
item, subghz_setting_get_preset_name(subghz->setting, value_index));
|
|
|
|
if(scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneReadRAW) !=
|
|
SubGhzCustomEventManagerSet) {
|
|
// Hopping
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Hopping:",
|
|
HOPPING_COUNT,
|
|
subghz_scene_receiver_config_set_hopping_running,
|
|
subghz);
|
|
value_index = subghz_scene_receiver_config_hopper_value_index(
|
|
subghz->txrx->hopper_state, hopping_value, HOPPING_COUNT, subghz);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, hopping_text[value_index]);
|
|
|
|
// Detect Raw
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Detect Raw:",
|
|
DETECT_RAW_COUNT,
|
|
subghz_scene_receiver_config_set_detect_raw,
|
|
subghz);
|
|
#ifdef SUBGHZ_SAVE_DETECT_RAW_SETTING
|
|
value_index = subghz->last_settings->detect_raw;
|
|
#else
|
|
value_index = subghz_scene_receiver_config_detect_raw_value_index(
|
|
subghz_receiver_get_filter(subghz->txrx->receiver),
|
|
detect_raw_value,
|
|
DETECT_RAW_COUNT);
|
|
#endif
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, detect_raw_text[value_index]);
|
|
|
|
// RSSI
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"RSSI for Raw:",
|
|
RSSI_THRESHOLD_COUNT,
|
|
subghz_scene_receiver_config_set_rssi_threshold,
|
|
subghz);
|
|
value_index = subghz_scene_receiver_config_rssi_threshold_value_index(
|
|
subghz_protocol_encoder_get_rssi_threshold(subghz_receiver_search_decoder_base_by_name(
|
|
subghz->txrx->receiver, SUBGHZ_PROTOCOL_RAW_NAME)),
|
|
rssi_threshold_value,
|
|
RSSI_THRESHOLD_COUNT);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, rssi_threshold_text[value_index]);
|
|
|
|
// Lock keyboard
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Sound:",
|
|
SPEAKER_COUNT,
|
|
subghz_scene_receiver_config_set_speaker,
|
|
subghz);
|
|
value_index =
|
|
value_index_uint32(subghz->txrx->speaker_state, speaker_value, SPEAKER_COUNT);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, speaker_text[value_index]);
|
|
|
|
variable_item_list_add(subghz->variable_item_list, "Lock Keyboard", 1, NULL, NULL);
|
|
variable_item_list_set_enter_callback(
|
|
subghz->variable_item_list,
|
|
subghz_scene_receiver_config_var_list_enter_callback,
|
|
subghz);
|
|
}
|
|
if(scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneReadRAW) ==
|
|
SubGhzCustomEventManagerSet) {
|
|
item = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"RSSI Threshold:",
|
|
RAW_THRESHOLD_RSSI_COUNT,
|
|
subghz_scene_receiver_config_set_raw_threshold_rssi,
|
|
subghz);
|
|
value_index = value_index_float(
|
|
subghz->txrx->raw_threshold_rssi, raw_theshold_rssi_value, RAW_THRESHOLD_RSSI_COUNT);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, raw_theshold_rssi_text[value_index]);
|
|
|
|
// Advanced MODEM settings. RW only for ADVANCED_AM_PRESET_NAME
|
|
// Bandwidth
|
|
subghz->variable_item_bandwidth = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Bandwidth:",
|
|
BANDWIDTH_COUNT,
|
|
subghz_scene_receiver_config_set_raw_ook_bandwidth,
|
|
subghz);
|
|
|
|
// Data rate (editable via OK click)
|
|
subghz->variable_item_datarate = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Data rate:",
|
|
2,
|
|
subghz_scene_receiver_config_set_datarate,
|
|
subghz);
|
|
|
|
// Manchester codec flag
|
|
subghz->variable_item_manchester = variable_item_list_add(
|
|
subghz->variable_item_list,
|
|
"Manch. Enc.:",
|
|
MANCHESTER_FLAG_COUNT,
|
|
subghz_scene_receiver_config_set_manchester_flag,
|
|
subghz);
|
|
|
|
subghz_scene_receiver_config_update_advanced(subghz);
|
|
}
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdVariableItemList);
|
|
}
|
|
|
|
bool subghz_scene_receiver_config_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
bool consumed = false;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == SubGhzCustomEventSceneSettingLock) {
|
|
subghz->lock = SubGhzLockOn;
|
|
scene_manager_previous_scene(subghz->scene_manager);
|
|
consumed = true;
|
|
} else if(event.event == SubGhzCustomEventSceneSettingError) {
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneShowErrorSub);
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneShowErrorSub, event.event);
|
|
consumed = true;
|
|
}
|
|
}
|
|
return consumed;
|
|
}
|
|
|
|
void subghz_scene_receiver_config_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
|
|
// reset UI variable list items (next scene may be not RAW config)
|
|
subghz->variable_item_bandwidth = NULL;
|
|
subghz->variable_item_datarate = NULL;
|
|
subghz->variable_item_manchester = NULL;
|
|
text_input_set_validator(subghz->text_input, NULL, NULL);
|
|
|
|
// apply advanced preset variables (if applicable)
|
|
subghz_scene_receiver_config_apply_advanced(subghz);
|
|
|
|
variable_item_list_set_selected_item(subghz->variable_item_list, 0);
|
|
variable_item_list_reset(subghz->variable_item_list);
|
|
subghz_last_settings_save(subghz->last_settings);
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneReadRAW, SubGhzCustomEventManagerNoSet);
|
|
}
|