From 51e8bf4798a5acb826a70a1c13ca8457128a7ad6 Mon Sep 17 00:00:00 2001 From: lordloki Date: Wed, 31 Oct 2018 03:07:02 -0700 Subject: [PATCH] UPBGE: Fix for mouse actuator return value (#907) Now it works perfectly when activating from an always sensor. Additionally, it introduces a boolean check for initial skipping instead the modifying the oldposition. --- source/gameengine/Ketsji/KX_MouseActuator.cpp | 14 +++++++------- source/gameengine/Ketsji/KX_MouseActuator.h | 1 + 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/source/gameengine/Ketsji/KX_MouseActuator.cpp b/source/gameengine/Ketsji/KX_MouseActuator.cpp index 8fbac6a94f3d..dea9ab9bfae1 100644 --- a/source/gameengine/Ketsji/KX_MouseActuator.cpp +++ b/source/gameengine/Ketsji/KX_MouseActuator.cpp @@ -51,7 +51,8 @@ KX_MouseActuator::KX_MouseActuator(SCA_IObject* gameobj, KX_KetsjiEngine* ketsji m_visible(visible), m_threshold(threshold), m_sensitivity(sensitivity), - m_oldPosition(-1.0f, -1.0f), + m_initialSkipping(true), + m_oldPosition(mt::zero2), m_angle(mt::zero2) { for (unsigned short i = 0; i < 2; ++i) { @@ -71,14 +72,12 @@ KX_MouseActuator::~KX_MouseActuator() bool KX_MouseActuator::Update() { - bool result = false; - bool bNegativeEvent = IsNegativeEvent(); RemoveAllEvents(); if (bNegativeEvent) { - // Reset previous position on negative events. - m_oldPosition = mt::vec2(-1.0f, -1.0f); + // Reset initial skipping check on negative events. + m_initialSkipping = true; return false; } @@ -121,7 +120,7 @@ bool KX_MouseActuator::Update() } //preventing initial skipping. - if ((m_oldPosition.x <= -0.9f) && (m_oldPosition.y <= -0.9f)) { + if (m_initialSkipping) { for (unsigned short i = 0; i < 2; ++i) { if (m_reset[i]) { m_oldPosition[i] = center[i]; @@ -132,6 +131,7 @@ bool KX_MouseActuator::Update() } SetMousePosition(m_oldPosition); + m_initialSkipping = false; break; } @@ -205,7 +205,7 @@ bool KX_MouseActuator::Update() break; } } - return result; + return true; } EXP_Value *KX_MouseActuator::GetReplica() diff --git a/source/gameengine/Ketsji/KX_MouseActuator.h b/source/gameengine/Ketsji/KX_MouseActuator.h index 34e84fbe7df3..aa5476671883 100644 --- a/source/gameengine/Ketsji/KX_MouseActuator.h +++ b/source/gameengine/Ketsji/KX_MouseActuator.h @@ -41,6 +41,7 @@ class KX_MouseActuator : public SCA_IActuator SCA_IInputDevice* m_mouse; RAS_ICanvas* m_canvas; int m_type; + bool m_initialSkipping; bool m_visible;