aboutsummaryrefslogtreecommitdiff
path: root/backends/platform/n64/osys_n64_base.cpp
diff options
context:
space:
mode:
authorFabio Battaglia2010-01-13 13:53:31 +0000
committerFabio Battaglia2010-01-13 13:53:31 +0000
commit6c6604d5897f828fb26f2884fa70c596671d30cc (patch)
tree17080d95a71ee0aca678f400ec28a311dea9aaf8 /backends/platform/n64/osys_n64_base.cpp
parent7db58ae29e9503a51ed27979b4959a9170ccd390 (diff)
downloadscummvm-rg350-6c6604d5897f828fb26f2884fa70c596671d30cc.tar.gz
scummvm-rg350-6c6604d5897f828fb26f2884fa70c596671d30cc.tar.bz2
scummvm-rg350-6c6604d5897f828fb26f2884fa70c596671d30cc.zip
N64: if user has inserted a rumble-pak, rumble with shaking screen
svn-id: r47289
Diffstat (limited to 'backends/platform/n64/osys_n64_base.cpp')
-rw-r--r--backends/platform/n64/osys_n64_base.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/backends/platform/n64/osys_n64_base.cpp b/backends/platform/n64/osys_n64_base.cpp
index 6625607ba8..9479081897 100644
--- a/backends/platform/n64/osys_n64_base.cpp
+++ b/backends/platform/n64/osys_n64_base.cpp
@@ -135,6 +135,7 @@ OSystem_N64::OSystem_N64() {
_dirtyOffscreen = false;
_ctrlData = (controller_data_buttons*)memalign(8, sizeof(controller_data_buttons));
+ _controllerHasRumble = (identifyPak(0) == 2);
_fsFactory = new N64FilesystemFactory();
@@ -602,6 +603,11 @@ void OSystem_N64::unlockScreen() {
}
void OSystem_N64::setShakePos(int shakeOffset) {
+
+ // If a rumble pak is plugged in and screen shakes, rumble!
+ if(shakeOffset && _controllerHasRumble) rumblePakEnable(1, 0);
+ else if(!shakeOffset && _controllerHasRumble) rumblePakEnable(0, 0);
+
_shakeOffset = shakeOffset;
_dirtyOffscreen = true;