* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/*
- * Modifications copyright (c) 2012-2015 Roderick W. Smith
+ * Modifications copyright (c) 2012-2017 Roderick W. Smith
*
* Modifications distributed under the terms of the GNU General Public
* License (GPL) version 3 (GPLv3), or (at your option) any later version.
UINTN MenuExit;
EFI_STATUS TouchStatus = EFI_NOT_READY;
- EFI_ABSOLUTE_POINTER_STATE *TouchState = NULL;
+ EFI_ABSOLUTE_POINTER_STATE TouchState;
if (Screen->TimeoutSeconds > 0) {
HaveTimeout = TRUE;
// read key press or touch event (and wait for them if applicable)
if(TouchEnabled) {
- TouchStatus = refit_call2_wrapper(TouchProtocol->GetState, TouchProtocol, TouchState);
+ TouchStatus = refit_call2_wrapper(TouchProtocol->GetState, TouchProtocol, &TouchState);
}
Status = refit_call2_wrapper(ST->ConIn->ReadKeyStroke, ST->ConIn, &key);
case ' ':
MenuExit = MENU_EXIT_ENTER;
break;
+ case CHAR_BACKSPACE:
+ MenuExit = MENU_EXIT_ESCAPE;
+ break;
case '+':
+ case CHAR_TAB:
MenuExit = MENU_EXIT_DETAILS;
break;
default:
break;
}
} else { //react to touch event
- UINTN Item = FindMainMenuItem(Screen, &State, TouchState->CurrentX, TouchState->CurrentY);
+ //the TouchProtocol min/max may not match the screen size
+ UINT32 TouchScreenPosX = (TouchState.CurrentX * UGAWidth) / TouchProtocol->Mode->AbsoluteMaxX;
+ UINT32 TouchScreenPosY = (TouchState.CurrentY * UGAHeight) / TouchProtocol->Mode->AbsoluteMaxY;
+
+
+ UINTN Item = FindMainMenuItem(Screen, &State, TouchScreenPosX, TouchScreenPosY);
switch (Item) {
case TOUCH_NO_ITEM:
//do nothing