winport: add options for killing stylus off-screen
This commit is contained in:
parent
f22f05959d
commit
bf911bf571
|
@ -259,6 +259,8 @@ SPiano DefaultPiano = { false, 'Z', 'S', 'X', 'D', 'C', 'V', 'G', 'B', 'H', 'N',
|
||||||
SPaddle Paddle;
|
SPaddle Paddle;
|
||||||
SPaddle DefaultPaddle = { false, 'K', 'L' };
|
SPaddle DefaultPaddle = { false, 'K', 'L' };
|
||||||
|
|
||||||
|
bool killStylusTopScreen = false;
|
||||||
|
bool killStylusOffScreen = false;
|
||||||
bool allowUpAndDown = false;
|
bool allowUpAndDown = false;
|
||||||
bool allowBackgroundInput = false;
|
bool allowBackgroundInput = false;
|
||||||
|
|
||||||
|
@ -469,6 +471,7 @@ static void LoadInputConfig()
|
||||||
|
|
||||||
allowUpAndDown = GetPrivateProfileInt("Controls","AllowUpAndDown",0,IniName) != 0;
|
allowUpAndDown = GetPrivateProfileInt("Controls","AllowUpAndDown",0,IniName) != 0;
|
||||||
allowBackgroundInput = GetPrivateProfileInt("Controls","AllowBackgroundInput",0,IniName) != 0;
|
allowBackgroundInput = GetPrivateProfileInt("Controls","AllowBackgroundInput",0,IniName) != 0;
|
||||||
|
killStylusTopScreen = GetPrivateProfileInt("Controls","KillStylusTopScreen",0,IniName) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void WriteControl(char* name, WORD val)
|
static void WriteControl(char* name, WORD val)
|
||||||
|
@ -488,6 +491,8 @@ static void SaveInputConfig()
|
||||||
#undef DO
|
#undef DO
|
||||||
|
|
||||||
WritePrivateProfileInt("Controls","AllowUpAndDown",allowUpAndDown?1:0,IniName);
|
WritePrivateProfileInt("Controls","AllowUpAndDown",allowUpAndDown?1:0,IniName);
|
||||||
|
WritePrivateProfileInt("Controls","KillStylusTopScreen",killStylusTopScreen?1:0,IniName);
|
||||||
|
WritePrivateProfileInt("Controls","KillStylusOffScreen",killStylusOffScreen?1:0,IniName);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL di_init()
|
BOOL di_init()
|
||||||
|
@ -2208,6 +2213,8 @@ switch(msg)
|
||||||
//SendDlgItemMessage(hDlg,IDC_JPTOGGLE,BM_SETCHECK, Joypad[index].Enabled ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
//SendDlgItemMessage(hDlg,IDC_JPTOGGLE,BM_SETCHECK, Joypad[index].Enabled ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
||||||
|
|
||||||
SendDlgItemMessage(hDlg,IDC_ALLOWLEFTRIGHT,BM_SETCHECK, allowUpAndDown ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
SendDlgItemMessage(hDlg,IDC_ALLOWLEFTRIGHT,BM_SETCHECK, allowUpAndDown ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
||||||
|
SendDlgItemMessage(hDlg,IDC_KILLSTYLUSTOP,BM_SETCHECK, killStylusTopScreen ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
||||||
|
SendDlgItemMessage(hDlg,IDC_KILLSTYLUSOFF,BM_SETCHECK, killStylusOffScreen ? (WPARAM)BST_CHECKED : (WPARAM)BST_UNCHECKED, 0);
|
||||||
|
|
||||||
set_buttoninfo(index,hDlg);
|
set_buttoninfo(index,hDlg);
|
||||||
|
|
||||||
|
@ -2322,6 +2329,8 @@ switch(msg)
|
||||||
|
|
||||||
case IDOK:
|
case IDOK:
|
||||||
allowUpAndDown = IsDlgButtonChecked(hDlg, IDC_ALLOWLEFTRIGHT) != 0;
|
allowUpAndDown = IsDlgButtonChecked(hDlg, IDC_ALLOWLEFTRIGHT) != 0;
|
||||||
|
killStylusTopScreen = IsDlgButtonChecked(hDlg, IDC_KILLSTYLUSTOP) != 0;
|
||||||
|
killStylusOffScreen = IsDlgButtonChecked(hDlg, IDC_KILLSTYLUSOFF) != 0;
|
||||||
SaveInputConfig();
|
SaveInputConfig();
|
||||||
EndDialog(hDlg,0);
|
EndDialog(hDlg,0);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -322,6 +322,8 @@ CToolBar* MainWindowToolbar;
|
||||||
|
|
||||||
DWORD hKeyInputTimer;
|
DWORD hKeyInputTimer;
|
||||||
bool start_paused;
|
bool start_paused;
|
||||||
|
extern bool killStylusTopScreen;
|
||||||
|
extern bool killStylusOffScreen;
|
||||||
|
|
||||||
extern LRESULT CALLBACK RamSearchProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
|
extern LRESULT CALLBACK RamSearchProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
|
||||||
void InitRamSearch();
|
void InitRamSearch();
|
||||||
|
@ -5082,10 +5084,39 @@ DOKEYDOWN:
|
||||||
const bool isMainGPUFirst = (GPU->GetDisplayMain()->GetEngineID() == GPUEngineID_Main);
|
const bool isMainGPUFirst = (GPU->GetDisplayMain()->GetEngineID() == GPUEngineID_Main);
|
||||||
if ((video.layout == 2) && ((video.swap == 0) || (video.swap == 2 && isMainGPUFirst) || (video.swap == 3 && !isMainGPUFirst))) return 0;
|
if ((video.layout == 2) && ((video.swap == 0) || (video.swap == 2 && isMainGPUFirst) || (video.swap == 3 && !isMainGPUFirst))) return 0;
|
||||||
|
|
||||||
|
bool untouch = false;
|
||||||
ToDSScreenRelativeCoords(x,y,1);
|
ToDSScreenRelativeCoords(x,y,1);
|
||||||
if(x<0) x = 0; else if(x>255) x = 255;
|
if(x<0)
|
||||||
if(y<0) y = 0; else if(y>192) y = 192;
|
{
|
||||||
NDS_setTouchPos(x, y);
|
x = 0;
|
||||||
|
untouch |= killStylusOffScreen;
|
||||||
|
}
|
||||||
|
if(x>255)
|
||||||
|
{
|
||||||
|
x = 255;
|
||||||
|
untouch |= killStylusOffScreen;
|
||||||
|
}
|
||||||
|
if(y>191)
|
||||||
|
{
|
||||||
|
y = 191;
|
||||||
|
untouch |= killStylusOffScreen;
|
||||||
|
}
|
||||||
|
if(y<-191)
|
||||||
|
{
|
||||||
|
y = -191;
|
||||||
|
untouch |= killStylusOffScreen;
|
||||||
|
}
|
||||||
|
if(y<0)
|
||||||
|
{
|
||||||
|
y = 0;
|
||||||
|
untouch |= killStylusTopScreen;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(untouch)
|
||||||
|
NDS_releaseTouch();
|
||||||
|
else
|
||||||
|
NDS_setTouchPos(x, y);
|
||||||
|
|
||||||
winLastTouch.x = x;
|
winLastTouch.x = x;
|
||||||
winLastTouch.y = y;
|
winLastTouch.y = y;
|
||||||
userTouchesScreen = true;
|
userTouchesScreen = true;
|
||||||
|
|
|
@ -998,6 +998,9 @@
|
||||||
#define IDC_LID 50037
|
#define IDC_LID 50037
|
||||||
#define IDD_INPUTCONFIG 50038
|
#define IDD_INPUTCONFIG 50038
|
||||||
#define IDC_LABEL_BLUE1 50039
|
#define IDC_LABEL_BLUE1 50039
|
||||||
|
#define IDC_KILLSTYLUS 50039
|
||||||
|
#define IDC_KILLSTYLUSTOP 50039
|
||||||
|
#define IDC_KILLSTYLUSOFF 50040
|
||||||
#define IDC_LUASCRIPT_RESERVE_START 58000
|
#define IDC_LUASCRIPT_RESERVE_START 58000
|
||||||
#define IDC_LUASCRIPT_RESERVE_END 58099
|
#define IDC_LUASCRIPT_RESERVE_END 58099
|
||||||
#define IDD_LUARECENT_RESERVE_START 58100
|
#define IDD_LUARECENT_RESERVE_START 58100
|
||||||
|
|
|
@ -1267,9 +1267,9 @@ BEGIN
|
||||||
CONTROL " ",IDC_UPRIGHT,"InputCustom",WS_TABSTOP,163,81,71,12,WS_EX_CLIENTEDGE
|
CONTROL " ",IDC_UPRIGHT,"InputCustom",WS_TABSTOP,163,81,71,12,WS_EX_CLIENTEDGE
|
||||||
CONTROL " ",IDC_DWNRIGHT,"InputCustom",WS_TABSTOP,163,94,71,12,WS_EX_CLIENTEDGE
|
CONTROL " ",IDC_DWNRIGHT,"InputCustom",WS_TABSTOP,163,94,71,12,WS_EX_CLIENTEDGE
|
||||||
CONTROL " ",IDC_DWNLEFT,"InputCustom",WS_TABSTOP,163,107,71,12,WS_EX_CLIENTEDGE
|
CONTROL " ",IDC_DWNLEFT,"InputCustom",WS_TABSTOP,163,107,71,12,WS_EX_CLIENTEDGE
|
||||||
PUSHBUTTON "OK",IDOK,245,119,41,14
|
PUSHBUTTON "OK",IDOK,245,129,41,14
|
||||||
PUSHBUTTON "Cancel",IDCANCEL,293,119,39,14
|
PUSHBUTTON "Cancel",IDCANCEL,293,129,39,14
|
||||||
LTEXT "Blue means the button is already mapped.\nPink means it conflicts with a custom hotkey.\nRed means it's reserved by Windows.\nButtons can be disabled using Escape.",IDC_LABEL_BLUE,246,10,80,88
|
LTEXT "Blue means the button is already mapped.\nPink means it conflicts with a custom hotkey.\nRed means it's reserved by Windows.\nButtons can be disabled using Escape.",IDC_LABEL_BLUE,246,10,80,69
|
||||||
RTEXT "UP",IDC_LABEL_UP,10,18,38,8
|
RTEXT "UP",IDC_LABEL_UP,10,18,38,8
|
||||||
RTEXT "RIGHT",IDC_LABEL_RIGHT,8,58,41,8
|
RTEXT "RIGHT",IDC_LABEL_RIGHT,8,58,41,8
|
||||||
RTEXT "LEFT",IDC_LABEL_LEFT,11,31,37,8
|
RTEXT "LEFT",IDC_LABEL_LEFT,11,31,37,8
|
||||||
|
@ -1286,12 +1286,14 @@ BEGIN
|
||||||
RTEXT "DN RIGHT",IDC_LABEL_DOWNRIGHT,124,97,36,8
|
RTEXT "DN RIGHT",IDC_LABEL_DOWNRIGHT,124,97,36,8
|
||||||
RTEXT "UP RIGHT",IDC_LABEL_UPRIGHT,124,84,36,8
|
RTEXT "UP RIGHT",IDC_LABEL_UPRIGHT,124,84,36,8
|
||||||
RTEXT "DN LEFT",IDC_LABEL_DOWNLEFT,129,109,31,8
|
RTEXT "DN LEFT",IDC_LABEL_DOWNLEFT,129,109,31,8
|
||||||
CONTROL "Allow Left+Rt/Up+Dn",IDC_ALLOWLEFTRIGHT,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,245,102,87,11
|
CONTROL "Allow Left+Rt/Up+Dn",IDC_ALLOWLEFTRIGHT,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,245,86,87,11
|
||||||
GROUPBOX "Buttons",IDC_STATIC,7,7,234,129,0,WS_EX_TRANSPARENT
|
GROUPBOX "Buttons",IDC_STATIC,7,7,234,129,0,WS_EX_TRANSPARENT
|
||||||
CONTROL "",IDC_LID,"InputCustom",WS_TABSTOP,52,120,71,12,WS_EX_CLIENTEDGE
|
CONTROL "",IDC_LID,"InputCustom",WS_TABSTOP,52,120,71,12,WS_EX_CLIENTEDGE
|
||||||
RTEXT "LID",IDC_LABEL_X2,8,121,39,8
|
RTEXT "LID",IDC_LABEL_X2,8,121,39,8
|
||||||
RTEXT "DEBUG",IDC_LABEL_X3,127,123,29,8
|
RTEXT "DEBUG",IDC_LABEL_X3,127,123,29,8
|
||||||
CONTROL " ",IDC_DEBUG,"InputCustom",WS_TABSTOP,163,120,71,12,WS_EX_CLIENTEDGE
|
CONTROL " ",IDC_DEBUG,"InputCustom",WS_TABSTOP,163,120,71,12,WS_EX_CLIENTEDGE
|
||||||
|
CONTROL "Kill stylus on top screen",IDC_KILLSTYLUSTOP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,245,102,87,11
|
||||||
|
CONTROL "Kill stylus off-screen",IDC_KILLSTYLUSOFF,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,245,114,87,11
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_KEYCUSTOM DIALOGEX 0, 0, 382, 180
|
IDD_KEYCUSTOM DIALOGEX 0, 0, 382, 180
|
||||||
|
@ -1906,6 +1908,10 @@ BEGIN
|
||||||
BOTTOMMARGIN, 140
|
BOTTOMMARGIN, 140
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_INPUTCONFIG, DIALOG
|
||||||
|
BEGIN
|
||||||
|
END
|
||||||
|
|
||||||
IDD_GBASLOT_PIANO, DIALOG
|
IDD_GBASLOT_PIANO, DIALOG
|
||||||
BEGIN
|
BEGIN
|
||||||
LEFTMARGIN, 7
|
LEFTMARGIN, 7
|
||||||
|
|
Loading…
Reference in New Issue