Initial merge of RedInquisitive's branch
It all merged, it compiled and it works. There are 2 separate implementations of POV switches in this which I haven't sorted out yet, if that's necessary (1 for each type, it's ok I guess?)
This commit is contained in:
commit
b3fe66858b
14 changed files with 99 additions and 22 deletions
5
.gitignore
vendored
5
.gitignore
vendored
|
@ -1,9 +1,10 @@
|
||||||
3DS/build/
|
3DS/build/
|
||||||
3DS/*.elf
|
3DS/*.elf
|
||||||
3DS/*stripped.elf
|
3DS/*stripped.elf
|
||||||
3DS/*.3dsx
|
|
||||||
3DS/*.smdh
|
3DS/*.smdh
|
||||||
3DS/*.3ds
|
3DS/*.3ds
|
||||||
3DS/*.cia
|
3DS/*.cia
|
||||||
PC/build/
|
PC/build/
|
||||||
PC/*.exe
|
*.pnproj
|
||||||
|
*.pnps
|
||||||
|
*.ppg
|
||||||
|
|
BIN
3DS/3DSController.3dsx
Normal file
BIN
3DS/3DSController.3dsx
Normal file
Binary file not shown.
|
@ -59,6 +59,8 @@ struct packet {
|
||||||
short x;
|
short x;
|
||||||
short y;
|
short y;
|
||||||
} cStick;
|
} cStick;
|
||||||
|
|
||||||
|
unsigned int volume; //way longer than needed, but it works.
|
||||||
};
|
};
|
||||||
struct keysPacket keysPacket;
|
struct keysPacket keysPacket;
|
||||||
};
|
};
|
||||||
|
@ -84,4 +86,4 @@ bool openSocket(int port);
|
||||||
void sendBuf(int length);
|
void sendBuf(int length);
|
||||||
int receiveBuffer(int length);
|
int receiveBuffer(int length);
|
||||||
void sendConnectionRequest(void);
|
void sendConnectionRequest(void);
|
||||||
void sendKeys(unsigned int keys, circlePosition circlePad, touchPosition touch, circlePosition cStick);
|
void sendKeys(unsigned int keys, circlePosition circlePad, touchPosition touch, circlePosition cStick, unsigned int volume);
|
||||||
|
|
|
@ -34,8 +34,8 @@ int main(void) {
|
||||||
acInit();
|
acInit();
|
||||||
gfxInitDefault();
|
gfxInitDefault();
|
||||||
|
|
||||||
gfxSetDoubleBuffering(GFX_TOP, false);
|
gfxSetDoubleBuffering(GFX_TOP, true);
|
||||||
gfxSetDoubleBuffering(GFX_BOTTOM, false);
|
gfxSetDoubleBuffering(GFX_BOTTOM, true);
|
||||||
|
|
||||||
if(setjmp(exitJmp)) goto exit;
|
if(setjmp(exitJmp)) goto exit;
|
||||||
|
|
||||||
|
@ -91,8 +91,12 @@ int main(void) {
|
||||||
u32 kHeld = hidKeysHeld();
|
u32 kHeld = hidKeysHeld();
|
||||||
circlePosition circlePad;
|
circlePosition circlePad;
|
||||||
circlePosition cStick;
|
circlePosition cStick;
|
||||||
|
u8 vol8;
|
||||||
|
u8* volp = &vol8; //As a test for pointing at things.
|
||||||
hidCstickRead(&cStick);
|
hidCstickRead(&cStick);
|
||||||
hidCircleRead(&circlePad);
|
hidCircleRead(&circlePad);
|
||||||
|
HIDUSER_GetSoundVolume(volp);
|
||||||
|
u32 volume = (u32)vol8; //Upscale to 32 for transmission
|
||||||
touchPosition touch;
|
touchPosition touch;
|
||||||
touchRead(&touch);
|
touchRead(&touch);
|
||||||
|
|
||||||
|
@ -103,7 +107,11 @@ int main(void) {
|
||||||
keyboardActive = !keyboardActive;
|
keyboardActive = !keyboardActive;
|
||||||
keyboardToggle = false;
|
keyboardToggle = false;
|
||||||
|
|
||||||
if(keyboardActive) enableBacklight();
|
if(keyboardActive) {
|
||||||
|
enableBacklight();
|
||||||
|
} else {
|
||||||
|
disableBacklight();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else keyboardToggle = true;
|
else keyboardToggle = true;
|
||||||
|
@ -135,12 +143,12 @@ int main(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sendKeys(kHeld, circlePad, touch, cStick);
|
sendKeys(kHeld, circlePad, touch, cStick, volume);
|
||||||
|
drawString(10, 10, "Volume: %x", volume);
|
||||||
//receiveBuffer(sizeof(struct packet));
|
//receiveBuffer(sizeof(struct packet));
|
||||||
|
|
||||||
if((kHeld & KEY_START) && (kHeld & KEY_SELECT)) {
|
if((kHeld & KEY_START) && (kHeld & KEY_SELECT)) {
|
||||||
sendKeys(0, circlePad, touch, cStick);
|
sendKeys(0, circlePad, touch, cStick, volume);
|
||||||
longjmp(exitJmp, 1);
|
longjmp(exitJmp, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,12 +38,13 @@ void sendConnectionRequest(void) {
|
||||||
sendBuf(offsetof(struct packet, connectPacket) + sizeof(struct connectPacket));
|
sendBuf(offsetof(struct packet, connectPacket) + sizeof(struct connectPacket));
|
||||||
}
|
}
|
||||||
|
|
||||||
void sendKeys(unsigned int keys, circlePosition circlePad, touchPosition touch, circlePosition cStick) {
|
void sendKeys(unsigned int keys, circlePosition circlePad, touchPosition touch, circlePosition cStick, unsigned int volume) {
|
||||||
outBuf.command = KEYS;
|
outBuf.command = KEYS;
|
||||||
outBuf.keyboardActive = keyboardActive;
|
outBuf.keyboardActive = keyboardActive;
|
||||||
memcpy(&outBuf.keys, &keys, 4);
|
memcpy(&outBuf.keys, &keys, 4);
|
||||||
memcpy(&outBuf.circlePad, &circlePad, 4);
|
memcpy(&outBuf.circlePad, &circlePad, 4);
|
||||||
memcpy(&outBuf.touch, &touch, 4);
|
memcpy(&outBuf.touch, &touch, 4);
|
||||||
memcpy(&outBuf.cStick, &cStick, 4);
|
memcpy(&outBuf.cStick, &cStick, 4);
|
||||||
|
memcpy(&outBuf.volume, &volume, 4);
|
||||||
sendBuf(offsetof(struct packet, keysPacket) + sizeof(struct keysPacket));
|
sendBuf(offsetof(struct packet, keysPacket) + sizeof(struct keysPacket));
|
||||||
}
|
}
|
||||||
|
|
BIN
PC/3DSController.exe
Normal file
BIN
PC/3DSController.exe
Normal file
Binary file not shown.
|
@ -13,6 +13,10 @@
|
||||||
#define joyY iReport.wAxisY
|
#define joyY iReport.wAxisY
|
||||||
#define joyRX iReport.wAxisXRot
|
#define joyRX iReport.wAxisXRot
|
||||||
#define joyRY iReport.wAxisYRot
|
#define joyRY iReport.wAxisYRot
|
||||||
|
//#define joyVolume iReport.wSlider
|
||||||
|
#define joyVolume iReport.wAxisZ
|
||||||
|
#define povHat iReport.bHats
|
||||||
|
|
||||||
#define joyButtons iReport.lButtons
|
#define joyButtons iReport.lButtons
|
||||||
|
|
||||||
#define JOY_MIDDLE (128 * 128)
|
#define JOY_MIDDLE (128 * 128)
|
||||||
|
|
|
@ -3,4 +3,4 @@
|
||||||
extern unsigned char keyboardActive;
|
extern unsigned char keyboardActive;
|
||||||
extern unsigned char keyboardToggle;
|
extern unsigned char keyboardToggle;
|
||||||
|
|
||||||
inline char currentKeyboardKey(void);
|
char currentKeyboardKey(void);
|
||||||
|
|
|
@ -101,12 +101,14 @@ struct touch {
|
||||||
extern unsigned int lastKeys;
|
extern unsigned int lastKeys;
|
||||||
extern unsigned int currentKeys;
|
extern unsigned int currentKeys;
|
||||||
|
|
||||||
|
extern unsigned int volume;
|
||||||
|
|
||||||
extern struct circlePad circlePad;
|
extern struct circlePad circlePad;
|
||||||
extern struct cStick cStick;
|
extern struct cStick cStick;
|
||||||
extern struct touch lastTouch;
|
extern struct touch lastTouch;
|
||||||
extern struct touch currentTouch;
|
extern struct touch currentTouch;
|
||||||
|
|
||||||
inline unsigned int mapVirtualKey(unsigned int key);
|
unsigned int mapVirtualKey(unsigned int key);
|
||||||
void simulateKeyNewpress(unsigned int key);
|
void simulateKeyNewpress(unsigned int key);
|
||||||
void simulateKeyRelease(unsigned int key);
|
void simulateKeyRelease(unsigned int key);
|
||||||
void handleHat(unsigned int hat);
|
void handleHat(unsigned int hat);
|
||||||
|
|
|
@ -20,6 +20,7 @@ struct settings {
|
||||||
int mouseSpeed;
|
int mouseSpeed;
|
||||||
UINT vJoyDevice;
|
UINT vJoyDevice;
|
||||||
struct keyMapping A, B, X, Y, L, R, ZL, ZR, Start, Select, Tap, Left, Right, Up, Down, PadLeft, PadRight, PadUp, PadDown, CSLeft, CSRight, CSUp, CSDown;
|
struct keyMapping A, B, X, Y, L, R, ZL, ZR, Start, Select, Tap, Left, Right, Up, Down, PadLeft, PadRight, PadUp, PadDown, CSLeft, CSRight, CSUp, CSDown;
|
||||||
|
bool isUsingPov;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct settings settings;
|
extern struct settings settings;
|
||||||
|
|
|
@ -51,6 +51,8 @@ struct packet {
|
||||||
short x;
|
short x;
|
||||||
short y;
|
short y;
|
||||||
} cStick;
|
} cStick;
|
||||||
|
|
||||||
|
unsigned int volume;
|
||||||
};
|
};
|
||||||
struct keysPacket keysPacket;
|
struct keysPacket keysPacket;
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
unsigned int lastKeys;
|
unsigned int lastKeys;
|
||||||
unsigned int currentKeys;
|
unsigned int currentKeys;
|
||||||
|
unsigned int volume; //slider
|
||||||
|
|
||||||
struct circlePad circlePad;
|
struct circlePad circlePad;
|
||||||
struct cStick cStick;
|
struct cStick cStick;
|
||||||
|
@ -84,4 +85,4 @@ void handleHat(unsigned int hat) {
|
||||||
else if(hat & BIT(2)) iReport.bHats = 2;
|
else if(hat & BIT(2)) iReport.bHats = 2;
|
||||||
else if(hat & BIT(3)) iReport.bHats = 3;
|
else if(hat & BIT(3)) iReport.bHats = 3;
|
||||||
else iReport.bHats = -1;
|
else iReport.bHats = -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,15 +121,19 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmd, int nShow)
|
||||||
memcpy(&circlePad, &buffer.circlePad, 4);
|
memcpy(&circlePad, &buffer.circlePad, 4);
|
||||||
memcpy(¤tTouch, &buffer.touch, 4);
|
memcpy(¤tTouch, &buffer.touch, 4);
|
||||||
memcpy(&cStick, &buffer.cStick, 4);
|
memcpy(&cStick, &buffer.cStick, 4);
|
||||||
|
memcpy(&volume, &buffer.volume, 4);
|
||||||
|
//printf("\rVolume is currently: %x ", volume); //test
|
||||||
|
|
||||||
handleKey(KEY_A, settings.A);
|
handleKey(KEY_A, settings.A);
|
||||||
handleKey(KEY_B, settings.B);
|
handleKey(KEY_B, settings.B);
|
||||||
handleKey(KEY_SELECT, settings.Select);
|
handleKey(KEY_SELECT, settings.Select);
|
||||||
handleKey(KEY_START, settings.Start);
|
handleKey(KEY_START, settings.Start);
|
||||||
handleKey(KEY_DRIGHT, settings.Right);
|
if(!settings.isUsingPov) { //Handle normally if not using POV in settings.
|
||||||
handleKey(KEY_DLEFT, settings.Left);
|
handleKey(KEY_DRIGHT, settings.Right);
|
||||||
handleKey(KEY_DUP, settings.Up);
|
handleKey(KEY_DLEFT, settings.Left);
|
||||||
handleKey(KEY_DDOWN, settings.Down);
|
handleKey(KEY_DUP, settings.Up);
|
||||||
|
handleKey(KEY_DDOWN, settings.Down);
|
||||||
|
}
|
||||||
handleKey(KEY_R, settings.R);
|
handleKey(KEY_R, settings.R);
|
||||||
handleKey(KEY_L, settings.L);
|
handleKey(KEY_L, settings.L);
|
||||||
handleKey(KEY_ZR, settings.ZR);
|
handleKey(KEY_ZR, settings.ZR);
|
||||||
|
@ -180,18 +184,28 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmd, int nShow)
|
||||||
SetCursorPos((int)((double)currentTouch.x * widthMultiplier), (int)((double)currentTouch.y * heightMultiplier));
|
SetCursorPos((int)((double)currentTouch.x * widthMultiplier), (int)((double)currentTouch.y * heightMultiplier));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(settings.touch == joystick1) {
|
else if(settings.touch == joystick1) { //made a little bit more accurate to the screen size.
|
||||||
joyX = (currentTouch.x) * 128;
|
joyX = (int)((float)(currentTouch.x) * 102.3f);
|
||||||
joyY = (currentTouch.y) * 128;
|
joyY = (int)((float)(currentTouch.y) * 136.5f);
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(settings.touch == joystick2) {
|
else if(settings.touch == joystick2) {
|
||||||
joyRX = (currentTouch.x) * 128;
|
joyRX = (int)((float)(currentTouch.x) * 102.3f);
|
||||||
joyRY = (currentTouch.y) * 128;
|
joyRY = (int)((float)(currentTouch.y) * 136.5f);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
handleKey(KEY_TOUCH, settings.Tap);
|
handleKey(KEY_TOUCH, settings.Tap);
|
||||||
}
|
}
|
||||||
|
} else { //If we are not touching, move to center (Like if you release the joystick on a normal controller).
|
||||||
|
if(settings.touch == joystick1) {
|
||||||
|
joyX = 16383; //Halfway between the x
|
||||||
|
joyY = 16383; //Halfway between the y
|
||||||
|
}
|
||||||
|
|
||||||
|
else if(settings.touch == joystick2) {
|
||||||
|
joyRX = 16383; //Halfway between the rx
|
||||||
|
joyRY = 16383; //Halfway between the ry
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(settings.circlePad == mouse) {
|
if(settings.circlePad == mouse) {
|
||||||
|
@ -231,6 +245,43 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmd, int nShow)
|
||||||
joyRY = (128 - cStick.y) * 128;
|
joyRY = (128 - cStick.y) * 128;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(settings.isUsingPov) {
|
||||||
|
if((currentKeys & KEY_DUP) && !(currentKeys & KEY_DLEFT)) {
|
||||||
|
if((currentKeys & KEY_DRIGHT)) {
|
||||||
|
povHat = 4500;
|
||||||
|
} else {
|
||||||
|
povHat = 0;
|
||||||
|
}
|
||||||
|
} else if((currentKeys & KEY_DRIGHT)) {
|
||||||
|
if((currentKeys & KEY_DDOWN)) {
|
||||||
|
povHat = 13500;
|
||||||
|
} else {
|
||||||
|
povHat = 9000;
|
||||||
|
}
|
||||||
|
} else if((currentKeys & KEY_DDOWN)) {
|
||||||
|
if((currentKeys & KEY_DLEFT)) {
|
||||||
|
povHat = 22500;
|
||||||
|
} else {
|
||||||
|
povHat = 18000;
|
||||||
|
}
|
||||||
|
} else if((currentKeys & KEY_DLEFT)) {
|
||||||
|
if ((currentKeys & KEY_DUP)) {
|
||||||
|
povHat = 31500;
|
||||||
|
} else {
|
||||||
|
povHat = 27000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!((currentKeys & KEY_DUP) || (currentKeys & KEY_DRIGHT) || (currentKeys & KEY_DDOWN) || (currentKeys & KEY_DLEFT))) {
|
||||||
|
//If none are pressed, reset the POV hat
|
||||||
|
povHat = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
joyVolume = volume * 512;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,7 @@ struct settings defaultSettings = {
|
||||||
Start: { 1, {VK_RETURN} },
|
Start: { 1, {VK_RETURN} },
|
||||||
Select: { 1, {VK_BACK} },
|
Select: { 1, {VK_BACK} },
|
||||||
Tap: { 1, {'T'} },
|
Tap: { 1, {'T'} },
|
||||||
|
isUsingPov: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool getSetting(char *name, char *src, char *dest) {
|
static bool getSetting(char *name, char *src, char *dest) {
|
||||||
|
@ -92,6 +93,9 @@ static struct keyMapping getButton(char *string) {
|
||||||
else if(strcmp(string, "JOY14") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 5; }
|
else if(strcmp(string, "JOY14") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 5; }
|
||||||
else if(strcmp(string, "JOY15") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 6; }
|
else if(strcmp(string, "JOY15") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 6; }
|
||||||
else if(strcmp(string, "JOY16") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 7; }
|
else if(strcmp(string, "JOY16") == 0) { k.useJoypad = 2; k.joypadButton = 1 << 7; }
|
||||||
|
else if(strcmp(string, "POV") == 0) {settings.isUsingPov = true;}
|
||||||
|
//No matter what the others are, if any are set to true then we are using the POV hat for the DPad
|
||||||
|
//This would mean if any setting at all is POV then the dpad is suddenly a POV.
|
||||||
|
|
||||||
else if(strcmp(string, "NORTH") == 0) { k.useJoypad = 3; k.joypadButton = 1 << 0; }
|
else if(strcmp(string, "NORTH") == 0) { k.useJoypad = 3; k.joypadButton = 1 << 0; }
|
||||||
else if(strcmp(string, "EAST") == 0) { k.useJoypad = 3; k.joypadButton = 1 << 1; }
|
else if(strcmp(string, "EAST") == 0) { k.useJoypad = 3; k.joypadButton = 1 << 1; }
|
||||||
|
|
Loading…
Add table
Reference in a new issue