/**************************************************************************** MODULE: HAU_MIDI.HPP Tab settings: 5 9 Copyright 1995, 1996, Microsoft Corporation, All Rights Reserved. PURPOSE: Header for HAU_MIDI.CPP Author(s): Name: ---------- ---------------- MEA Manolito E. Adan Revision History: ----------------- Version Date Author Comments 1.0 03-Apr-96 MEA original 21-Mar-99 waltw Removed unreferenced ModifyEnvelopeParams, ModifyEffectParams, MapEnvelope, CMD_ModifyParamByIndex, CMD_Download_RTCSpring ****************************************************************************/ #ifndef _HAU_MIDI_SEEN #define _HAU_MIDI_SEEN #include "DX_MAP.hpp" #define MAX_EFFECT_IDS 32 #define NEW_EFFECT_ID 0x7f #define SYSTEM_EFFECT_ID 0x7f #define SYSTEM_RTCSPRING_ID 0 #define SYSTEM_FRICTIONCANCEL_ID 1 #define SYSTEM_RTCSPRING_ALIAS_ID 0x7e // Due to internal ID=0 means create new #define MAX_MIDI_CHANNEL 16 #define DEFAULT_MIDI_CHANNEL 5 #define DEFAULT_MIDI_PORTIO 0x330 #define COMM_WINMM 0x01 #define COMM_MIDI_BACKDOOR 0x02 #define COMM_SERIAL_BACKDOOR 0x03 #define COMM_SERIAL_FILE 0x04 #define MASK_OVERRIDE_MIDI_PATH 0x80000000 #define MASK_SERIAL_BACKDOOR 0x40000000 #define COMM_SERIAL1 1 // COMM Port 1 #define MIN_COMMSERIAL 1 #define MAX_COMMSERIAL 4 #define DEFAULT_JOLT_FORCE_RATE 100 #define DEFAULT_PERCENT 10000 #define MAX_SYS_EX_BUFFER_SIZE 1024 // Maximum Primary buffer size #define DIFFERENCE_THRESHOLD 32 // Threshold to using absolute data #define DIFFERENCE_BIT 0x40 // Bit to set for Difference data #define MAX_MIDI_WAVEFORM_PACKET_SIZE (256-20) // Midi SYS_EX packet size #define MAX_MIDI_WAVEFORM_DATA_SIZE 100 // Midi SYS_EX Data sample window size #define MAX_PLIST_EFFECT_SIZE 8 // 8 effects in a PList #define MAX_PLIST_EFFECT 8 // 8 PLists allowed #define MAX_INDEX 15 #define MAX_SIZE_SNAME 64 #define MS_MANUFACTURER_ID 0x0a01 #define JOLT_PRODUCT_ID 0x01 // REVIEW: Is this correct? #define DRIVER_ERROR_NO_MIDI_INPUT 0x100 // No open Midi input device #define DRIVER_ERROR_MIDI_OUTPUT 0x101 // Error outputing to Midi output // // --- RTC Spring defaults // #define DEFAULT_RTC_KX 80 #define DEFAULT_RTC_KY 80 #define DEFAULT_RTC_X0 0 #define DEFAULT_RTC_Y0 0 #define DEFAULT_RTC_XSAT 96 #define DEFAULT_RTC_YSAT 96 #define DEFAULT_RTC_XDBAND 16 #define DEFAULT_RTC_YDBAND 16 // // --- Effect status code from Device // #define SWDEV_STS_EFFECT_STOPPED 0x01 #define SWDEV_STS_EFFECT_RUNNING 0x02 // // --- Bitmasks for Device Status // #define BANDWIDTH_MASK 0x200 // Bandwidth bit #define COMM_MODE_MASK 0x100 // 0 = MIDI, 1 = Serial #define AC_FAULT_MASK 0x80 // 1= AC brick fault #define HOTS_MASK 0x20 // Hands on Throttle Sensor #define RESET_MASK 0x10 // 1 = Power On Reset detected #define SHUTDOWN_MASK 0x08 // 0 = normal Shutdown, else 1 = Soft Reset #define MINIMUM_BANDWIDTH 1 #define MAXIMUM_BANDWIDTH 100 // in % // // --- ERROR CODES from Device // #define DEV_ERR_SUCCESS 0x00 // Success #define DEV_ERR_INVALID_ID 0x01 // Effect ID is invalid or not found #define DEV_ERR_INVALID_PARAM 0x02 // Invalid parameter in data structure #define DEV_ERR_CHECKSUM 0x03 // Invalid checksum #define DEV_ERR_TYPE_FULL 0x04 // No more room for specified Effect #define DEV_ERR_UNKNOWN_CMD 0x05 // Unrecognized command #define DEV_ERR_PLAYLIST_FULL 0x06 // Play List is full, cannot play any // more effects #define DEV_ERR_PROCESS_LIST_FULL 0x07 // Process List is full // // --- MIDI Command codes // #define MODIFY_CMD 0xA0 #define EFFECT_CMD 0xB0 #define SYSTEM_CMD 0xC0 #define STATUS_CMD 0xD0 #define RESPONSE_CMD 0xE0 // Device to Host #define SYS_EX_CMD 0xF0 #define ASSIGN_CMD 0xF0 #define DNLOAD_CMD 0xF0 #define UPLOAD_CMD 0xF0 #define PROCESS_CMD 0xF0 #define MIDI_EOX 0xF7 // // --- Second byte sub-commands // // --- MIDI_CMD_EFFECT second byte sub-command #define NO_OVERRIDE 0x00 #define DESTINATION_X 0x01 #define DESTINATION_Y 0x02 #define DESTINATION_XY 0x03 #define PUT_FORCE_X 0x01 #define PUT_FORCE_Y 0x02 #define PUT_FORCE_XY 0x03 #define PLAY_EFFECT_SOLO 0x00 #define DESTROY_EFFECT 0x10 #define PLAY_EFFECT_SUPERIMPOSE 0x20 #define STOP_EFFECT 0x30 #define SET_INDEX 0x40 // --- MIDI_CMD_SYSTEM second byte sub-command #define SWDEV_SHUTDOWN 1L // All Effects destroyed, Motors disabled #define SWDEV_FORCE_ON 2L // Motors enabled. "Un-Mute" #define SWDEV_FORCE_OFF 3L // Motors disabled. "Mute" #define SWDEV_CONTINUE 4L // All "Paused" Effects are allow to continue #define SWDEV_PAUSE 5L // All Effects are "Paused" #define SWDEV_STOP_ALL 6L // Stops all Effects. #define SWDEV_KILL_MIDI 7L // Kills (tri-states) MIDI // Remap for dinput modes #define DEV_RESET SWDEV_SHUTDOWN #define DEV_FORCE_ON SWDEV_FORCE_ON #define DEV_FORCE_OFF SWDEV_FORCE_OFF #define DEV_CONTINUE SWDEV_CONTINUE #define DEV_PAUSE SWDEV_PAUSE #define DEV_STOP_ALL SWDEV_STOP_ALL // // --- ACK and NACK 2nd byte from RESPONSE_CMD // #define ACK 0x00 #define NACK 0x7f #define ACKNACK_TIMEOUT 50 // 50*1msec timeout = 50msecs #define ACKNACK_EFFECT_STATUS_TIMEOUT 1 // 1ms Timeout #define MAX_RETRY_COUNT 10 // Retry count for comm NACKS //#define MAX_GET_STATUS_PACKET_RETRY_COUNT 30 #define MAX_GET_STATUS_PACKET_RETRY_COUNT 10 #define SHORT_MSG_TIMEOUT 1 #define LONG_MSG_TIMEOUT 2 #define POWER_ON_MSG 0x007F00E5UL #define RESPONSE_NACK 0x007FE0UL // Example for MIDI channel 0. #define RESPONSE_ACK 0x0000E0UL // " " // timing delays, in mS /* #define DEFAULT_SHORT_MSG_DELAY 1 #define DEFAULT_LONG_MSG_DELAY 1 #define DEFAULT_DIGITAL_OVERDRIVE_PRECHARGE_CMD_DELAY 1 #define DEFAULT_SHUTDOWN_DELAY 10 #define DEFAULT_HWRESET_DELAY 20 #define DEFAULT_POST_SET_DEVICE_STATE_DELAY 1 #define DEFAULT_GET_EFFECT_STATUS_DELAY 1 #define DEFAULT_GET_DATA_PACKET_DELAY 1 #define DEFAULT_GET_STATUS_PACKET_DELAY 0 #define DEFAULT_GET_ID_PACKET_DELAY 1 #define DEFAULT_GET_STATUS_GATE_DATA_DELAY 0 #define DEFAULT_SET_INDEX_DELAY 0 #define DEFAULT_MODIFY_PARAM_DELAY 0 #define DEFAULT_FORCE_OUT_DELAY 1 #define DEFAULT_DESTROY_EFFECT_DELAY 1 #define DEFAULT_FORCE_OUT_MOD 1 */ // Changes of above for Zep #define DEFAULT_SHORT_MSG_DELAY 0 #define DEFAULT_LONG_MSG_DELAY 0 #define DEFAULT_DIGITAL_OVERDRIVE_PRECHARGE_CMD_DELAY 0 #define DEFAULT_SHUTDOWN_DELAY 0 #define DEFAULT_HWRESET_DELAY 0 #define DEFAULT_POST_SET_DEVICE_STATE_DELAY 0 #define DEFAULT_GET_EFFECT_STATUS_DELAY 0 #define DEFAULT_GET_DATA_PACKET_DELAY 0 #define DEFAULT_GET_STATUS_PACKET_DELAY 0 #define DEFAULT_GET_ID_PACKET_DELAY 0 #define DEFAULT_GET_STATUS_GATE_DATA_DELAY 0 #define DEFAULT_SET_INDEX_DELAY 0 #define DEFAULT_MODIFY_PARAM_DELAY 0 #define DEFAULT_FORCE_OUT_DELAY 0 #define DEFAULT_DESTROY_EFFECT_DELAY 0 #define DEFAULT_FORCE_OUT_MOD 0 typedef struct _DELAY_PARAMS { DWORD dwBytes; DWORD dwDigitalOverdrivePrechargeCmdDelay; DWORD dwShutdownDelay; DWORD dwHWResetDelay; DWORD dwPostSetDeviceStateDelay; DWORD dwGetEffectStatusDelay; DWORD dwGetDataPacketDelay; DWORD dwGetStatusPacketDelay; DWORD dwGetIDPacketDelay; DWORD dwGetStatusGateDataDelay; DWORD dwSetIndexDelay; DWORD dwModifyParamDelay; DWORD dwForceOutDelay; DWORD dwShortMsgDelay; DWORD dwLongMsgDelay; DWORD dwDestroyEffectDelay; DWORD dwForceOutMod; } DELAY_PARAMS, *PDELAY_PARAMS; void GetDelayParams(UINT nJoystickID, PDELAY_PARAMS pDelayParams); // // --- Format of Download command // Bytes in SYS EX body (starting from Byte 5 to (n-1) // // Byte Contents // ----- --------- // 0 bOpCode - see detail on OPCODE below // 1 bSubType - e.g. ET_UD_WAVEFORM, etc. // 2 bEffectID - Effect ID, 0x7f = Create New // 3 bDurationL - Low 7 bits duration in 2ms ticks, 0=Forever // 4 bDurationH - High 7 bits // 5 bAngleL - Low 7 bits Direction Angle // 7 bAngleH - High 2 bits Direction Angle // 8 bGain - 7 bits Gain 1 - 100% // 9 bButtonPlayL - Low 7 bits button mask // 10 bButtonPlayH - High 2 bits button mask // 11 bForceOutRateL - Low 7 bits, 1 to 500 Hz // 12 bForceOutRateH - High 2 bits // 13 bLoopCountL - Low 7 bits Loop Count, Normally 1 // 14 bLoopCountH - High 7 bits Loop count // // // The next block is optional and starts at Byte 15 // 15 bAttack - %tage // 16 bSustain; - %tage // 17 bDecay; - %tage // // Otherwise, Type specific Parameters start at either Byte 15 or 18 // 18 Type specific parameter bytes here // // // ... // n 7 bits Checksum of bytes 0 to n // // // // --- MIDI_CMD_ASSIGN, MIDI_CMD_DNLOAD, MIDI_CMD_PROCESS // second byte sub-command // Opcode is defined as follows: // 7 6 5 4 3 2 1 0 // - - - - - - - - // 0 c c c a a d d // // where: // c c c // - - - // 0 0 0 - EXTEND_ESCAPE // 0 0 1 - MIDI_ASSIGN // 0 1 0 - DNLOAD_DATA // 0 1 1 - UPLOAD_DATA // 1 0 0 - PROCESS_DATA // 1 0 1 - reserved // 1 1 0 - reserved // 1 1 1 - reserved // // and: // a a // - - // 0 0 - DL_PLAY_STORE only after download // 0 1 - DL_PLAY_SUPERIMPOSE right after download // 1 0 - DL_PLAY_SOLO right after download // 1 1 - reserved // and: // d d // - - // 0 0 - reserved // 0 1 - X-Axis // 1 0 - Y-Axis // 1 1 - X and Y-Axis // #define EXTEND_ESCAPE 0x00 #define MIDI_ASSIGN 0x10 #define DNLOAD_DATA 0x20 #define UPLOAD_DATA 0x30 #define PROCESS_DATA 0x40 #define GET_FORCE_EFFECT_VALUE 0x50 // --- Download sub-commands // #define DL_PLAY_STORE 0x00 #define DL_PLAY_SUPERIMPOSE 0x04 #define DL_PLAY_SOLO 0x08 // // --- Process List sub-commands // #define PLIST_CONCATENATE 0x01 //0x11 // Temp. s/b 0x01 #define PLIST_SUPERIMPOSE 0x02 //0x12 // Temp. s/b 0x02 // // --- Special UD_EFFECT parameters // #define UD_DIFFERENCE_DATA 0x40 // // --- Bitmap Indexes into Parameter storage array // #define INDEX0_MASK 0x00000001L #define INDEX1_MASK 0x00000002L #define INDEX2_MASK 0x00000004L #define INDEX3_MASK 0x00000008L #define INDEX4_MASK 0x00000010L #define INDEX5_MASK 0x00000020L #define INDEX6_MASK 0x00000040L #define INDEX7_MASK 0x00000080L #define INDEX8_MASK 0x00000100L #define INDEX9_MASK 0x00000200L #define INDEX10_MASK 0x00000400L #define INDEX11_MASK 0x00000800L #define INDEX12_MASK 0x00001000L #define INDEX13_MASK 0x00002000L #define INDEX14_MASK 0x00004000L #define INDEX15_MASK 0x00008000L #define INDEX_DURATION 0 #define INDEX_TRIGGERBUTTONMASK 1 #define INDEX_X_COEEFICIENT 2 #define INDEX_Y_COEEFICIENT 3 #define INDEX_X_CENTER 4 #define INDEX_Y_CENTER 5 // Indexes for 1XX RTCSpring Parms #define INDEX_RTC_COEEFICIENT_X (BYTE)0 #define INDEX_RTC_COEEFICIENT_Y (BYTE)1 #define INDEX_RTC_CENTER_X (BYTE)2 #define INDEX_RTC_CENTER_Y (BYTE)3 #define INDEX_RTC_SATURATION_X (BYTE)4 #define INDEX_RTC_SATURATION_Y (BYTE)5 #define INDEX_RTC_DEADBAND_X (BYTE)6 #define INDEX_RTC_DEADBAND_Y (BYTE)7 #define INDEX0 (BYTE)0 #define INDEX1 (BYTE)1 #define INDEX2 (BYTE)2 #define INDEX3 (BYTE)3 #define INDEX4 (BYTE)4 #define INDEX5 (BYTE)5 #define INDEX6 (BYTE)6 #define INDEX7 (BYTE)7 #define INDEX8 (BYTE)8 #define INDEX9 (BYTE)9 #define INDEX10 (BYTE)10 #define INDEX11 (BYTE)11 #define INDEX12 (BYTE)12 #define INDEX13 (BYTE)13 #define INDEX14 (BYTE)14 #define INDEX15 (BYTE)15 // // --- Effect types // #define ET_UD_WAVEFORM 1 // User Defined Waveform #define ET_SE_SINE 2 // Sinusoidal #define ET_SE_COSINE 3 // Cosine #define ET_SE_SQUARELOW 4 // Square starting Low #define ET_SE_SQUAREHIGH 5 // Square starting High #define ET_SE_RAMPUP 6 // Ramp UP #define ET_SE_RAMPDOWN 7 // Ramp Down #define ET_SE_TRIANGLEUP 8 // Triangle rising #define ET_SE_TRIANGLEDOWN 9 // Triangle falling #define ET_SE_SAWTOOTHUP 10 // Sawtooth rising #define ET_SE_SAWTOOTHDOWN 11 // Sawtooth falling #define ET_BE_DELAY 12 // NOP delay #define ET_BE_SPRING 13 // Springs #define ET_BE_DAMPER 14 // Dampers #define ET_BE_INERTIA 15 // Gravity #define ET_BE_FRICTION 16 // Friction #define ET_BE_WALL 17 // Wall (bumper) #define ET_SE_CONSTANT_FORCE 18 // Constant Force #define ET_PL_CONCATENATE 19 // Concatenate process list #define ET_PL_SUPERIMPOSE 20 // Superimpose process list // ROM Effect IDS #define ET_RE_ROMID1 32 #define ET_RE_ROMID2 33 #define ET_RE_ROMID3 34 #define ET_RE_ROMID4 35 #define ET_RE_ROMID5 36 #define ET_RE_ROMID6 37 #define ET_RE_ROMID7 38 #define ET_RE_ROMID8 39 #define ET_RE_ROMID9 40 #define ET_RE_ROMID10 41 #define ET_RE_ROMID11 42 #define ET_RE_ROMID12 43 #define ET_RE_ROMID13 44 #define ET_RE_ROMID14 45 #define ET_RE_ROMID15 46 #define ET_RE_ROMID16 47 #define ET_RE_ROMID17 48 #define ET_RE_ROMID18 49 #define ET_RE_ROMID19 50 #define ET_RE_ROMID20 51 #define ET_RE_ROMID21 52 #define ET_RE_ROMID22 53 #define ET_RE_ROMID23 54 #define ET_RE_ROMID24 55 #define ET_RE_ROMID25 56 #define ET_RE_ROMID26 57 #define ET_RE_ROMID27 58 #define ET_RE_ROMID28 59 #define ET_RE_ROMID29 60 #define ET_RE_ROMID30 61 #define ET_RE_ROMID31 62 #define ET_RE_ROMID32 63 #define ET_RE_ROMID33 64 #define ET_RE_ROMID34 65 #define ET_RE_ROMID35 66 #define ET_RE_ROMID36 67 #define ET_RE_ROMID37 68 // more to be defined.... // // Effect IDs as defined in Jolt device // #define EFFECT_ID_RTC_SPRING 0 // Built-in Return To Center Virtual Spring #define EFFECT_ID_FRICTIONCANCEL 1 // Friction cancellation // // --- Process List Structure // typedef struct _PLIST { ULONG ulNumEffects; ULONG ulProcessMode; // PLIST_SUPERIMPOSE or PLIST_CONCATENATE PDNHANDLE pEffectArray; // Effect ID[0} . . . ULONG ulAction; ULONG ulDuration; } PLIST, *PPLIST; // // --- Behavioral Effects Structure // typedef struct _BE_XXX { LONG m_XConstant; //(KX/BX/MX/FX/Wall type) LONG m_YConstant; //(KY/BY/MY/FY/KWall) LONG m_Param3; //(CX/VX/AX/Wall angle) LONG m_Param4; //(CY/VYO/AY/Wall distance) } BE_XXX, *PBE_XXX; // // --- SysEx Messages // typedef struct _SYS_EX_HDR { BYTE m_bSysExCmd; // SysEx Fx command BYTE m_bEscManufID; // Escape to long Manufac. ID, s/b 0 BYTE m_bManufIDL; // Low byte BYTE m_bManufIDH; // High byte BYTE m_bProdID; // Product ID } SYS_EX_HDR, *PSYS_EX_HDR; // --- Common Effect parameters typedef struct _MIDI_EFFECT { BYTE bDurationL; // Low 7 bits duration in 2ms ticks, 0=Forever BYTE bDurationH; // High 7 bits BYTE bButtonPlayL; // Low 7 bits button mask BYTE bButtonPlayH; // High 2 bits button mask BYTE bAngleL; // Low 7 bits Direction Angle BYTE bAngleH; // High 2 bits Direction Angle BYTE bGain; // 7 bits Gain 1 - 100% BYTE bForceOutRateL; // Low 7 bits, 1 to 500 Hz BYTE bForceOutRateH; // High 2 bits BYTE bPercentL; // Low 7 bits Percent of waveform 1 to 10000 BYTE bPercentH; // High 7 bits Loop Count } MIDI_EFFECT, *PMIDI_EFFECT; // --- Envelope typedef struct MIDI_ENVELOPE { BYTE bAttackLevel; // Initial Attack amplitude 0 to +127 BYTE bSustainL; // time to Sustain in 2ms ticks BYTE bSustainH; // BYTE bSustainLevel; // Amplitude level to sustain BYTE bDecayL; // time to Decay in 2ms ticks BYTE bDecayH; BYTE bDecayLevel; // Amplitude level to decay } MIDI_ENVELOPE, *PMIDI_ENVELOPE; // --- Midi Assign typedef struct _MIDI_ASSIGN_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: MIDI_ASSIGN BYTE bChannel; // Midi channel 1-16 BYTE bChecksum; BYTE bEOX; } MIDI_ASSIGN_SYS_EX, *PMIDI_ASSIGN_SYS_EX; // --- Get Effect Force Value at a tick sample time typedef struct _MIDI_GET_EFFECT_FORCE_VALUE_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: GET_EFFECT_FORCE_VALUE BYTE bEffectID; // Effect ID BYTE bSampleTimeL; // Low 7 bits in 2ms ticks BYTE bSampleTimeH; // High 7 bits in 2ms ticks BYTE bChecksum; BYTE bEOX; } MIDI_GET_EFFECT_FORCE_VALUE_SYS_EX, *PMIDI_GET_EFFECT_FORCE_VALUE_SYS_EX; // --- Note: For the following, if bEffectID = 0x7f, then New, else Modify // --- Download Data - Synthesized Waveform typedef struct _SE_WAVEFORM_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: DNLOAD_DATA BYTE bSubType; // ex: ET_SE_SINE BYTE bEffectID; // Downloaded Effect ID MIDI_EFFECT Effect; MIDI_ENVELOPE Envelope; // SE Parameters BYTE bFreqL; // Low 7 bits Frequency 1-2048Hz BYTE bFreqH; // High 4 bits BYTE bMaxAmpL; // Low 7 bits Maximum Amplitude +/- 100% BYTE bMaxAmpH; // High 1 bit BYTE bMinAmpL; // Low 7 bits Minimum Amplitude +/- 100% BYTE bMinAmpH; // High 1 bit BYTE bChecksum; BYTE bEOX; } SE_WAVEFORM_SYS_EX, *PSE_WAVEFORM_SYS_EX; // --- Download Data - NOP Delay typedef struct _NOP_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: DNLOAD_DATA BYTE bSubType; // Behavioral Effect Type: BE_FRICTION BYTE bEffectID; // Downloaded Effect ID, 0x7F = Create NEw BYTE bDurationL; // Low 7 bits duration in 2ms ticks, 0=Forever BYTE bDurationH; // High 7 bits BYTE bChecksum; BYTE bEOX; } NOP_SYS_EX, *PNOP_SYS_EX; // --- Download Data - Behavioral SysEx typedef struct _BEHAVIORAL_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: DNLOAD_DATA BYTE bSubType; // Behavioral Effect Type: BE_SPRING BYTE bEffectID; // Downloaded Effect ID // Effects params BYTE bDurationL; // Low 7 bits duration in 2ms ticks, 0=Forever BYTE bDurationH; // High 7 bits BYTE bButtonPlayL; // Low 7 bits button mask BYTE bButtonPlayH; // High 2 bits button mask // BE_XXX Parameters BYTE bXConstantL; // Low 7 bits K (in +/- 100%) X-Axis BYTE bXConstantH; // High 1 bit K BYTE bYConstantL; // Low 7 bits K (in +/- 100%) Y-Axis BYTE bYConstantH; // High 1 bit K BYTE bParam3L; // Low 7 bits Axis center (in +/- 100%) X-Axis BYTE bParam3H; // High 1 bit BYTE bParam4L; // Low 7 bits Axis center (in +/- 100%) Y-Axis BYTE bParam4H; // High 1 bit BYTE bChecksum; BYTE bEOX; } BEHAVIORAL_SYS_EX, *PBEHAVIORAL_SYS_EX; // --- Download Data - Friction SysEx typedef struct _FRICTION_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: DNLOAD_DATA BYTE bSubType; // Behavioral Effect Type: BE_FRICTION BYTE bEffectID; // Downloaded Effect ID // Effects params BYTE bDurationL; // Low 7 bits duration in 2ms ticks, 0=Forever BYTE bDurationH; // High 7 bits BYTE bButtonPlayL; // Low 7 bits button mask BYTE bButtonPlayH; // High 2 bits button mask // BE_FRICTION Parameters BYTE bXFConstantL; // Low 7 bits F (in +/- 100%) X-Axis BYTE bXFConstantH; // High 1 bit F BYTE bYFConstantL; // Low 7 bits F (in +/- 100%) Y-Axis BYTE bYFConstantH; // High 1 bit F BYTE bChecksum; BYTE bEOX; } FRICTION_SYS_EX, *PFRICTION_SYS_EX; // --- Download Data - WALL SysEx #define INNER_WALL 0 // Wall face to center #define OUTER_WALL 1 // Wall face away from center typedef struct _WALL_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: DNLOAD_DATA BYTE bSubType; // Behavioral Effect Type: e.g. EF_BE_WALL BYTE bEffectID; // Downloaded Effect ID // Effects params BYTE bDurationL; // Low 7 bits duration in 2ms ticks, 0=Forever BYTE bDurationH; // High 7 bits BYTE bButtonPlayL; // Low 7 bits button mask BYTE bButtonPlayH; // High 2 bits button mask // BE_SPRING Parameters BYTE bWallType; // INNER_WALL or OUTER_WALL BYTE bWallConstantL; // Low 7 bits: Similar to Spring Constant. // Value is from +/- 100%. BYTE bWallConstantH; // High 1 bit BYTE bWallAngleL; // Low 7 bits: 0 to 359 degrees // For simple vertical and horizontal walls, // this value should be set to 0, 90, 180, 270 BYTE bWallAngleH; // Low 2 bit BYTE bWallDistance; // 7 bits: Distance from Center of stick 0 to 100 BYTE bChecksum; BYTE bEOX; } WALL_SYS_EX, *PWALL_SYS_EX; // --- Download Data - User Defined Waveform SysEx typedef struct _UD_WAVEFORM_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: PROCESS_DATA BYTE bSubType; // Process List: PL_SUPERIMPOSE/PL_CONCATENATE BYTE bEffectID; // Downloaded Effect ID MIDI_EFFECT Effect; // BYTE bWaveformArray; // Force Data . . . // BYTE bChecksum; // BYTE bEOX; } UD_WAVEFORM_SYS_EX, *PUD_WAVEFORM_SYS_EX; #define UD_WAVEFORM_START_OFFSET (sizeof(UD_WAVEFORM_SYS_EX)) // --- Download Data - Process List SysEx typedef struct _PROCESS_LIST_SYS_EX { SYS_EX_HDR SysExHdr; BYTE bOpCode; // Sub-command opcode: PROCESS_DATA BYTE bSubType; // Process List: PL_SUPERIMPOSE/PL_CONCATENATE BYTE bEffectID; // Downloaded Effect ID BYTE bButtonPlayL; // Low 7 bits button mask BYTE bButtonPlayH; // High 2 bits button mask BYTE bEffectArrayID; // Effect ID[0] . . . // BYTE bChecksum; // BYTE bEOX; } PROCESS_LIST_SYS_EX, *PPROCESS_LIST_SYS_EX; #define PROCESS_LIST_EFFECT_START_OFFSET (sizeof(PROCESS_LIST_SYS_EX)) // // --- Function Prototypes // BOOL DetectMidiDevice( IN OUT UINT *pDeviceOutID); HRESULT CMD_SetIndex( IN int nIndex, IN DNHANDLE DnloadID); HRESULT CMD_ModifyParam( IN WORD wNewParam); HRESULT CMD_Download_VFX( IN PEFFECT pEffect, IN PENVELOPE pEnvelope, IN PVFX_PARAM pVFX_Param, IN ULONG ulAction, IN OUT PDNHANDLE pDnloadID, IN DWORD dwFlags); HRESULT CMD_Download_BE_XXX( IN PEFFECT pEffect, IN PENVELOPE pEnvelope, IN PBE_XXX pBE_XXX, IN OUT PDNHANDLE pDnloadID, IN DWORD dwFlags); class CMidiSynthesized; #endif // of ifdef _HAU_MIDI_SEEN