mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-09 23:59:27 +01:00
Fix emulated wiimote shaking in Wario Land: Shake It, and probably others.
Fixes issue 5295. (probably issue 5017 and issue 5578 too)
This commit is contained in:
parent
d05d10d2a1
commit
69b1da915f
@ -15,6 +15,8 @@
|
|||||||
// Official SVN repository and contact information can be found at
|
// Official SVN repository and contact information can be found at
|
||||||
// http://code.google.com/p/dolphin-emu/
|
// http://code.google.com/p/dolphin-emu/
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
|
||||||
#include "Attachment/Classic.h"
|
#include "Attachment/Classic.h"
|
||||||
#include "Attachment/Nunchuk.h"
|
#include "Attachment/Nunchuk.h"
|
||||||
#include "Attachment/Guitar.h"
|
#include "Attachment/Guitar.h"
|
||||||
@ -89,23 +91,32 @@ const ReportFeatures reporting_mode_features[] =
|
|||||||
{ 0, 0, 0, 0, 23 },
|
{ 0, 0, 0, 0, 23 },
|
||||||
};
|
};
|
||||||
|
|
||||||
void EmulateShake( AccelData* const accel
|
void EmulateShake(AccelData* const accel
|
||||||
, ControllerEmu::Buttons* const buttons_group
|
, ControllerEmu::Buttons* const buttons_group
|
||||||
, u8* const shake_step )
|
, u8* const shake_step )
|
||||||
{
|
{
|
||||||
static const double shake_data[] = { -2.5f, -5.0f, -2.5f, 0.0f, 2.5f, 5.0f, 2.5f, 0.0f };
|
// frame count of one up/down shake
|
||||||
|
// < 9 no shake detection in "Wario Land: Shake It"
|
||||||
|
auto const shake_step_max = 15;
|
||||||
|
|
||||||
|
// peak G-force
|
||||||
|
auto const shake_intensity = 3.f;
|
||||||
|
|
||||||
|
// shake is a bitfield of X,Y,Z shake button states
|
||||||
static const unsigned int btns[] = { 0x01, 0x02, 0x04 };
|
static const unsigned int btns[] = { 0x01, 0x02, 0x04 };
|
||||||
unsigned int shake = 0;
|
unsigned int shake = 0;
|
||||||
|
|
||||||
buttons_group->GetState( &shake, btns );
|
buttons_group->GetState( &shake, btns );
|
||||||
for ( unsigned int i=0; i<3; ++i )
|
|
||||||
|
for (int i = 0; i != 3; ++i)
|
||||||
|
{
|
||||||
if (shake & (1 << i))
|
if (shake & (1 << i))
|
||||||
{
|
{
|
||||||
(&(accel->x))[i] = shake_data[shake_step[i]++];
|
(&(accel->x))[i] = std::sin(TAU * shake_step[i] / shake_step_max) * shake_intensity;
|
||||||
shake_step[i] %= sizeof(shake_data)/sizeof(double);
|
shake_step[i] = (shake_step[i] + 1) % shake_step_max;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
shake_step[i] = 0;
|
shake_step[i] = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulateTilt(AccelData* const accel
|
void EmulateTilt(AccelData* const accel
|
||||||
|
@ -30,7 +30,12 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
#define PI 3.14159265358979323846
|
namespace
|
||||||
|
{
|
||||||
|
// :)
|
||||||
|
auto const TAU = 6.28318530717958647692;
|
||||||
|
auto const PI = TAU / 2.0;
|
||||||
|
}
|
||||||
|
|
||||||
// Registry sizes
|
// Registry sizes
|
||||||
#define WIIMOTE_EEPROM_SIZE (16*1024)
|
#define WIIMOTE_EEPROM_SIZE (16*1024)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user