mirror of
https://github.com/Ralim/IronOS.git
synced 2025-02-26 07:53:55 +00:00
* Starting GUI render refactor to be more immediate mode Update TemperatureAdjust.cpp . Cleanup Soldering Sleep SolderingProfiles Soldering Rework Rough pass GUI Temp Adjust Cleanup old OperatingMode Debug Menu * Update TemperatureAdjust.cpp * Roughing some transition work * Fixup! Hook in the init starter helper * Better home screen button handler * FIXUP! Fix typo's . * Update SettingsMenu.cpp * More settings rework * More settings rendering * Fixup * Transitions Update SolderingProfile.cpp Hook in transistions * Update TemperatureAdjust.cpp * Update push.yml * Add auto-repeat to settings menu * Miniware: Use IT for I2C writes * Update USBPDDebug_HUSB238.cpp * Force write screen on side animation cancel . * Refactor moving down the settings list * Update settingsGUI.cpp * Update I2C_Wrapper.cpp * Update OLED.cpp * Rework button handling * Fix PD debug at boot * Fixup not showing right menu options * silence some warnings * Style cleanup * Fkit use bit-bang I2C for Miniware * Update GUIRendering.md * Fixup transition on enter soldering mode * Save Settings * Fixes for some animations not running Dont bail on animations if keypress is still held * Fixup settings acceleration * OLED Up animation * Link up/down on debug meny * Make all accelerometers I2C bus aware Update accelerometers_common.h * Make I2C mag optional * Miniware -> Only Bit-Bang I2C * Fixup for scrollbar FIXUP! Debug menu returns to home screen FIXUP! Up oled animation Fix temp exit * Settings menu -> Both buttons return a menu layer * Merge fixup * Update BMA223.cpp * Re-Enable OLED sleep * Save Setting on temp adjust exit * WiP on startup mode * Some autostart working * Add hibernation mode & more autostart fixes * If cant CJC; go to startup * Hibernate in sleep * Cleanup scroll indicator * FIXUP! Ensure startup warnings are linked in * FIXUP! Ensure we render out temp change before timing out * Ensure 100ms delay between CJC samples * Fix not re-calculating menu length on entering menu * Implement NegotiationinProgress for USB-PD * Mask heating until PD finishes negotiation * Fixup staying in hibernate correctly * Warning timeout * Show reset settings warning * Correctly compensate help text start time * Update GUIThread.cpp * Update USBPD.cpp * . * Fixup sleep time * Update printSleepCountdown.cpp * replacing countdown with big plus while in boost mode * bringing back the + 1 since it was missing when not in boost mode * Bail on USB-PD check after 3 seconds incase of DC source * Fix hibernate * Update PIDThread.cpp * did center plus symbol (boost mode) * Big refactor to not make settings increment handler handle the "is last item" return * Fixup boot logo * Fix flashing * Fixup recalculate the menu length on long hold * Fixup missing menu entries * Fix junk left on screen after user confirmation * Re-order button handler to use custom, then default order to allow setting associated setting * Attach setting for settings using custom handler * Fix swap +/- keys * Fix boost temp * Implement last menu option for Language selector * Wait for init before CJC runs * Check last setting via increment value * Update BSP.cpp * removed = from >= Otherwise incrementing would stop and the scroll bar would already flash at the second to last value. * (Hacky) Fix for Settings reset --------- Co-authored-by: discip <53649486+discip@users.noreply.github.com>
107 lines
4.0 KiB
C++
107 lines
4.0 KiB
C++
#include "OperatingModes.h"
|
|
OperatingMode gui_solderingTempAdjust(const ButtonState buttonIn, guiContext *cxt) {
|
|
|
|
currentTempTargetDegC = 0; // Turn off heater while adjusting temp
|
|
uint16_t *waitForRelease = &(cxt->scratch_state.state1);
|
|
uint32_t *autoRepeatTimer = &(cxt->scratch_state.state3);
|
|
uint16_t *autoRepeatAcceleration = &(cxt->scratch_state.state2);
|
|
ButtonState buttons = buttonIn;
|
|
if (*waitForRelease == 0) {
|
|
// When we first enter we wait for the user to release buttons before enabling changes
|
|
if (buttons != BUTTON_NONE) {
|
|
buttons = BUTTON_NONE;
|
|
} else {
|
|
(*waitForRelease)++;
|
|
}
|
|
}
|
|
|
|
OLED::setCursor(0, 0);
|
|
|
|
int16_t delta = 0;
|
|
switch (buttons) {
|
|
case BUTTON_NONE:
|
|
// stay
|
|
(*autoRepeatAcceleration) = 0;
|
|
break;
|
|
case BUTTON_BOTH:
|
|
// exit
|
|
saveSettings();
|
|
cxt->transitionMode = TransitionAnimation::Right;
|
|
return cxt->previousMode;
|
|
case BUTTON_B_LONG:
|
|
if (xTaskGetTickCount() - (*autoRepeatTimer) + (*autoRepeatAcceleration) > PRESS_ACCEL_INTERVAL_MAX) {
|
|
delta = -getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
(*autoRepeatTimer) = xTaskGetTickCount();
|
|
(*autoRepeatAcceleration) += PRESS_ACCEL_STEP;
|
|
}
|
|
break;
|
|
case BUTTON_B_SHORT:
|
|
delta = -getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
break;
|
|
case BUTTON_F_LONG:
|
|
if (xTaskGetTickCount() - (*autoRepeatTimer) + (*autoRepeatAcceleration) > PRESS_ACCEL_INTERVAL_MAX) {
|
|
delta = getSettingValue(SettingsOptions::TempChangeLongStep);
|
|
(*autoRepeatTimer) = xTaskGetTickCount();
|
|
(*autoRepeatAcceleration) += PRESS_ACCEL_STEP;
|
|
}
|
|
break;
|
|
case BUTTON_F_SHORT:
|
|
delta = getSettingValue(SettingsOptions::TempChangeShortStep);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
if ((PRESS_ACCEL_INTERVAL_MAX - (*autoRepeatAcceleration)) < PRESS_ACCEL_INTERVAL_MIN) {
|
|
(*autoRepeatAcceleration) = PRESS_ACCEL_INTERVAL_MAX - PRESS_ACCEL_INTERVAL_MIN;
|
|
}
|
|
// If buttons are flipped; flip the delta
|
|
if (getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled)) {
|
|
delta = -delta;
|
|
}
|
|
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;
|
|
} else if (newTemp < MIN_TEMP_F) {
|
|
newTemp = MIN_TEMP_F;
|
|
}
|
|
} else {
|
|
if (newTemp > MAX_TEMP_C) {
|
|
newTemp = MAX_TEMP_C;
|
|
} else if (newTemp < MIN_TEMP_C) {
|
|
newTemp = MIN_TEMP_C;
|
|
}
|
|
}
|
|
setSettingValue(SettingsOptions::SolderingTemp, (uint16_t)newTemp);
|
|
}
|
|
if (OLED::getRotation()) {
|
|
OLED::print(getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled) ? LargeSymbolPlus : LargeSymbolMinus, FontStyle::LARGE);
|
|
} else {
|
|
OLED::print(getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled) ? LargeSymbolMinus : LargeSymbolPlus, FontStyle::LARGE);
|
|
}
|
|
|
|
OLED::print(LargeSymbolSpace, FontStyle::LARGE);
|
|
OLED::printNumber(getSettingValue(SettingsOptions::SolderingTemp), 3, FontStyle::LARGE);
|
|
OLED::printSymbolDeg(FontStyle::EXTRAS);
|
|
OLED::print(LargeSymbolSpace, FontStyle::LARGE);
|
|
if (OLED::getRotation()) {
|
|
OLED::print(getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled) ? LargeSymbolMinus : LargeSymbolPlus, FontStyle::LARGE);
|
|
} else {
|
|
OLED::print(getSettingValue(SettingsOptions::ReverseButtonTempChangeEnabled) ? LargeSymbolPlus : LargeSymbolMinus, FontStyle::LARGE);
|
|
}
|
|
|
|
if (xTaskGetTickCount() - lastButtonTime > (TICKS_SECOND * 3)) {
|
|
saveSettings();
|
|
cxt->transitionMode = TransitionAnimation::Right;
|
|
return cxt->previousMode; // exit if user just doesn't press anything for a bit
|
|
}
|
|
return OperatingMode::TemperatureAdjust; // Stay in temp adjust
|
|
}
|