mirror of
https://github.com/overte-org/overte.git
synced 2025-08-08 09:17:29 +02:00
Merge pull request #6012 from howard-stearns/align-body-to-head-on-reset
Align body to head on reset
This commit is contained in:
commit
4862e78fce
2 changed files with 33 additions and 16 deletions
|
@ -80,12 +80,10 @@ const float MyAvatar::ZOOM_DEFAULT = 1.5f;
|
||||||
|
|
||||||
MyAvatar::MyAvatar(RigPointer rig) :
|
MyAvatar::MyAvatar(RigPointer rig) :
|
||||||
Avatar(rig),
|
Avatar(rig),
|
||||||
_gravity(0.0f, 0.0f, 0.0f),
|
|
||||||
_wasPushing(false),
|
_wasPushing(false),
|
||||||
_isPushing(false),
|
_isPushing(false),
|
||||||
_isBraking(false),
|
_isBraking(false),
|
||||||
_boomLength(ZOOM_DEFAULT),
|
_boomLength(ZOOM_DEFAULT),
|
||||||
_trapDuration(0.0f),
|
|
||||||
_thrust(0.0f),
|
_thrust(0.0f),
|
||||||
_keyboardMotorVelocity(0.0f),
|
_keyboardMotorVelocity(0.0f),
|
||||||
_keyboardMotorTimescale(DEFAULT_KEYBOARD_MOTOR_TIMESCALE),
|
_keyboardMotorTimescale(DEFAULT_KEYBOARD_MOTOR_TIMESCALE),
|
||||||
|
@ -142,24 +140,46 @@ QByteArray MyAvatar::toByteArray(bool cullSmallChanges, bool sendAll) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyAvatar::reset() {
|
void MyAvatar::reset() {
|
||||||
_skeletonModel.reset();
|
// Gather animation mode...
|
||||||
getHead()->reset();
|
|
||||||
|
|
||||||
_targetVelocity = glm::vec3(0.0f);
|
|
||||||
setThrust(glm::vec3(0.0f));
|
|
||||||
// Reset the pitch and roll components of the avatar's orientation, preserve yaw direction
|
|
||||||
glm::vec3 eulers = safeEulerAngles(getOrientation());
|
|
||||||
eulers.x = 0.0f;
|
|
||||||
eulers.z = 0.0f;
|
|
||||||
setOrientation(glm::quat(eulers));
|
|
||||||
|
|
||||||
// This should be simpler when we have only graph animations always on.
|
// This should be simpler when we have only graph animations always on.
|
||||||
bool isRig = _rig->getEnableRig();
|
bool isRig = _rig->getEnableRig();
|
||||||
// seting rig animation to true, below, will clear the graph animation menu item, so grab it now.
|
// seting rig animation to true, below, will clear the graph animation menu item, so grab it now.
|
||||||
bool isGraph = _rig->getEnableAnimGraph() || Menu::getInstance()->isOptionChecked(MenuOption::EnableAnimGraph);
|
bool isGraph = _rig->getEnableAnimGraph() || Menu::getInstance()->isOptionChecked(MenuOption::EnableAnimGraph);
|
||||||
|
// ... and get to sane configuration where other activity won't bother us.
|
||||||
qApp->setRawAvatarUpdateThreading(false);
|
qApp->setRawAvatarUpdateThreading(false);
|
||||||
_rig->disableHands = true;
|
_rig->disableHands = true;
|
||||||
setEnableRigAnimations(true);
|
setEnableRigAnimations(true);
|
||||||
|
|
||||||
|
// Reset dynamic state.
|
||||||
|
_wasPushing = _isPushing = _isBraking = _billboardValid = _goToPending = _straightingLean = false;
|
||||||
|
_skeletonModel.reset();
|
||||||
|
getHead()->reset();
|
||||||
|
_targetVelocity = glm::vec3(0.0f);
|
||||||
|
setThrust(glm::vec3(0.0f));
|
||||||
|
|
||||||
|
// Get fresh data, in case we're really slow and out of wack.
|
||||||
|
_hmdSensorMatrix = qApp->getHMDSensorPose();
|
||||||
|
_hmdSensorPosition = extractTranslation(_hmdSensorMatrix);
|
||||||
|
_hmdSensorOrientation = glm::quat_cast(_hmdSensorMatrix);
|
||||||
|
|
||||||
|
// Reset body position/orientation under the head.
|
||||||
|
auto newBodySensorMatrix = deriveBodyFromHMDSensor(); // Based on current cached HMD position/rotation..
|
||||||
|
auto worldBodyMatrix = _sensorToWorldMatrix * newBodySensorMatrix;
|
||||||
|
glm::vec3 worldBodyPos = extractTranslation(worldBodyMatrix);
|
||||||
|
glm::quat worldBodyRot = glm::normalize(glm::quat_cast(worldBodyMatrix));
|
||||||
|
|
||||||
|
// FIXME: Hack to retain the previous behavior wrt height.
|
||||||
|
// I'd like to make the body match head height, but that will have to wait for separate PR.
|
||||||
|
worldBodyPos.y = getPosition().y;
|
||||||
|
|
||||||
|
setPosition(worldBodyPos);
|
||||||
|
setOrientation(worldBodyRot);
|
||||||
|
// If there is any discrepency between positioning and the head (as there is in initial deriveBodyFromHMDSensor),
|
||||||
|
// we can make that right by setting _bodySensorMatrix = newBodySensorMatrix.
|
||||||
|
// However, doing so will make the head want to point to the previous body orientation, as cached above.
|
||||||
|
//_bodySensorMatrix = newBodySensorMatrix;
|
||||||
|
//updateSensorToWorldMatrix(); // Uses updated position/orientation and _bodySensorMatrix changes
|
||||||
|
|
||||||
_skeletonModel.simulate(0.1f); // non-zero
|
_skeletonModel.simulate(0.1f); // non-zero
|
||||||
setEnableRigAnimations(false);
|
setEnableRigAnimations(false);
|
||||||
_skeletonModel.simulate(0.1f);
|
_skeletonModel.simulate(0.1f);
|
||||||
|
|
|
@ -282,8 +282,6 @@ private:
|
||||||
// results are in sensor space
|
// results are in sensor space
|
||||||
glm::mat4 deriveBodyFromHMDSensor() const;
|
glm::mat4 deriveBodyFromHMDSensor() const;
|
||||||
|
|
||||||
glm::vec3 _gravity;
|
|
||||||
|
|
||||||
float _driveKeys[MAX_DRIVE_KEYS];
|
float _driveKeys[MAX_DRIVE_KEYS];
|
||||||
bool _wasPushing;
|
bool _wasPushing;
|
||||||
bool _isPushing;
|
bool _isPushing;
|
||||||
|
@ -291,7 +289,6 @@ private:
|
||||||
|
|
||||||
float _boomLength;
|
float _boomLength;
|
||||||
|
|
||||||
float _trapDuration; // seconds that avatar has been trapped by collisions
|
|
||||||
glm::vec3 _thrust; // impulse accumulator for outside sources
|
glm::vec3 _thrust; // impulse accumulator for outside sources
|
||||||
|
|
||||||
glm::vec3 _keyboardMotorVelocity; // target local-frame velocity of avatar (keyboard)
|
glm::vec3 _keyboardMotorVelocity; // target local-frame velocity of avatar (keyboard)
|
||||||
|
|
Loading…
Reference in a new issue