parent
c4d22af61e
commit
00e96fd53b
@ -57,6 +57,7 @@ typedef union {
|
|||||||
#include "nanojpeg.h"
|
#include "nanojpeg.h"
|
||||||
#include "math.h"
|
#include "math.h"
|
||||||
#include "theme.h"
|
#include "theme.h"
|
||||||
|
#include "message-box.h"
|
||||||
|
|
||||||
void menuStartup();
|
void menuStartup();
|
||||||
void menuLoop();
|
void menuLoop();
|
||||||
|
@ -30,6 +30,7 @@ static void menuAddEntry(menuEntry_s* me) {
|
|||||||
m->firstEntry = me;
|
m->firstEntry = me;
|
||||||
m->lastEntry = me;
|
m->lastEntry = me;
|
||||||
}
|
}
|
||||||
|
m->xPos = 0;
|
||||||
m->nEntries ++;
|
m->nEntries ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -410,17 +410,16 @@ void menuLoop() {
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
static int x = 0;
|
|
||||||
static int v = 0;
|
static int v = 0;
|
||||||
|
|
||||||
if (menu->nEntries > 7) {
|
if (menu->nEntries > 7) {
|
||||||
int wanted_x = clamp(-menu->curEntry * (140 + 30), -(menu->nEntries - 7) * (140 + 30), 0);
|
int wanted_x = clamp(-menu->curEntry * (140 + 30), -(menu->nEntries - 7) * (140 + 30), 0);
|
||||||
x += v;
|
menu->xPos += v;
|
||||||
v += (wanted_x - x) / 3;
|
v += (wanted_x - menu->xPos) / 3;
|
||||||
v /= 2;
|
v /= 2;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
x = v = 0;
|
menu->xPos = v = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
menuEntry_s *active_entry = NULL;
|
menuEntry_s *active_entry = NULL;
|
||||||
@ -430,7 +429,7 @@ void menuLoop() {
|
|||||||
int entry_start_x = 29 + i * (140 + 30);
|
int entry_start_x = 29 + i * (140 + 30);
|
||||||
|
|
||||||
int screen_width = 1280;
|
int screen_width = 1280;
|
||||||
if (entry_start_x >= (screen_width - x))
|
if (entry_start_x >= (screen_width - menu->xPos))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
int is_active = i==menu->curEntry;
|
int is_active = i==menu->curEntry;
|
||||||
@ -438,7 +437,7 @@ void menuLoop() {
|
|||||||
if (is_active)
|
if (is_active)
|
||||||
active_entry = me;
|
active_entry = me;
|
||||||
|
|
||||||
drawEntry(me, entry_start_x + x, is_active);
|
drawEntry(me, entry_start_x + menu->xPos, is_active);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(active_entry != NULL) {
|
if(active_entry != NULL) {
|
||||||
|
@ -29,6 +29,7 @@ struct menu_s_tag
|
|||||||
menuEntry_s *firstEntry, *lastEntry;
|
menuEntry_s *firstEntry, *lastEntry;
|
||||||
int nEntries;
|
int nEntries;
|
||||||
int curEntry;
|
int curEntry;
|
||||||
|
int xPos;
|
||||||
|
|
||||||
char dirname[PATH_MAX+1];
|
char dirname[PATH_MAX+1];
|
||||||
};
|
};
|
||||||
@ -73,11 +74,6 @@ double menuTimer;
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void menuCreateMsgBox(int width, int height, const char *text);
|
|
||||||
void menuCloseMsgBox();
|
|
||||||
bool menuIsMsgBoxOpen();
|
|
||||||
void menuDrawMsgBox(void);
|
|
||||||
|
|
||||||
void menuEntryInit(menuEntry_s* me, MenuEntryType type);
|
void menuEntryInit(menuEntry_s* me, MenuEntryType type);
|
||||||
void menuEntryFree(menuEntry_s* me);
|
void menuEntryFree(menuEntry_s* me);
|
||||||
bool fileExists(const char* path);
|
bool fileExists(const char* path);
|
||||||
|
@ -1,12 +1,5 @@
|
|||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "message-box.h"
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
uint32_t width;
|
|
||||||
uint32_t height;
|
|
||||||
color_t *bg;
|
|
||||||
char *text;
|
|
||||||
} MessageBox;
|
|
||||||
|
|
||||||
MessageBox currMsgBox;
|
MessageBox currMsgBox;
|
||||||
|
|
||||||
@ -177,3 +170,7 @@ void menuCloseMsgBox() {
|
|||||||
currMsgBox.text = NULL;
|
currMsgBox.text = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MessageBox menuGetCurrentMsgBox() {
|
||||||
|
return currMsgBox;
|
||||||
|
}
|
||||||
|
15
common/message-box.h
Normal file
15
common/message-box.h
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
uint32_t width;
|
||||||
|
uint32_t height;
|
||||||
|
color_t *bg;
|
||||||
|
char *text;
|
||||||
|
} MessageBox;
|
||||||
|
|
||||||
|
void menuCreateMsgBox(int width, int height, const char *text);
|
||||||
|
void menuCloseMsgBox();
|
||||||
|
bool menuIsMsgBoxOpen();
|
||||||
|
void menuDrawMsgBox(void);
|
||||||
|
MessageBox menuGetCurrentMsgBox();
|
@ -3,6 +3,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "../common/common.h"
|
#include "../common/common.h"
|
||||||
|
#include "nx_touch.h"
|
||||||
|
|
||||||
uint8_t* g_framebuf;
|
uint8_t* g_framebuf;
|
||||||
u32 g_framebuf_width;
|
u32 g_framebuf_width;
|
||||||
@ -110,6 +111,7 @@ bool menuUpdate(void) {
|
|||||||
bool exitflag = 0;
|
bool exitflag = 0;
|
||||||
menu_s* menu = menuGetCurrent();
|
menu_s* menu = menuGetCurrent();
|
||||||
u32 down = hidKeysDown(CONTROLLER_P1_AUTO);
|
u32 down = hidKeysDown(CONTROLLER_P1_AUTO);
|
||||||
|
handleTouch(menu);
|
||||||
|
|
||||||
if (down & KEY_Y)
|
if (down & KEY_Y)
|
||||||
{
|
{
|
||||||
|
141
nx_main/nx_touch.c
Normal file
141
nx_main/nx_touch.c
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
#include "nx_touch.h"
|
||||||
|
|
||||||
|
#define TAP_MOVEMENT_GAP 20
|
||||||
|
#define VERTICAL_SWIPE_HORIZONTAL_PLAY 250
|
||||||
|
#define VERTICAL_SWIPE_MINIMUM_DISTANCE 300
|
||||||
|
#define LISTING_START_Y 475
|
||||||
|
#define LISTING_END_Y 647
|
||||||
|
#define BUTTON_START_Y 672
|
||||||
|
#define BUTTON_END_Y 704
|
||||||
|
#define BACK_BUTTON_START_X 966
|
||||||
|
#define BACK_BUTTON_END_X 1048
|
||||||
|
#define LAUNCH_BUTTON_START_X 1092
|
||||||
|
#define LAUNCH_BUTTON_END_X 1200
|
||||||
|
|
||||||
|
#define distance(x1, y1, x2, y2) (int) sqrt(pow(x2 - x1, 2) + pow(y2 - y1, 2))
|
||||||
|
|
||||||
|
struct touchInfo_s touchInfo;
|
||||||
|
|
||||||
|
void touchInit() {
|
||||||
|
touchInfo.gestureInProgress = false;
|
||||||
|
touchInfo.isTap = true;
|
||||||
|
touchInfo.initMenuXPos = 0;
|
||||||
|
touchInfo.initMenuIndex = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void handleTappingOnApp(menu_s* menu, int px) {
|
||||||
|
int i = 0;
|
||||||
|
menuEntry_s *me = NULL;
|
||||||
|
|
||||||
|
for (me = menu->firstEntry, i = 0; me; me = me->next, i ++) {
|
||||||
|
int entry_start_x = 29 + i * (140 + 30);
|
||||||
|
|
||||||
|
int screen_width = 1280;
|
||||||
|
if (entry_start_x >= (screen_width - menu->xPos))
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (px >= (entry_start_x + menu->xPos) && px <= (entry_start_x + menu->xPos) + 140 ) {
|
||||||
|
launchMenuEntryTask(me);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void handleTappingOnOpenLaunch(menu_s* menu) {
|
||||||
|
if (menu->nEntries > 0)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
menuEntry_s* me;
|
||||||
|
for (i = 0, me = menu->firstEntry; i != menu->curEntry; i ++, me = me->next);
|
||||||
|
launchMenuEntryTask(me);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void handleTouch(menu_s* menu) {
|
||||||
|
touchPosition currentTouch;
|
||||||
|
u32 touches = hidTouchCount();
|
||||||
|
|
||||||
|
// On touch start.
|
||||||
|
if (touches == 1 && !touchInfo.gestureInProgress) {
|
||||||
|
hidTouchRead(¤tTouch, 0);
|
||||||
|
|
||||||
|
touchInfo.gestureInProgress = true;
|
||||||
|
touchInfo.firstTouch = currentTouch;
|
||||||
|
touchInfo.prevTouch = currentTouch;
|
||||||
|
touchInfo.isTap = true;
|
||||||
|
touchInfo.initMenuXPos = menu->xPos;
|
||||||
|
touchInfo.initMenuIndex = menu->curEntry;
|
||||||
|
}
|
||||||
|
// On touch moving.
|
||||||
|
else if (touches >= 1 && touchInfo.gestureInProgress) {
|
||||||
|
hidTouchRead(¤tTouch, 0);
|
||||||
|
|
||||||
|
touchInfo.prevTouch = currentTouch;
|
||||||
|
|
||||||
|
if (touchInfo.isTap && (abs(touchInfo.firstTouch.px - currentTouch.px) > TAP_MOVEMENT_GAP || abs(touchInfo.firstTouch.py - currentTouch.py) > TAP_MOVEMENT_GAP)) {
|
||||||
|
touchInfo.isTap = false;
|
||||||
|
}
|
||||||
|
if (!menuIsMsgBoxOpen() && touchInfo.firstTouch.py > LISTING_START_Y && touchInfo.firstTouch.py < LISTING_END_Y && !touchInfo.isTap && menu->nEntries > 7) {
|
||||||
|
menu->xPos = touchInfo.initMenuXPos + (currentTouch.px - touchInfo.firstTouch.px);
|
||||||
|
menu->curEntry = touchInfo.initMenuIndex + ((int) (touchInfo.firstTouch.px - currentTouch.px) / 170);
|
||||||
|
|
||||||
|
if (menu->curEntry < 0)
|
||||||
|
menu->curEntry = 0;
|
||||||
|
|
||||||
|
if (menu->curEntry >= menu->nEntries - 6)
|
||||||
|
menu->curEntry = menu->nEntries - 7;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// On touch end.
|
||||||
|
else if (touchInfo.gestureInProgress) {
|
||||||
|
int x1 = touchInfo.firstTouch.px;
|
||||||
|
int y1 = touchInfo.firstTouch.py;
|
||||||
|
int x2 = touchInfo.prevTouch.px;
|
||||||
|
int y2 = touchInfo.prevTouch.py;
|
||||||
|
|
||||||
|
if (menuIsMsgBoxOpen()) {
|
||||||
|
MessageBox currMsgBox = menuGetCurrentMsgBox();
|
||||||
|
int start_x = 1280 / 2 - currMsgBox.width / 2;
|
||||||
|
int start_y = (720 / 2 - currMsgBox.height / 2) + (currMsgBox.height - 80);
|
||||||
|
int end_x = start_x + currMsgBox.width;
|
||||||
|
int end_y = start_y + 80;
|
||||||
|
|
||||||
|
if (x1 > start_x && x1 < end_x && y1 > start_y && y1 < end_y && touchInfo.isTap) {
|
||||||
|
menuCloseMsgBox();
|
||||||
|
}
|
||||||
|
} else if (touchInfo.isTap) {
|
||||||
|
// App Icons
|
||||||
|
if (y1 > LISTING_START_Y && y1 < LISTING_END_Y) {
|
||||||
|
handleTappingOnApp(menu, touchInfo.prevTouch.px);
|
||||||
|
}
|
||||||
|
// Bottom Buttons
|
||||||
|
else if (y1 > BUTTON_START_Y && y1 < BUTTON_END_Y) {
|
||||||
|
// Back Button for non-empty directory
|
||||||
|
if (menu->nEntries != 0 && x1 > BACK_BUTTON_START_X && x1 < BACK_BUTTON_END_X) {
|
||||||
|
launchMenuBackTask();
|
||||||
|
}
|
||||||
|
// Open/Launch Button / Back Button for empty directories
|
||||||
|
else if (x1 > LAUNCH_BUTTON_START_X && x1 < LAUNCH_BUTTON_END_X) {
|
||||||
|
if (menu->nEntries == 0) {
|
||||||
|
launchMenuBackTask();
|
||||||
|
} else {
|
||||||
|
handleTappingOnOpenLaunch(menu);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Vertical Swipe
|
||||||
|
else if (abs(x1 - x2) < VERTICAL_SWIPE_HORIZONTAL_PLAY && distance(x1, y1, x2, y2) > VERTICAL_SWIPE_MINIMUM_DISTANCE) {
|
||||||
|
// Swipe up to go back
|
||||||
|
if (y1 - y2 > 0) {
|
||||||
|
launchMenuBackTask();
|
||||||
|
}
|
||||||
|
// Swipe down to go into netloader
|
||||||
|
else if (y1 - y2 < 0) {
|
||||||
|
launchMenuNetloaderTask();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
touchInfo.gestureInProgress = false;
|
||||||
|
}
|
||||||
|
}
|
15
nx_main/nx_touch.h
Normal file
15
nx_main/nx_touch.h
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <switch.h>
|
||||||
|
#include "../common/common.h"
|
||||||
|
|
||||||
|
struct touchInfo_s {
|
||||||
|
bool gestureInProgress;
|
||||||
|
touchPosition firstTouch;
|
||||||
|
touchPosition prevTouch;
|
||||||
|
bool isTap;
|
||||||
|
int initMenuXPos;
|
||||||
|
int initMenuIndex;
|
||||||
|
};
|
||||||
|
|
||||||
|
void handleTouch(menu_s* menu);
|
Loading…
Reference in New Issue
Block a user