@@ -29,7 +29,7 @@ typedef struct {
|
|||||||
uint16_t versionMarker;
|
uint16_t versionMarker;
|
||||||
uint16_t length; // Length of valid bytes following
|
uint16_t length; // Length of valid bytes following
|
||||||
uint16_t settingsValues[SettingsOptionsLength];
|
uint16_t settingsValues[SettingsOptionsLength];
|
||||||
// used to make this nicely "good enough" aligned to 32 butes to make driver code trivial
|
// used to make this nicely "good enough" aligned to 32 bytes to make driver code trivial
|
||||||
uint32_t padding;
|
uint32_t padding;
|
||||||
|
|
||||||
} systemSettingsType;
|
} systemSettingsType;
|
||||||
|
|||||||
@@ -202,36 +202,23 @@ static void gui_solderingTempAdjust() {
|
|||||||
break;
|
break;
|
||||||
case BUTTON_B_LONG:
|
case BUTTON_B_LONG:
|
||||||
if (xTaskGetTickCount() - autoRepeatTimer + autoRepeatAcceleration > PRESS_ACCEL_INTERVAL_MAX) {
|
if (xTaskGetTickCount() - autoRepeatTimer + autoRepeatAcceleration > PRESS_ACCEL_INTERVAL_MAX) {
|
||||||
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
delta = -getSettingValue(SettingsOptions::TempChangeLongStep);
|
||||||
delta = getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
||||||
} else
|
|
||||||
delta = -getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
||||||
|
|
||||||
autoRepeatTimer = xTaskGetTickCount();
|
autoRepeatTimer = xTaskGetTickCount();
|
||||||
autoRepeatAcceleration += PRESS_ACCEL_STEP;
|
autoRepeatAcceleration += PRESS_ACCEL_STEP;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BUTTON_B_SHORT:
|
case BUTTON_B_SHORT:
|
||||||
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
delta = -getSettingValue(SettingsOptions::TempChangeShortStep);
|
||||||
delta = getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
||||||
} else
|
|
||||||
delta = -getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
||||||
break;
|
break;
|
||||||
case BUTTON_F_LONG:
|
case BUTTON_F_LONG:
|
||||||
if (xTaskGetTickCount() - autoRepeatTimer + autoRepeatAcceleration > PRESS_ACCEL_INTERVAL_MAX) {
|
if (xTaskGetTickCount() - autoRepeatTimer + autoRepeatAcceleration > PRESS_ACCEL_INTERVAL_MAX) {
|
||||||
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
delta = getSettingValue(SettingsOptions::TempChangeLongStep);
|
||||||
delta = -getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
||||||
} else
|
|
||||||
delta = getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
||||||
autoRepeatTimer = xTaskGetTickCount();
|
autoRepeatTimer = xTaskGetTickCount();
|
||||||
autoRepeatAcceleration += PRESS_ACCEL_STEP;
|
autoRepeatAcceleration += PRESS_ACCEL_STEP;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BUTTON_F_SHORT:
|
case BUTTON_F_SHORT:
|
||||||
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
delta = getSettingValue(SettingsOptions::TempChangeShortStep);
|
||||||
delta = -getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
||||||
} else
|
|
||||||
delta = getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@@ -239,22 +226,31 @@ static void gui_solderingTempAdjust() {
|
|||||||
if ((PRESS_ACCEL_INTERVAL_MAX - autoRepeatAcceleration) < PRESS_ACCEL_INTERVAL_MIN) {
|
if ((PRESS_ACCEL_INTERVAL_MAX - autoRepeatAcceleration) < PRESS_ACCEL_INTERVAL_MIN) {
|
||||||
autoRepeatAcceleration = PRESS_ACCEL_INTERVAL_MAX - PRESS_ACCEL_INTERVAL_MIN;
|
autoRepeatAcceleration = PRESS_ACCEL_INTERVAL_MAX - PRESS_ACCEL_INTERVAL_MIN;
|
||||||
}
|
}
|
||||||
// constrain between 10-450 C
|
// If buttons are flipped; flip the delta
|
||||||
uint16_t newTemp = getSettingValue(SettingsOptions::SolderingTemp);
|
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
||||||
newTemp += delta;
|
delta = -delta;
|
||||||
if (getSettingValue(SettingsOptions::TemperatureInF)) {
|
|
||||||
if (newTemp > MAX_TEMP_F)
|
|
||||||
newTemp = MAX_TEMP_F;
|
|
||||||
if (newTemp < MIN_TEMP_F)
|
|
||||||
newTemp = MIN_TEMP_F;
|
|
||||||
} else {
|
|
||||||
if (newTemp > MAX_TEMP_C)
|
|
||||||
newTemp = MAX_TEMP_C;
|
|
||||||
if (newTemp < MIN_TEMP_C)
|
|
||||||
newTemp = MIN_TEMP_C;
|
|
||||||
}
|
}
|
||||||
setSettingValue(SettingsOptions::SolderingTemp, newTemp);
|
if (delta != 0) {
|
||||||
|
// constrain between the set temp limits, i.e. 10-450 C
|
||||||
|
int16_t newTemp = getSettingValue(SettingsOptions::SolderingTemp);
|
||||||
|
newTemp += delta;
|
||||||
|
// Round to nearest increment of delta
|
||||||
|
delta = abs(delta);
|
||||||
|
newTemp = (newTemp / delta) * delta;
|
||||||
|
|
||||||
|
if (getSettingValue(SettingsOptions::TemperatureInF)) {
|
||||||
|
if (newTemp > MAX_TEMP_F)
|
||||||
|
newTemp = MAX_TEMP_F;
|
||||||
|
if (newTemp < MIN_TEMP_F)
|
||||||
|
newTemp = MIN_TEMP_F;
|
||||||
|
} else {
|
||||||
|
if (newTemp > MAX_TEMP_C)
|
||||||
|
newTemp = MAX_TEMP_C;
|
||||||
|
if (newTemp < MIN_TEMP_C)
|
||||||
|
newTemp = MIN_TEMP_C;
|
||||||
|
}
|
||||||
|
setSettingValue(SettingsOptions::SolderingTemp, (uint16_t)newTemp);
|
||||||
|
}
|
||||||
if (xTaskGetTickCount() - lastChange > (TICKS_SECOND * 2))
|
if (xTaskGetTickCount() - lastChange > (TICKS_SECOND * 2))
|
||||||
return; // exit if user just doesn't press anything for a bit
|
return; // exit if user just doesn't press anything for a bit
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user