You've already forked TEF6686_ESP32
Merge pull request #77 from ohmytime/Add_100KStep_for_FM
Add 100k step for fm
This commit is contained in:
@@ -129,6 +129,7 @@ byte SNR;
|
|||||||
byte SNRold;
|
byte SNRold;
|
||||||
byte specialstepOIRT;
|
byte specialstepOIRT;
|
||||||
byte stepsize;
|
byte stepsize;
|
||||||
|
byte fmminstepsize;
|
||||||
byte deepsleep;
|
byte deepsleep;
|
||||||
byte StereoLevel;
|
byte StereoLevel;
|
||||||
byte subnetclient;
|
byte subnetclient;
|
||||||
@@ -272,7 +273,7 @@ WiFiUDP Udp;
|
|||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
setupmode = true;
|
setupmode = true;
|
||||||
EEPROM.begin(261);
|
EEPROM.begin(262);
|
||||||
if (EEPROM.readByte(43) != 29) DefaultSettings();
|
if (EEPROM.readByte(43) != 29) DefaultSettings();
|
||||||
|
|
||||||
frequency = EEPROM.readUInt(0);
|
frequency = EEPROM.readUInt(0);
|
||||||
@@ -325,6 +326,7 @@ void setup() {
|
|||||||
colorinvert = EEPROM.readByte(258);
|
colorinvert = EEPROM.readByte(258);
|
||||||
deepsleep = EEPROM.readByte(259);
|
deepsleep = EEPROM.readByte(259);
|
||||||
CurrentTheme = EEPROM.readByte(260);
|
CurrentTheme = EEPROM.readByte(260);
|
||||||
|
fmminstepsize = EEPROM.readByte(261);
|
||||||
|
|
||||||
LWLowEdgeSet = FREQ_LW_LOW_EDGE_MIN; // later will read from flash
|
LWLowEdgeSet = FREQ_LW_LOW_EDGE_MIN; // later will read from flash
|
||||||
LWHighEdgeSet = FREQ_LW_HIGH_EDGE_MAX; // later will read from flash
|
LWHighEdgeSet = FREQ_LW_HIGH_EDGE_MAX; // later will read from flash
|
||||||
@@ -363,7 +365,7 @@ void setup() {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (frequency % 10 != 0) {
|
if (frequency % 10 != 0) {
|
||||||
Round50K(frequency);
|
if (fmminstepsize == 1) Round100K(frequency); else Round50K(frequency);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -1282,10 +1284,12 @@ void ModeButtonPress() {
|
|||||||
Round30K(frequency);
|
Round30K(frequency);
|
||||||
EEPROM.writeUInt(0, frequency);
|
EEPROM.writeUInt(0, frequency);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (fmminstepsize == 1) Round100K(frequency); else Round50K(frequency);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (frequency % 10 != 0) {
|
if (frequency % 10 != 0) {
|
||||||
Round50K(frequency);
|
if (fmminstepsize == 1) Round100K(frequency); else Round50K(frequency);
|
||||||
EEPROM.writeUInt(0, frequency);
|
EEPROM.writeUInt(0, frequency);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1330,6 +1334,7 @@ void ModeButtonPress() {
|
|||||||
EEPROM.writeByte(258, colorinvert);
|
EEPROM.writeByte(258, colorinvert);
|
||||||
EEPROM.writeByte(259, deepsleep);
|
EEPROM.writeByte(259, deepsleep);
|
||||||
EEPROM.writeByte(260, CurrentTheme);
|
EEPROM.writeByte(260, CurrentTheme);
|
||||||
|
EEPROM.writeByte(261, fmminstepsize);
|
||||||
EEPROM.commit();
|
EEPROM.commit();
|
||||||
Serial.end();
|
Serial.end();
|
||||||
if (wifi) remoteip = IPAddress (WiFi.localIP()[0], WiFi.localIP()[1], WiFi.localIP()[2], subnetclient);
|
if (wifi) remoteip = IPAddress (WiFi.localIP()[0], WiFi.localIP()[1], WiFi.localIP()[2], subnetclient);
|
||||||
@@ -1391,6 +1396,14 @@ void Round50K(unsigned int freq) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Round100K(unsigned int freq) {
|
||||||
|
if (freq % 10 < 5) {
|
||||||
|
frequency = (freq - freq % 10);
|
||||||
|
} else {
|
||||||
|
frequency = (freq - (freq % 10) + 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Round5K(unsigned int freqAM) {
|
void Round5K(unsigned int freqAM) {
|
||||||
if (freqAM % 10 < 3) {
|
if (freqAM % 10 < 3) {
|
||||||
frequency_AM = (freqAM - freqAM % 10);
|
frequency_AM = (freqAM - freqAM % 10);
|
||||||
@@ -1410,10 +1423,10 @@ void RoundStep() {
|
|||||||
if (frequency >= FREQ_FM_OIRT_START && frequency <= FREQ_FM_OIRT_END) {
|
if (frequency >= FREQ_FM_OIRT_START && frequency <= FREQ_FM_OIRT_END) {
|
||||||
Round30K(freq);
|
Round30K(freq);
|
||||||
} else {
|
} else {
|
||||||
Round50K(freq);
|
if (fmminstepsize == 1) Round100K(freq); else Round50K(freq);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Round50K(freq);
|
if (fmminstepsize == 1) Round100K(freq); else Round50K(freq);
|
||||||
}
|
}
|
||||||
radio.SetFreq(frequency);
|
radio.SetFreq(frequency);
|
||||||
} else {
|
} else {
|
||||||
@@ -1804,6 +1817,13 @@ void ButtonPress() {
|
|||||||
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
||||||
break;
|
break;
|
||||||
|
case 90:
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
|
tft.drawCentreString(myLanguage[language][90], 155, 70, GFXFF);
|
||||||
|
tft.drawString("KHz", 170, 110, GFXFF);
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 155, 110, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 155, 110, GFXFF);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -2200,6 +2220,13 @@ void KeyUp() {
|
|||||||
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
||||||
break;
|
break;
|
||||||
|
case 90:
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_WHITE); else tft.setTextColor(TFT_BLACK);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 155, 110, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 155, 110, GFXFF);
|
||||||
|
if (fmminstepsize) fmminstepsize = 0; else fmminstepsize = 1;
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 155, 110, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 155, 110, GFXFF);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -2590,6 +2617,13 @@ void KeyDown() {
|
|||||||
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
if (deepsleep) tft.drawCentreString(myLanguage[language][75], 155, 110, GFXFF); else tft.drawCentreString(myLanguage[language][76], 155, 110, GFXFF);
|
||||||
break;
|
break;
|
||||||
|
case 90:
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_WHITE); else tft.setTextColor(TFT_BLACK);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 155, 110, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 155, 110, GFXFF);
|
||||||
|
if (fmminstepsize) fmminstepsize = 0; else fmminstepsize = 1;
|
||||||
|
if (CurrentTheme == 7) tft.setTextColor(TFT_BLACK); else tft.setTextColor(TFT_WHITE);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 155, 110, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 155, 110, GFXFF);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -3184,7 +3218,7 @@ void BuildMenu() {
|
|||||||
switch (menupage) {
|
switch (menupage) {
|
||||||
case 1:
|
case 1:
|
||||||
tft.drawRightString("dB", 305, 30, GFXFF);
|
tft.drawRightString("dB", 305, 30, GFXFF);
|
||||||
tft.drawRightString("MHz", 305, 52, GFXFF);
|
tft.drawRightString("MHz", 305, 50, GFXFF);
|
||||||
tft.drawRightString("MHz", 305, 70, GFXFF);
|
tft.drawRightString("MHz", 305, 70, GFXFF);
|
||||||
tft.drawRightString("MHz", 305, 90, GFXFF);
|
tft.drawRightString("MHz", 305, 90, GFXFF);
|
||||||
tft.drawRightString("dB", 305, 110, GFXFF);
|
tft.drawRightString("dB", 305, 110, GFXFF);
|
||||||
@@ -3267,12 +3301,15 @@ void BuildMenu() {
|
|||||||
if (specialstepOIRT) tft.drawRightString(myLanguage[language][42], 305, 210, GFXFF); else tft.drawRightString(myLanguage[language][30], 305, 210, GFXFF);
|
if (specialstepOIRT) tft.drawRightString(myLanguage[language][42], 305, 210, GFXFF); else tft.drawRightString(myLanguage[language][30], 305, 210, GFXFF);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
|
tft.drawRightString("KHz", 305, 90, GFXFF);
|
||||||
tft.drawString(myLanguage[language][77], 14, 30, GFXFF);
|
tft.drawString(myLanguage[language][77], 14, 30, GFXFF);
|
||||||
tft.drawString(myLanguage[language][70], 14, 50, GFXFF);
|
tft.drawString(myLanguage[language][70], 14, 50, GFXFF);
|
||||||
tft.drawString(myLanguage[language][74], 14, 70, GFXFF);
|
tft.drawString(myLanguage[language][74], 14, 70, GFXFF);
|
||||||
|
tft.drawString(myLanguage[language][90], 14, 90, GFXFF);
|
||||||
tft.setTextColor(PrimaryColor);
|
tft.setTextColor(PrimaryColor);
|
||||||
tft.drawRightString(CurrentThemeString, 305, 30, GFXFF);
|
tft.drawRightString(CurrentThemeString, 305, 30, GFXFF);
|
||||||
if (deepsleep) tft.drawRightString(myLanguage[language][75], 305, 70, GFXFF); else tft.drawRightString(myLanguage[language][76], 305, 70, GFXFF);
|
if (deepsleep) tft.drawRightString(myLanguage[language][75], 305, 70, GFXFF); else tft.drawRightString(myLanguage[language][76], 305, 70, GFXFF);
|
||||||
|
if (fmminstepsize) tft.drawRightString(String(FREQ_FM_STEP_100K * 10, DEC), 265, 90, GFXFF); else tft.drawRightString(String(FREQ_FM_STEP_50K * 10, DEC), 265, 90, GFXFF);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
analogWrite(SMETERPIN, 0);
|
analogWrite(SMETERPIN, 0);
|
||||||
@@ -4976,10 +5013,10 @@ void TuneUp() {
|
|||||||
if (specialstepOIRT) {
|
if (specialstepOIRT) {
|
||||||
temp = FREQ_FM_STEP_30K;
|
temp = FREQ_FM_STEP_30K;
|
||||||
} else {
|
} else {
|
||||||
temp = FREQ_FM_STEP_50K;
|
if (fmminstepsize == 1) temp = FREQ_FM_STEP_100K; else temp = FREQ_FM_STEP_50K;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
temp = FREQ_FM_STEP_50K;
|
if (fmminstepsize == 1) temp = FREQ_FM_STEP_100K; else temp = FREQ_FM_STEP_50K;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -5055,10 +5092,10 @@ void TuneDown() {
|
|||||||
if (specialstepOIRT) {
|
if (specialstepOIRT) {
|
||||||
temp = FREQ_FM_STEP_30K;
|
temp = FREQ_FM_STEP_30K;
|
||||||
} else {
|
} else {
|
||||||
temp = FREQ_FM_STEP_50K;
|
if (fmminstepsize == 1) temp = FREQ_FM_STEP_100K; else temp = FREQ_FM_STEP_50K;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
temp = FREQ_FM_STEP_50K;
|
if (fmminstepsize == 1) temp = FREQ_FM_STEP_100K; else temp = FREQ_FM_STEP_50K;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -5393,5 +5430,6 @@ void DefaultSettings() {
|
|||||||
EEPROM.writeByte(258, 0);
|
EEPROM.writeByte(258, 0);
|
||||||
EEPROM.writeByte(259, 0);
|
EEPROM.writeByte(259, 0);
|
||||||
EEPROM.writeByte(260, 0);
|
EEPROM.writeByte(260, 0);
|
||||||
|
EEPROM.writeByte(261, 0);
|
||||||
EEPROM.commit();
|
EEPROM.commit();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,8 +12,9 @@
|
|||||||
#define FREQ_MW_STEP_9K 9
|
#define FREQ_MW_STEP_9K 9
|
||||||
#define FREQ_MW_STEP_10K 10
|
#define FREQ_MW_STEP_10K 10
|
||||||
#define FREQ_SW_STEP_5K 5
|
#define FREQ_SW_STEP_5K 5
|
||||||
#define FREQ_FM_STEP_50K 5
|
|
||||||
#define FREQ_FM_STEP_30K 3
|
#define FREQ_FM_STEP_30K 3
|
||||||
|
#define FREQ_FM_STEP_50K 5
|
||||||
|
#define FREQ_FM_STEP_100K 10
|
||||||
|
|
||||||
#define FREQ_LW_LOW_EDGE_MIN 144
|
#define FREQ_LW_LOW_EDGE_MIN 144
|
||||||
#define FREQ_LW_HIGH_EDGE_MAX 519
|
#define FREQ_LW_HIGH_EDGE_MAX 519
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
// [number of languages][number of texts][max. length of text]
|
// [number of languages][number of texts][max. length of text]
|
||||||
|
|
||||||
static const char myLanguage[9][90][85] = {
|
static const char myLanguage[9][91][85] = {
|
||||||
{ "English", // English
|
{ "English", // English
|
||||||
"Rotary direction changed", // 1
|
"Rotary direction changed", // 1
|
||||||
"Please release button", // 2
|
"Please release button", // 2
|
||||||
@@ -90,7 +90,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Nederlands", // Dutch
|
{ "Nederlands", // Dutch
|
||||||
@@ -182,7 +183,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NIET MOGELIJK", // 86
|
"NIET MOGELIJK", // 86
|
||||||
"AF niet beschikbaar", // 87
|
"AF niet beschikbaar", // 87
|
||||||
"EON niet beschikbaar", // 88
|
"EON niet beschikbaar", // 88
|
||||||
"RT+ niet beschikbaar" // 89
|
"RT+ niet beschikbaar", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
}, //
|
}, //
|
||||||
|
|
||||||
{ "Polski", // Polish
|
{ "Polski", // Polish
|
||||||
@@ -274,7 +276,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Hrvatski", // Croatian
|
{ "Hrvatski", // Croatian
|
||||||
@@ -366,7 +369,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Ελληνικά", // Greek
|
{ "Ελληνικά", // Greek
|
||||||
@@ -458,7 +462,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"ΜΗ ΔΥΝΑΤΟ", // 86
|
"ΜΗ ΔΥΝΑΤΟ", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Romana", // Romanian
|
{ "Romana", // Romanian
|
||||||
@@ -550,7 +555,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Deutsch", // German
|
{ "Deutsch", // German
|
||||||
@@ -642,7 +648,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Czech", // Czech
|
{ "Czech", // Czech
|
||||||
@@ -734,7 +741,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
|
|
||||||
{ "Slovak", // Slovak
|
{ "Slovak", // Slovak
|
||||||
@@ -826,7 +834,8 @@ static const char myLanguage[9][90][85] = {
|
|||||||
"NOT POSSIBLE", // 86
|
"NOT POSSIBLE", // 86
|
||||||
"No AF available", // 87
|
"No AF available", // 87
|
||||||
"No EON available", // 88
|
"No EON available", // 88
|
||||||
"No RT+ available" // 89
|
"No RT+ available", // 89
|
||||||
|
"FM min stepsize" // 90
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user