diff options
Diffstat (limited to 'wiiyourself/wiimote_state.h')
-rw-r--r-- | wiiyourself/wiimote_state.h | 379 |
1 files changed, 0 insertions, 379 deletions
diff --git a/wiiyourself/wiimote_state.h b/wiiyourself/wiimote_state.h deleted file mode 100644 index 1bf167a2..00000000 --- a/wiiyourself/wiimote_state.h +++ /dev/null @@ -1,379 +0,0 @@ -// _______________________________________________________________________________ -// -// - WiiYourself! - native C++ Wiimote library v1.15 -// (c) gl.tter 2007-10 - http://gl.tter.org -// -// see License.txt for conditions of use. see History.txt for change log. -// _______________________________________________________________________________ -// -// wiimote_state.h (tab = 4 spaces) - -// the 'wiimote_state' struct contains all the Wiimote and Extension state data -// (buttons etc) - the wiimote class inherits from this and the app can poll -// the data there at any time. -#ifdef _MSC_VER // VC -# pragma once -#endif - -#ifndef _WIIMOTE_STATE_H -# define _WIIMOTE_STATE_H - -#include "wiimote_common.h" - - -// wiimote_state (contains the Wiimote and Extension data and settings) -struct wiimote_state - { - friend class wiimote; // for Clear() - - // calibration information (stored on the Wiimote) - struct calibration_info - { - BYTE X0, Y0, Z0; - BYTE XG, YG, ZG; - } CalibrationInfo; - - // button state: - struct buttons - { - // convenience accessors - inline bool A () const { return (Bits & _A) != 0; } - inline bool B () const { return (Bits & _B) != 0; } - inline bool Plus () const { return (Bits & PLUS) != 0; } - inline bool Home () const { return (Bits & HOME) != 0; } - inline bool Minus () const { return (Bits & MINUS) != 0; } - inline bool One () const { return (Bits & ONE) != 0; } - inline bool Two () const { return (Bits & TWO) != 0; } - inline bool Up () const { return (Bits & UP) != 0; } - inline bool Down () const { return (Bits & DOWN) != 0; } - inline bool Left () const { return (Bits & LEFT) != 0; } - inline bool Right () const { return (Bits & RIGHT) != 0; } - - // all 11 buttons stored as bits (set = pressed) - WORD Bits; - - // button bit masks (little-endian order) - enum mask - { - LEFT = 0x0001, - RIGHT = 0x0002, - DOWN = 0x0004, - UP = 0x0008, - PLUS = 0x0010, - TWO = 0x0100, - ONE = 0x0200, - _B = 0x0400, // ie. trigger - _A = 0x0800, - MINUS = 0x1000, - HOME = 0x8000, - // - ALL = LEFT|RIGHT|DOWN|UP|PLUS|TWO|ONE|_A|_B|MINUS|HOME, - }; - } Button; - - // accelerometers state: - struct acceleration - { - BYTE RawX, RawY, RawZ; - float X, Y, Z; - - // note: experimental! the orientation values can only be safely estimated - // if the controller isn't accelerating (otherwise there is no - // simple way to seperate orientation from acceleration - except - // perhaps using the IR reference and/or some clever assumptions). - // so for now the code only updates orientation if the controller - // appear to be stationary (by checking if the acceleration vector - // length is near 1G for several updates in a row). - // also note that there is no way to detect Yaw from the accelerometer - // alone when it's pointing at the screen (and I'm not curently - // processing IR): - struct orientation - { - float X, Y, Z; - unsigned UpdateAge; // how many acceleration updates ago the last - // orientation estimate was made (if this - // value is high, the values are out-of-date - // and probably shouldn't be used). - // Euler angle support (useful for some things). - // * note that decomposing to Euler angles is complex, not always reliable, - // and also depends on your assumptions about the order each component - // is applied in. you may need to handle this yourself for more - // complex scenarios * - float Pitch; // in degrees (-180 - +180) - float Roll; // " - // float Yaw; - } Orientation; - } Acceleration; - - // IR camera state: - struct ir - { - // in theory the IR imager is 1024x768 and so should report raw coords - // 0-1023 x 0-767. in practice I have never seen them exceed the values - // below, so I'm using them instead to give the full 0-1 float range - // (it's possible that the edge pixels are used for processing, or masked - // out due to being unreliable). let me know if your wiimote reports - // a different range. - static const unsigned MAX_RAW_X = 1016; - static const unsigned MAX_RAW_Y = 760; - - // data mode reported by the IR sensor - enum mode - { - OFF = 0x00, - BASIC = 0x01, // 10 bytes - EXTENDED = 0x03, // 12 bytes - FULL = 0x05, // 16 bytes * 2 (format unknown) - }; - - mode Mode; // read-only (depends on ReportType set) - - struct dot - { - bool bVisible; // other values are not valid if == false - unsigned RawX; - unsigned RawY; - float X; // 0-1 (left-right) - float Y; // " (top -bottom) - int Size; // (not available in BASIC mode) - } Dot[4]; - } IR; - - struct leds - { - // all LEDs stored in bits 0-3 (1 = lit) - BYTE Bits; - - // convenience accessors: - inline bool Lit (unsigned index) - { _ASSERT(index < 4); - return (index >= 4)? false : ((Bits & (1<<index)) != 0); } - } LED; - - BYTE BatteryRaw; // 0 - ~200 (it seems 200 *may* be the maximum charge) - BYTE BatteryPercent; // (using the above assumption, where 200 raw = 100%) - bool bBatteryDrained; // battery is nearly flat - bool bRumble; - bool bExtension; // an extension (eg. Nunchuk) is connected. - - // speaker state: - struct speaker - { - bool bEnabled; - bool bMuted; - speaker_freq Freq; - BYTE Volume; - } Speaker; - - // the extension plugged into the Wiimote (if any) - enum extension_type - { - NONE = 0, - NUNCHUK, - CLASSIC, - GH3_GHWT_GUITAR, // GH3 or GHWT Guitar (treated as Classic) - GHWT_DRUMS, // not yet used - BALANCE_BOARD, - MOTION_PLUS, - PARTIALLY_INSERTED, - }; - extension_type ExtensionType; - - // joystick struct (shared between Nunchuk & Classic Controller) - struct joystick - { - friend class wiimote; - - // raw unprocessed coordinates: - float RawX, RawY; - - // processed coordinates in approximately -1 - +1 range (includes calibration - // data and deadzones) - note that due to calibration inaccuracies, the - // extremes may be slightly over/under (+-)1.0. - float X, Y; - - // a 'deadzone' is a user-defined range near the joystick center which - // is treated as zero (joysticks often drift a little even at the center - // position). you can set a deadzone for each axis at any time, range is - // 0.0 (off) to 1.0 (entire range - not useful :). try 0.03. - struct deadzone - { - float X, Y; - } DeadZone; - }; - - // Nunchuk state (if connected) - struct nunchuk - { - struct calibration_info - { - BYTE X0, Y0, Z0; - BYTE XG, YG, ZG; - BYTE MinX, MidX, MaxX; - BYTE MinY, MidY, MaxY; - } CalibrationInfo; - - acceleration Acceleration; - joystick Joystick; - bool C; - bool Z; - } Nunchuk; - - // Classic Controller state (if connected) - struct classic_controller - { - // calibration information (stored on the controller) - struct calibration_info - { - BYTE MinXL, MidXL, MaxXL; - BYTE MinYL, MidYL, MaxYL; - BYTE MinXR, MidXR, MaxXR; - BYTE MinYR, MidYR, MaxYR; - BYTE MinTriggerL, MaxTriggerL; - BYTE MinTriggerR, MaxTriggerR; - } CalibrationInfo; - - // button state - struct buttons - { - // convenience accessors - inline bool A () const { return (Bits & _A) != 0; } - inline bool B () const { return (Bits & _B) != 0; } - inline bool Plus () const { return (Bits & PLUS) != 0; } - inline bool Minus () const { return (Bits & MINUS) != 0; } - inline bool Home () const { return (Bits & HOME) != 0; } - inline bool Up () const { return (Bits & UP) != 0; } - inline bool Down () const { return (Bits & DOWN) != 0; } - inline bool Left () const { return (Bits & LEFT) != 0; } - inline bool Right () const { return (Bits & RIGHT) != 0; } - inline bool X () const { return (Bits & _X) != 0; } - inline bool Y () const { return (Bits & _Y) != 0; } - inline bool ZL () const { return (Bits & _ZL) != 0; } - inline bool ZR () const { return (Bits & _ZR) != 0; } - inline bool TriggerL () const { return (Bits & TRIG_L) != 0; } - inline bool TriggerR () const { return (Bits & TRIG_R) != 0; } - - // all 15 buttons stored as bits (set = pressed) - WORD Bits; - - // button bitmasks (little-endian order) - enum mask - { - TRIG_R = 0x0002, - PLUS = 0x0004, - HOME = 0x0008, - MINUS = 0x0010, - TRIG_L = 0x0020, - DOWN = 0x0040, - RIGHT = 0x0080, - UP = 0x0100, - LEFT = 0x0200, - _ZR = 0x0400, - _X = 0x0800, - _A = 0x1000, - _Y = 0x2000, - _B = 0x4000, - _ZL = 0x8000, - // - ALL = TRIG_R|PLUS|HOME|MINUS|TRIG_L|DOWN|RIGHT|UP|LEFT| - _ZR|_X|_A|_Y|_B|_ZL, - }; - } Button; - - // joysticks - joystick JoystickL; - joystick JoystickR; - - // triggers - BYTE RawTriggerL, RawTriggerR; - float TriggerL, TriggerR; - } ClassicController; - - struct balance_board - { - // values for each of the board's 4 sensors: - // (these values are always exposed unmodifed) - struct sensors_raw - { - short TopR; - short TopL; - short BottomR; - short BottomL; - }; - struct sensors_f - { - float TopL; - float TopR; - float BottomL; - float BottomR; - - float Total; // sum of the 4 corner weights - }; - - // calibration info - struct calibration_info - { - sensors_raw Kg0; // calibration at 0 Kg - sensors_raw Kg17; // " 17 Kg - sensors_raw Kg34; // " 34 Kg - } CalibrationInfo; - - // state: - sensors_raw Raw; // raw values (per sensor) - sensors_f AtRestKg; // set by Connect() and CalibrateAtRest() - // (the values below have their 'at-rest' offsets automatically removed) - sensors_f Kg; // kilograms (per sensor) - sensors_f Lb; // pounds (per sensor) - } BalanceBoard; - - struct motion_plus - { - // (these values are always exposed unmodifed) - struct sensors_raw - { - short Yaw; - short Pitch; - short Roll; - }; - struct sensors_f - { - float Yaw; - float Pitch; - float Roll; - }; - - // state: - sensors_raw Raw; - sensors_f Speed; - } MotionPlus; - - // ---- internal use only ---- - protected: - unsigned WiimoteNearGUpdates; - unsigned NunchukNearGUpdates; - - void Clear (bool including_deadzones) - { - joystick::deadzone nunchuk_deadzone, - classic_joyl_deadzone, - classic_joyr_deadzone; - - // preserve the deadzone settings? - if(!including_deadzones) { - nunchuk_deadzone = Nunchuk.Joystick.DeadZone; - classic_joyl_deadzone = ClassicController.JoystickL.DeadZone; - classic_joyr_deadzone = ClassicController.JoystickR.DeadZone; - } - - memset(this, 0, sizeof(wiimote_state)); - - // restore the deadzones? - if(!including_deadzones) { - Nunchuk.Joystick.DeadZone = nunchuk_deadzone; - ClassicController.JoystickL.DeadZone = classic_joyl_deadzone; - ClassicController.JoystickR.DeadZone = classic_joyr_deadzone; - } - } - }; - -#endif // _WIIMOTE_STATE_H
\ No newline at end of file |