mirror of
				https://github.com/meshtastic/firmware.git
				synced 2025-10-25 06:12:48 +00:00 
			
		
		
		
	Rotary Encoder Update - play nice with Onebutton and small bugfix - also switches screen on when any input is processed by the broker
This commit is contained in:
		
							parent
							
								
									d81c1c08ee
								
							
						
					
					
						commit
						aca95248ee
					
				| @ -279,6 +279,12 @@ void PowerFSM_setup() | ||||
|     powerFSM.add_transition(&stateON, &stateSHUTDOWN, EVENT_SHUTDOWN, NULL, "Shutdown"); | ||||
|     powerFSM.add_transition(&stateSERIAL, &stateSHUTDOWN, EVENT_SHUTDOWN, NULL, "Shutdown"); | ||||
| 
 | ||||
|     // Inputbroker
 | ||||
|     powerFSM.add_transition(&stateLS, &stateON, EVENT_INPUT, NULL, "Input Device"); | ||||
|     powerFSM.add_transition(&stateNB, &stateON, EVENT_INPUT, NULL, "Input Device"); | ||||
|     powerFSM.add_transition(&stateDARK, &stateON, EVENT_INPUT, NULL, "Input Device"); | ||||
|     powerFSM.add_transition(&stateON, &stateON, EVENT_INPUT, NULL, "Input Device"); // restarts the sleep timer
 | ||||
| 
 | ||||
|     powerFSM.add_transition(&stateDARK, &stateON, EVENT_BLUETOOTH_PAIR, NULL, "Bluetooth pairing"); | ||||
|     powerFSM.add_transition(&stateON, &stateON, EVENT_BLUETOOTH_PAIR, NULL, "Bluetooth pairing"); | ||||
| 
 | ||||
|  | ||||
| @ -20,6 +20,7 @@ | ||||
| #define EVENT_POWER_DISCONNECTED 14 | ||||
| #define EVENT_FIRMWARE_UPDATE 15 // We just received a new firmware update packet from the phone
 | ||||
| #define EVENT_SHUTDOWN 16 //force a full shutdown now (not just sleep)
 | ||||
| #define EVENT_INPUT 17 // input broker wants something, we need to wake up and enable screen
 | ||||
| 
 | ||||
| extern Fsm powerFSM; | ||||
| extern State statePOWER, stateSERIAL; | ||||
|  | ||||
| @ -1,4 +1,5 @@ | ||||
| #include "InputBroker.h" | ||||
| #include "PowerFSM.h" // needed for event trigger
 | ||||
| 
 | ||||
| InputBroker *inputBroker; | ||||
| 
 | ||||
| @ -13,6 +14,7 @@ void InputBroker::registerSource(Observable<const InputEvent *> *source) | ||||
| 
 | ||||
| int InputBroker::handleInputEvent(const InputEvent *event) | ||||
| { | ||||
|   powerFSM.trigger(EVENT_INPUT); | ||||
|   this->notifyObservers(event); | ||||
|   return 0; | ||||
| } | ||||
| @ -54,7 +54,7 @@ int32_t RotaryEncoderInterruptBase::runOnce() | ||||
|     } | ||||
|     else if (this->action == ROTARY_ACTION_CCW) | ||||
|     { | ||||
|         DEBUG_MSG("Rotary event CW\n"); | ||||
|         DEBUG_MSG("Rotary event CCW\n"); | ||||
|         e.inputEvent = this->_eventCcw; | ||||
|     } | ||||
| 
 | ||||
| @ -84,7 +84,7 @@ void RotaryEncoderInterruptBase::intAHandler() | ||||
|         return; | ||||
|     } | ||||
|     this->rotaryLevelA = currentLevelA; | ||||
|     intHandler( | ||||
|     this->rotaryStateCCW = intHandler( | ||||
|         currentLevelA == HIGH, | ||||
|         this->rotaryLevelB, | ||||
|         ROTARY_ACTION_CCW, | ||||
|  | ||||
| @ -295,8 +295,12 @@ class ButtonThread : public OSThread | ||||
|     static void userButtonPressed() | ||||
|     { | ||||
|         // DEBUG_MSG("press!\n");
 | ||||
| #ifdef BUTTON_PIN | ||||
|         if ((BUTTON_PIN != radioConfig.preferences.rotary1_pin_press) || !radioConfig.preferences.canned_message_plugin_enabled) { | ||||
|             powerFSM.trigger(EVENT_PRESS); | ||||
|         } | ||||
| #endif | ||||
|     } | ||||
|     static void userButtonPressedLong() | ||||
|     { | ||||
|         // DEBUG_MSG("Long press!\n");
 | ||||
|  | ||||
| @ -1,5 +1,6 @@ | ||||
| #include "configuration.h" | ||||
| #include "CannedMessagePlugin.h" | ||||
| #include "PowerFSM.h" // neede for button bypass
 | ||||
| #include "MeshService.h" | ||||
| 
 | ||||
| // TODO: reuse defined from Screen.cpp
 | ||||
| @ -111,9 +112,14 @@ int CannedMessagePlugin::handleInputEvent(const InputEvent *event) | ||||
|     if (event->inputEvent == static_cast<char>(InputEventChar_KEY_SELECT)) | ||||
|     { | ||||
|         DEBUG_MSG("Canned message event Select\n"); | ||||
|         // when inactive, call the onebutton shortpress instead. Activate Module only on up/down
 | ||||
|         if (this->runState == CANNED_MESSAGE_RUN_STATE_INACTIVE) { | ||||
|             powerFSM.trigger(EVENT_PRESS); | ||||
|         }else{ | ||||
|             this->runState = CANNED_MESSAGE_RUN_STATE_ACTION_SELECT; | ||||
|             validEvent = true; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (validEvent) | ||||
|     { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Thomas Göttgens
						Thomas Göttgens