Reuse menu running code between quicklist and numpad
This commit is contained in:
parent
61c22474e9
commit
ab8ba66067
52
menu_np_ql_shared.cpp
Normal file
52
menu_np_ql_shared.cpp
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
#include "menu_np_ql_shared.h"
|
||||||
|
|
||||||
|
#include <avr/pgmspace.h>
|
||||||
|
|
||||||
|
#include "button.h"
|
||||||
|
#include "menu_utils.h"
|
||||||
|
|
||||||
|
MenuReturn_e runNpQlShared(const ButtonPress_e tuner_button,
|
||||||
|
const ButtonPress_e touch_button,
|
||||||
|
const Point touch_point,
|
||||||
|
const int16_t knob,
|
||||||
|
int16_t *const menuSelectedItemRaw,
|
||||||
|
const Button *const *const menu_buttons,
|
||||||
|
const uint8_t menu_num_buttons,
|
||||||
|
ButtonPress_e *const selection_mode)
|
||||||
|
{
|
||||||
|
if(ButtonPress_e::NotPressed != tuner_button){
|
||||||
|
uint8_t menu_index = *menuSelectedItemRaw/MENU_KNOB_COUNTS_PER_ITEM;
|
||||||
|
Button button;
|
||||||
|
Button* bp;
|
||||||
|
memcpy_P(&bp,&(menu_buttons[menu_index]),sizeof(bp));
|
||||||
|
memcpy_P(&button,bp,sizeof(button));
|
||||||
|
*selection_mode = tuner_button;
|
||||||
|
button.on_select();
|
||||||
|
}//tuner_button
|
||||||
|
|
||||||
|
else if(ButtonPress_e::NotPressed != touch_button){
|
||||||
|
Button button;
|
||||||
|
if(findPressedButton(menu_buttons,menu_num_buttons,&button,touch_point)){
|
||||||
|
*selection_mode = touch_button;
|
||||||
|
button.on_select();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
//Touch detected, but not on our buttons, so ignore
|
||||||
|
}
|
||||||
|
}//touch_button
|
||||||
|
|
||||||
|
else{//Neither button input type found, so handle the knob
|
||||||
|
adjustSelector(menuSelectedItemRaw,
|
||||||
|
knob,
|
||||||
|
menu_buttons,
|
||||||
|
menu_num_buttons,
|
||||||
|
MorsePlaybackType_e::PlayChar);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(ButtonPress_e::NotPressed == *selection_mode){
|
||||||
|
return MenuReturn_e::ExitedRedraw;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
return MenuReturn_e::StillActive;
|
||||||
|
}
|
||||||
|
}
|
14
menu_np_ql_shared.h
Normal file
14
menu_np_ql_shared.h
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "button.h"
|
||||||
|
#include "menu.h"
|
||||||
|
|
||||||
|
MenuReturn_e runNpQlShared(const ButtonPress_e tuner_button,
|
||||||
|
const ButtonPress_e touch_button,
|
||||||
|
const Point touch_point,
|
||||||
|
const int16_t knob,
|
||||||
|
int16_t *const menuSelectedItemRaw,
|
||||||
|
const Button *const *const menu_buttons,
|
||||||
|
const uint8_t menu_num_buttons,
|
||||||
|
ButtonPress_e *const selection_mode);
|
||||||
|
|
@ -4,6 +4,7 @@
|
|||||||
#include <avr/pgmspace.h>
|
#include <avr/pgmspace.h>
|
||||||
|
|
||||||
#include "color_theme.h"
|
#include "color_theme.h"
|
||||||
|
#include "menu_np_ql_shared.h"
|
||||||
#include "menu_utils.h"
|
#include "menu_utils.h"
|
||||||
#include "nano_gui.h"
|
#include "nano_gui.h"
|
||||||
|
|
||||||
@ -36,6 +37,7 @@ void drawNumpad(void)
|
|||||||
void initNumpad(void)
|
void initNumpad(void)
|
||||||
{
|
{
|
||||||
numpadMenuFrequency = 0;
|
numpadMenuFrequency = 0;
|
||||||
|
numpadSelectionMode = ButtonPress_e::LongPress;//Anything except NotPressed
|
||||||
drawNumpad();
|
drawNumpad();
|
||||||
initSelector(&numpadMenuSelectedItemRaw,
|
initSelector(&numpadMenuSelectedItemRaw,
|
||||||
numpadMenuButtons,
|
numpadMenuButtons,
|
||||||
@ -48,39 +50,12 @@ MenuReturn_e runNumpad(const ButtonPress_e tuner_button,
|
|||||||
const Point touch_point,
|
const Point touch_point,
|
||||||
const int16_t knob)
|
const int16_t knob)
|
||||||
{
|
{
|
||||||
if(ButtonPress_e::NotPressed != tuner_button){
|
return runNpQlShared(tuner_button,
|
||||||
//We treat long and short presses the same, so no need to have a switch
|
touch_button,
|
||||||
uint8_t menu_index = numpadMenuSelectedItemRaw/MENU_KNOB_COUNTS_PER_ITEM;
|
touch_point,
|
||||||
Button button;
|
|
||||||
Button* bp;
|
|
||||||
memcpy_P(&bp,&(numpadMenuButtons[menu_index]),sizeof(bp));
|
|
||||||
memcpy_P(&button,bp,sizeof(button));
|
|
||||||
button.on_select();
|
|
||||||
}//tuner_button
|
|
||||||
|
|
||||||
else if(ButtonPress_e::NotPressed != touch_button){
|
|
||||||
//We treat long and short presses the same, so no need to have a switch
|
|
||||||
Button button;
|
|
||||||
if(findPressedButton(numpadMenuButtons,NUMPAD_MENU_NUM_BUTTONS,&button,touch_point)){
|
|
||||||
button.on_select();
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
//Touch detected, but not on our buttons, so ignore
|
|
||||||
}
|
|
||||||
}//touch_button
|
|
||||||
|
|
||||||
else{//Neither button input type found, so handle the knob
|
|
||||||
adjustSelector(&numpadMenuSelectedItemRaw,
|
|
||||||
knob,
|
knob,
|
||||||
|
&numpadMenuSelectedItemRaw,
|
||||||
numpadMenuButtons,
|
numpadMenuButtons,
|
||||||
NUMPAD_MENU_NUM_BUTTONS,
|
NUMPAD_MENU_NUM_BUTTONS,
|
||||||
MorsePlaybackType_e::PlayChar);
|
&numpadSelectionMode);
|
||||||
}
|
|
||||||
|
|
||||||
if(NUMPAD_MENU_EXIT_FREQ == numpadMenuFrequency){
|
|
||||||
return MenuReturn_e::ExitedRedraw;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
return MenuReturn_e::StillActive;
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -22,8 +22,8 @@ static const unsigned int LAYOUT_BUTTON_HEIGHT = 36;
|
|||||||
static const unsigned int LAYOUT_BUTTON_PITCH_X = 64;
|
static const unsigned int LAYOUT_BUTTON_PITCH_X = 64;
|
||||||
static const unsigned int LAYOUT_BUTTON_PITCH_Y = 40;
|
static const unsigned int LAYOUT_BUTTON_PITCH_Y = 40;
|
||||||
|
|
||||||
const uint32_t NUMPAD_MENU_EXIT_FREQ = -1;
|
|
||||||
uint32_t numpadMenuFrequency;
|
uint32_t numpadMenuFrequency;
|
||||||
|
ButtonPress_e numpadSelectionMode;
|
||||||
|
|
||||||
#define D_STRINGIFY(x) #x
|
#define D_STRINGIFY(x) #x
|
||||||
#define D_STRING(x) D_STRINGIFY(x)
|
#define D_STRING(x) D_STRINGIFY(x)
|
||||||
@ -152,10 +152,10 @@ void osOk(void)
|
|||||||
SetActiveVfoFreq(numpadMenuFrequency);
|
SetActiveVfoFreq(numpadMenuFrequency);
|
||||||
SaveSettingsToEeprom();
|
SaveSettingsToEeprom();
|
||||||
setFrequency(numpadMenuFrequency);
|
setFrequency(numpadMenuFrequency);
|
||||||
numpadMenuFrequency = NUMPAD_MENU_EXIT_FREQ;
|
numpadSelectionMode = ButtonPress_e::NotPressed;
|
||||||
}
|
}
|
||||||
|
|
||||||
void osCancel(void)
|
void osCancel(void)
|
||||||
{
|
{
|
||||||
numpadMenuFrequency = NUMPAD_MENU_EXIT_FREQ;
|
numpadSelectionMode = ButtonPress_e::NotPressed;
|
||||||
}
|
}
|
||||||
|
@ -3,9 +3,11 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#include "button.h"
|
#include "button.h"
|
||||||
|
#include "button_press_e.h"
|
||||||
|
|
||||||
extern const Button* const numpadMenuButtons[];
|
extern const Button* const numpadMenuButtons[];
|
||||||
extern const uint8_t NUMPAD_MENU_NUM_BUTTONS;
|
extern const uint8_t NUMPAD_MENU_NUM_BUTTONS;
|
||||||
|
|
||||||
extern const uint32_t NUMPAD_MENU_EXIT_FREQ;
|
extern const uint32_t NUMPAD_MENU_EXIT_FREQ;
|
||||||
extern uint32_t numpadMenuFrequency;
|
extern uint32_t numpadMenuFrequency;
|
||||||
|
extern ButtonPress_e numpadSelectionMode;//NotPressed means exit menu. Other press types are consumed by selectors
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include <WString.h>//F()
|
#include <WString.h>//F()
|
||||||
|
|
||||||
#include "color_theme.h"
|
#include "color_theme.h"
|
||||||
|
#include "menu_np_ql_shared.h"
|
||||||
#include "menu_utils.h"
|
#include "menu_utils.h"
|
||||||
#include "nano_gui.h"
|
#include "nano_gui.h"
|
||||||
#include "scratch_space.h"
|
#include "scratch_space.h"
|
||||||
@ -52,39 +53,12 @@ MenuReturn_e runQuickList(const ButtonPress_e tuner_button,
|
|||||||
const Point touch_point,
|
const Point touch_point,
|
||||||
const int16_t knob)
|
const int16_t knob)
|
||||||
{
|
{
|
||||||
if(ButtonPress_e::NotPressed != tuner_button){
|
return runNpQlShared(tuner_button,
|
||||||
uint8_t menu_index = quickListMenuSelectedItemRaw/MENU_KNOB_COUNTS_PER_ITEM;
|
touch_button,
|
||||||
Button button;
|
touch_point,
|
||||||
Button* bp;
|
|
||||||
memcpy_P(&bp,&(quickListMenuButtons[menu_index]),sizeof(bp));
|
|
||||||
memcpy_P(&button,bp,sizeof(button));
|
|
||||||
quickListSelectionMode = tuner_button;
|
|
||||||
button.on_select();
|
|
||||||
}//tuner_button
|
|
||||||
|
|
||||||
else if(ButtonPress_e::NotPressed != touch_button){
|
|
||||||
Button button;
|
|
||||||
if(findPressedButton(quickListMenuButtons,QUICKLIST_MENU_NUM_BUTTONS,&button,touch_point)){
|
|
||||||
quickListSelectionMode = touch_button;
|
|
||||||
button.on_select();
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
//Touch detected, but not on our buttons, so ignore
|
|
||||||
}
|
|
||||||
}//touch_button
|
|
||||||
|
|
||||||
else{//Neither button input type found, so handle the knob
|
|
||||||
adjustSelector(&quickListMenuSelectedItemRaw,
|
|
||||||
knob,
|
knob,
|
||||||
|
&quickListMenuSelectedItemRaw,
|
||||||
quickListMenuButtons,
|
quickListMenuButtons,
|
||||||
QUICKLIST_MENU_NUM_BUTTONS,
|
QUICKLIST_MENU_NUM_BUTTONS,
|
||||||
MorsePlaybackType_e::PlayChar);
|
&quickListSelectionMode);
|
||||||
}
|
|
||||||
|
|
||||||
if(ButtonPress_e::NotPressed == quickListSelectionMode){
|
|
||||||
return MenuReturn_e::ExitedRedraw;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
return MenuReturn_e::StillActive;
|
|
||||||
}
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user