mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-24 17:09:06 +00:00 
			
		
		
		
	Removing and adding some elements, making it more readable for others. Off-Topic: Have fun at the Grandprix! May the best win:P git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5536 8ced0084-cf51-0410-be5f-012b33b47a6e
		
			
				
	
	
		
			363 lines
		
	
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			363 lines
		
	
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright (C) 2003 Dolphin Project.
 | |
| 
 | |
| // This program is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU General Public License as published by
 | |
| // the Free Software Foundation, version 2.0.
 | |
| 
 | |
| // This program is distributed in the hope that it will be useful,
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| // GNU General Public License 2.0 for more details.
 | |
| 
 | |
| // A copy of the GPL 2.0 should have been included with the program.
 | |
| // If not, see http://www.gnu.org/licenses/
 | |
| 
 | |
| // Official SVN repository and contact information can be found at
 | |
| // http://code.google.com/p/dolphin-emu/
 | |
| 
 | |
| #ifndef _EMU_DECLARATIONS_
 | |
| #define _EMU_DECLARATIONS_
 | |
| 
 | |
| #include <vector>
 | |
| #include <string>
 | |
| 
 | |
| #include "../../../Core/InputCommon/Src/InputCommon.h" // Core
 | |
| #include "../../../Core/InputCommon/Src/SDL_Util.h"
 | |
| #ifdef _WIN32
 | |
| #include "../../../Core/InputCommon/Src/XInput_Util.h"
 | |
| #endif
 | |
| 
 | |
| #include "Common.h"
 | |
| #include "pluginspecs_wiimote.h"
 | |
| 
 | |
| #include "wiimote_hid.h" // Local
 | |
| #include "Encryption.h"
 | |
| 
 | |
| #include "UDPWiimote.h"
 | |
| 
 | |
| #if defined(HAVE_X11) && HAVE_X11
 | |
| #include <X11/X.h>
 | |
| #endif
 | |
| 
 | |
| extern SWiimoteInitialize g_WiimoteInitialize;
 | |
| 
 | |
| namespace WiiMoteEmu
 | |
| {
 | |
| 
 | |
| //******************************************************************************
 | |
| // Definitions and variable declarations
 | |
| //******************************************************************************
 | |
| 
 | |
| /* The Libogc bounding box in smoothed IR coordinates is 232,284 792,704. However, there is no
 | |
|    universal standard that works with all games. They all use their own calibration. Also,
 | |
|    there is no widescreen mode for the calibration, at least not in the games I tried, the
 | |
|    game decides for example that a horizontal value of 500 is 50% from the left of the screen,
 | |
|    and then that's the same regardless if we use the widescreen mode or not.*/
 | |
| #define LEFT 266
 | |
| #define TOP 215
 | |
| #define RIGHT 752
 | |
| #define BOTTOM 705
 | |
| /* Since the width of the entire virtual screen is 1024 a reasonable sensor bar width is perhaps 200,
 | |
|    given how small most sensor bars are compared to the total TV width. When I tried the distance with
 | |
|    my Wiimote from around three meters distance from the sensor bar (that has around 15 cm beteen the
 | |
|    IR lights) I got a dot distance of around 110 (and a dot size of between 1 and 2). */
 | |
| #define SENSOR_BAR_WIDTH 200
 | |
| 
 | |
| // Movement recording
 | |
| extern int g_RecordingPlaying[3]; 
 | |
| extern int g_RecordingCounter[3];
 | |
| extern int g_RecordingPoint[3];
 | |
| extern double g_RecordingStart[3];
 | |
| extern double g_RecordingCurrentTime[3];
 | |
| 
 | |
| // Registry sizes 
 | |
| #define WIIMOTE_EEPROM_SIZE (16*1024)
 | |
| #define WIIMOTE_EEPROM_FREE_SIZE 0x16ff
 | |
| #define WIIMOTE_REG_SPEAKER_SIZE 10
 | |
| #define WIIMOTE_REG_EXT_SIZE 0x100
 | |
| #define WIIMOTE_REG_IR_SIZE 0x34
 | |
| 
 | |
| extern u8 g_Eeprom[MAX_WIIMOTES][WIIMOTE_EEPROM_SIZE];
 | |
| extern u8 g_RegExt[MAX_WIIMOTES][WIIMOTE_REG_EXT_SIZE];
 | |
| extern u8 g_RegMotionPlus[MAX_WIIMOTES][WIIMOTE_REG_EXT_SIZE];
 | |
| extern u8 g_RegSpeaker[MAX_WIIMOTES][WIIMOTE_REG_SPEAKER_SIZE];
 | |
| extern u8 g_RegIr[MAX_WIIMOTES][WIIMOTE_REG_IR_SIZE];
 | |
| extern u8 g_IRClock[MAX_WIIMOTES];
 | |
| extern u8 g_IR[MAX_WIIMOTES];
 | |
| extern u8 g_Leds[MAX_WIIMOTES];
 | |
| extern u8 g_Speaker[MAX_WIIMOTES];
 | |
| extern u8 g_MotionPlus[MAX_WIIMOTES];
 | |
| extern u8 g_MotionPlusLastWriteReg[MAX_WIIMOTES];
 | |
| extern u8 g_SpeakerMute[MAX_WIIMOTES];
 | |
| 
 | |
| extern u8 g_RegExtTmp[WIIMOTE_REG_EXT_SIZE];
 | |
| 
 | |
| extern int g_ID;
 | |
| extern bool g_ReportingAuto[MAX_WIIMOTES];
 | |
| extern u8 g_ReportingMode[MAX_WIIMOTES];
 | |
| extern u16 g_ReportingChannel[MAX_WIIMOTES];
 | |
| extern bool g_InterleavedData[MAX_WIIMOTES];
 | |
| 
 | |
| extern wiimote_key g_ExtKey[MAX_WIIMOTES]; // extension encryption key
 | |
| extern bool g_Encryption;
 | |
| 
 | |
| /* An example of a factory default first bytes of the Eeprom memory. There are differences between
 | |
|    different Wiimotes, my Wiimote had different neutral values for the accelerometer. */
 | |
| static const u8 EepromData_0[] = {
 | |
| 	0xA1, 0xAA, 0x8B, 0x99, 0xAE, 0x9E, 0x78, 0x30, 0xA7, 0x74, 0xD3,
 | |
| 	0xA1, 0xAA, 0x8B, 0x99, 0xAE, 0x9E, 0x78, 0x30, 0xA7, 0x74, 0xD3,
 | |
| 	// Accelerometer neutral values
 | |
| 	0x82, 0x82, 0x82, 0x15, 0x9C, 0x9C, 0x9E, 0x38, 0x40, 0x3E,
 | |
| 	0x82, 0x82, 0x82, 0x15, 0x9C, 0x9C, 0x9E, 0x38, 0x40, 0x3E
 | |
| };
 | |
| 
 | |
| static const u8 EepromData_16D0[] = {
 | |
| 	0x00, 0x00, 0x00, 0xFF, 0x11, 0xEE, 0x00, 0x00,
 | |
| 	0x33, 0xCC, 0x44, 0xBB, 0x00, 0x00, 0x66, 0x99,
 | |
| 	0x77, 0x88, 0x00, 0x00, 0x2B, 0x01, 0xE8, 0x13
 | |
| };
 | |
| 
 | |
| /* Default calibration for the nunchuck. It should be written to 0x20 - 0x3f of the
 | |
|    extension register. 0x80 is the neutral x and y accelerators and 0xb3 is the
 | |
|    neutral z accelerometer that is adjusted for gravity. */
 | |
| static const u8 nunchuck_calibration[] =
 | |
| {
 | |
| 	0x80,0x80,0x80,0x00, // accelerometer x, y, z neutral
 | |
| 	0xb3,0xb3,0xb3,0x00, //  x, y, z g-force values 
 | |
| 
 | |
| 	0xff, 0x00, 0x80, 0xff, // 0xff max, 0x00 min, 0x80 = analog stick x and y axis center
 | |
| 	0x00, 0x80, 0xec, 0x41	// checksum on the last two bytes 
 | |
| };
 | |
| 
 | |
| 
 | |
| static const u8 wireless_nunchuck_calibration[] =
 | |
| {
 | |
| 	128, 128, 128, 0x00,
 | |
| 	181, 181, 181, 0x00,
 | |
| 	255, 0, 125, 255,
 | |
| 	0, 126, 0xed, 0x43
 | |
| };
 | |
| 
 | |
| /* Classic Controller calibration */
 | |
| static const u8 classic_calibration[] =
 | |
| {
 | |
| 	0xff,0x00,0x80, 0xff,0x00,0x80, 0xff,0x00,0x80, 0xff,0x00,0x80,
 | |
| 	0x00,0x00, 0x51,0xa6
 | |
| };
 | |
| 
 | |
| 
 | |
| /* Default calibration for the motion plus, 0xA60020 */
 | |
| static const u8 motion_plus_calibration[] =
 | |
| {
 | |
| 	0x79, 0xbe, 0x77, 0x5a, 0x77, 0x38, // gyroscope neutral values (each 14 bit, last 2bits unknown) fast motion
 | |
| 	0x2f, 0x90, 0xcd, 0x3b,				// "" min/max
 | |
| 	0x2f, 0xfd, 0xc8, 0x29,				// "" min/max
 | |
| 	0x9c, 0x75,							
 | |
| 
 | |
| 	0x7d, 0xd4, 0x78, 0xef, 0x78, 0x8a, // gyroscope neutral values (each 14 bit, last 2bits unknown) slow motion
 | |
| 	0x35, 0xa6, 0xc9, 0x9b,				// "" min/max
 | |
| 	0x33, 0x50,							// "" min
 | |
| 	0x2d, 0x00, 0xbd, 0x23				
 | |
| }; // TODO: figure out remaining parts;
 | |
| 
 | |
| static const u8 motionplus_accel_gyro_syncing[] = { //resulting calibration data at 0xA60050 by syncing accels and gyros
 | |
| 	0x1e, 0x54, 0x74, 0xa2, 0x96, 0xec, 0x2b, 0xd6, 0xe1, 0xef, 0xc3, 0xf7, 0x84, 0x9e, 0x06, 0xbb,
 | |
| 	0x39, 0x33, 0x3d, 0x20, 0x97, 0xed, 0x75, 0x52, 0xfd, 0x98, 0xaf, 0xd8, 0xc9, 0x5a, 0x17, 0x23,
 | |
| 	0x74, 0x3a, 0x49, 0xd3, 0xb9, 0xf6, 0xff, 0x4f, 0x34, 0xa8, 0x6d, 0xc4, 0x96, 0x5c, 0xcd, 0xb2,
 | |
| 	0x33, 0x78, 0x98, 0xe9, 0xa9, 0x7f, 0xf7, 0x5e, 0x07, 0x87, 0xbb, 0x29, 0x01, 0x2b, 0x70, 0x3f
 | |
| };
 | |
| 
 | |
| static const u8 motionplus_activeflags[] = {		//0xA600F0
 | |
| 	0x55, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x10, 0xff, 0xff, //Different flags, e.g. activation, calibration, initiaton, extensionstate.
 | |
| 	0x00, 0x00, 0xa6, 0x20, 0x00, 0x05  //Extension ID
 | |
| };
 | |
| 
 | |
| // Extension device IDs to be written to the last bytes of the extension reg
 | |
| static const u8 nunchuck_id[]	= { 0x00, 0x00, 0xa4, 0x20, 0x00, 0x00 };
 | |
| static const u8 classic_id[]	= { 0x00, 0x00, 0xa4, 0x20, 0x01, 0x01 };
 | |
| static const u8 gh3glp_id[]		= { 0x00, 0x00, 0xa4, 0x20, 0x01, 0x03 };
 | |
| static const u8 ghwtdrums_id[]	= { 0x01, 0x00, 0xa4, 0x20, 0x01, 0x03 };
 | |
| static const u8 wbb_id[]	= { 0x00, 0x00, 0xa4, 0x20, 0x4, 0x02 };
 | |
| static const u8 motionplus_id[]	= { 0x00, 0x00, 0xa4, 0x20, 0x04, 0x05 };
 | |
| static const u8 motionplusnunchuk_id[]	= { 0x00, 0x00, 0xa6, 0x20, 0x05, 0x05 };
 | |
| // The id for nothing inserted
 | |
| static const u8 nothing_id[]	= { 0x00, 0x00, 0x00, 0x00, 0x2e, 0x2e };
 | |
| // The id for a partially inserted extension
 | |
| static const u8 partially_id[]	= { 0x00, 0x00, 0x00, 0x00, 0xff, 0xff };
 | |
| 
 | |
| 
 | |
| enum EExtensionType
 | |
| {
 | |
| 	EXT_NONE = 0,
 | |
| 	EXT_NUNCHUK,
 | |
| 	EXT_CLASSIC_CONTROLLER,
 | |
| 	EXT_GUITARHERO,
 | |
| 	EXT_WBB,
 | |
| };
 | |
| 
 | |
| enum EInputType
 | |
| {
 | |
| 	FROM_KEYBOARD,
 | |
| 	FROM_ANALOG1,
 | |
| 	FROM_ANALOG2,
 | |
| 	FROM_TRIGGER,
 | |
| };
 | |
| 
 | |
| enum EButtonCode
 | |
| {
 | |
| 	EWM_A = 0, // Keyboard A and Mouse A
 | |
| 	EWM_B,
 | |
| 	EWM_ONE, EWM_TWO,
 | |
| 	EWM_P, EWM_M, EWM_H,
 | |
| 	EWM_L, EWM_R, EWM_U, EWM_D,
 | |
| 	EWM_ROLL_L, EWM_ROLL_R,
 | |
| 	EWM_PITCH_U, EWM_PITCH_D,
 | |
| 	EWM_SHAKE,
 | |
| 
 | |
| 	ENC_Z, ENC_C,
 | |
| 	ENC_L, ENC_R, ENC_U, ENC_D,
 | |
| 	ENC_ROLL_L, ENC_ROLL_R,
 | |
| 	ENC_PITCH_U, ENC_PITCH_D,
 | |
| 	ENC_SHAKE,
 | |
| 
 | |
| 	ECC_A, ECC_B, ECC_X, ECC_Y,
 | |
| 	ECC_P, ECC_M, ECC_H,
 | |
| 	ECC_Tl, ECC_Tr, ECC_Zl, ECC_Zr,
 | |
| 	ECC_Dl, ECC_Dr, ECC_Du, ECC_Dd,
 | |
| 	ECC_Ll, ECC_Lr, ECC_Lu, ECC_Ld,
 | |
| 	ECC_Rl, ECC_Rr, ECC_Ru, ECC_Rd,
 | |
| 
 | |
| 	EGH_Green, EGH_Red, EGH_Yellow, EGH_Blue, EGH_Orange,
 | |
| 	EGH_Plus, EGH_Minus, EGH_Whammy,
 | |
| 	EGH_Al, EGH_Ar, EGH_Au, EGH_Ad,
 | |
| 	EGH_StrumUp, EGH_StrumDown,
 | |
| 
 | |
| 	LAST_CONSTANT,
 | |
| };
 | |
| 
 | |
| 
 | |
| union UAxis
 | |
| {
 | |
| 	int Code[6];
 | |
| 	struct
 | |
| 	{
 | |
| 		int Lx;
 | |
| 		int Ly;
 | |
| 		int Rx;
 | |
| 		int Ry;
 | |
| 		int Tl; // Trigger
 | |
| 		int Tr; // Trigger
 | |
| 	};
 | |
| };
 | |
| 
 | |
| struct SStickMapping
 | |
| {
 | |
| 	int NC;
 | |
| 	int CCL;
 | |
| 	int CCR;
 | |
| 	int CCT; //Trigger
 | |
| 	int GH; // Analog Stick
 | |
| 	int GHB; // Whammy bar
 | |
| };
 | |
| 
 | |
| struct STiltMapping
 | |
| {
 | |
| 	int InputWM;
 | |
| 	int InputNC;
 | |
| 	bool RollInvert;
 | |
| 	bool PitchInvert;
 | |
| 	int RollDegree;
 | |
| 	bool RollSwing;
 | |
| 	int RollRange;
 | |
| 	int PitchDegree;
 | |
| 	bool PitchSwing;
 | |
| 	int PitchRange;
 | |
| };
 | |
| 
 | |
| 
 | |
| struct SDot
 | |
| {
 | |
| 	int Rx, Ry, X, Y;
 | |
| 	bool Visible;
 | |
| 	int Size; 				// Size of the IR dot (0-15)
 | |
| 	int Order;				// Increasing order from low to higher x-axis values
 | |
| };
 | |
| 
 | |
| struct SIR
 | |
| {
 | |
| 	SDot Dot[4];
 | |
| 	int Distance;
 | |
| };
 | |
| 
 | |
| struct STiltData
 | |
| {
 | |
| 	// FakeNoise is used to prevent disconnection
 | |
| 	// when there is no input for a long time
 | |
| 	int FakeNoise;
 | |
| 	int Shake;
 | |
| 	int Roll, Pitch;
 | |
| 	STiltData()
 | |
| 	{
 | |
| 		FakeNoise = 1;
 | |
| 		Shake = 0;
 | |
| 		Roll = 0;
 | |
| 		Pitch = 0;
 | |
| 	}
 | |
| };
 | |
| 
 | |
| struct SMotion
 | |
| {
 | |
| 	// Raw X and Y coordinate and processed X and Y coordinates
 | |
| 	SIR IR;
 | |
| 	STiltData TiltWM;
 | |
| 	STiltData TiltNC;
 | |
| };
 | |
| 
 | |
| struct UDPWiiSettings
 | |
| {
 | |
| 	bool enable;
 | |
| 	bool enableAccel;
 | |
| 	bool enableButtons;
 | |
| 	bool enableIR;
 | |
| 	bool enableNunchuck;
 | |
| 	char port[10];
 | |
| 	UDPWiimote *instance;
 | |
| };
 | |
| 
 | |
| struct CONTROLLER_MAPPING_WII	// WII PAD MAPPING
 | |
| {
 | |
| 	SDL_Joystick *joy;		// SDL joystick device
 | |
| 	UAxis AxisState;
 | |
| 	UAxis AxisMapping;		// 6 Axes (Main, Sub, Triggers)
 | |
| 	int TriggerType;		// SDL or XInput trigger
 | |
| 	int ID;					// SDL joystick device ID
 | |
| 	bool Rumble;
 | |
| 	int RumbleStrength;
 | |
| 	int DeadZoneL;			// Analog 1 Deadzone
 | |
| 	int DeadZoneR;			// Analog 2 Deadzone
 | |
| 	bool bCircle2Square;
 | |
| 	int Diagonal;
 | |
| 
 | |
| 	int Source; // 0: inactive, 1: emu, 2: real
 | |
| 	bool bSideways;
 | |
| 	bool bUpright;
 | |
| 	bool bMotionPlusConnected;
 | |
| 	bool bWiiAutoReconnect;
 | |
| 	int iExtensionConnected;
 | |
| 
 | |
| 	STiltMapping Tilt;
 | |
| 	SStickMapping Stick;
 | |
| 	int Button[LAST_CONSTANT];
 | |
| 	SMotion Motion;
 | |
| 
 | |
| 	UDPWiiSettings UDPWM;
 | |
| };
 | |
| 
 | |
| // Gamepad input
 | |
| extern int NumPads, NumGoodPads; // Number of goods pads
 | |
| extern std::vector<InputCommon::CONTROLLER_INFO> joyinfo;
 | |
| extern CONTROLLER_MAPPING_WII WiiMapping[4];
 | |
| 
 | |
| } // namespace
 | |
| 
 | |
| #endif	//_EMU_DEFINITIONS_
 |