mirror of
https://github.com/overte-org/overte.git
synced 2025-08-06 19:59:28 +02:00
Merge pull request #5457 from howard-stearns/no-idle-hip-shifting
Remove avatar->shift hips for idle animations.
This commit is contained in:
commit
0b1a36148e
7 changed files with 1 additions and 90 deletions
|
@ -249,8 +249,6 @@ Menu::Menu() {
|
||||||
addCheckableActionToQMenuAndActionHash(avatarMenu, MenuOption::BlueSpeechSphere, 0, true);
|
addCheckableActionToQMenuAndActionHash(avatarMenu, MenuOption::BlueSpeechSphere, 0, true);
|
||||||
addCheckableActionToQMenuAndActionHash(avatarMenu, MenuOption::EnableCharacterController, 0, true,
|
addCheckableActionToQMenuAndActionHash(avatarMenu, MenuOption::EnableCharacterController, 0, true,
|
||||||
avatar, SLOT(updateMotionBehavior()));
|
avatar, SLOT(updateMotionBehavior()));
|
||||||
addCheckableActionToQMenuAndActionHash(avatarMenu, MenuOption::ShiftHipsForIdleAnimations, 0, false,
|
|
||||||
avatar, SLOT(updateMotionBehavior()));
|
|
||||||
|
|
||||||
MenuWrapper* viewMenu = addMenu("View");
|
MenuWrapper* viewMenu = addMenu("View");
|
||||||
|
|
||||||
|
|
|
@ -273,7 +273,6 @@ namespace MenuOption {
|
||||||
const QString SimpleShadows = "Simple";
|
const QString SimpleShadows = "Simple";
|
||||||
const QString SixenseEnabled = "Enable Hydra Support";
|
const QString SixenseEnabled = "Enable Hydra Support";
|
||||||
const QString SixenseMouseInput = "Enable Sixense Mouse Input";
|
const QString SixenseMouseInput = "Enable Sixense Mouse Input";
|
||||||
const QString ShiftHipsForIdleAnimations = "Shift hips for idle animations";
|
|
||||||
const QString Stars = "Stars";
|
const QString Stars = "Stars";
|
||||||
const QString Stats = "Stats";
|
const QString Stats = "Stats";
|
||||||
const QString StopAllScripts = "Stop All Scripts";
|
const QString StopAllScripts = "Stop All Scripts";
|
||||||
|
|
|
@ -98,7 +98,6 @@ MyAvatar::MyAvatar() :
|
||||||
_lookAtTargetAvatar(),
|
_lookAtTargetAvatar(),
|
||||||
_shouldRender(true),
|
_shouldRender(true),
|
||||||
_billboardValid(false),
|
_billboardValid(false),
|
||||||
_feetTouchFloor(true),
|
|
||||||
_eyeContactTarget(LEFT_EYE),
|
_eyeContactTarget(LEFT_EYE),
|
||||||
_realWorldFieldOfView("realWorldFieldOfView",
|
_realWorldFieldOfView("realWorldFieldOfView",
|
||||||
DEFAULT_REAL_WORLD_FIELD_OF_VIEW_DEGREES),
|
DEFAULT_REAL_WORLD_FIELD_OF_VIEW_DEGREES),
|
||||||
|
@ -166,9 +165,6 @@ void MyAvatar::update(float deltaTime) {
|
||||||
head->setAudioAverageLoudness(audio->getAudioAverageInputLoudness());
|
head->setAudioAverageLoudness(audio->getAudioAverageInputLoudness());
|
||||||
|
|
||||||
simulate(deltaTime);
|
simulate(deltaTime);
|
||||||
if (_feetTouchFloor) {
|
|
||||||
_skeletonModel.updateStandingFoot();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyAvatar::simulate(float deltaTime) {
|
void MyAvatar::simulate(float deltaTime) {
|
||||||
|
@ -1140,11 +1136,7 @@ glm::vec3 MyAvatar::getSkeletonPosition() const {
|
||||||
// The avatar is rotated PI about the yAxis, so we have to correct for it
|
// The avatar is rotated PI about the yAxis, so we have to correct for it
|
||||||
// to get the skeleton offset contribution in the world-frame.
|
// to get the skeleton offset contribution in the world-frame.
|
||||||
const glm::quat FLIP = glm::angleAxis(PI, glm::vec3(0.0f, 1.0f, 0.0f));
|
const glm::quat FLIP = glm::angleAxis(PI, glm::vec3(0.0f, 1.0f, 0.0f));
|
||||||
glm::vec3 skeletonOffset = _skeletonOffset;
|
return _position + getOrientation() * FLIP * _skeletonOffset;
|
||||||
if (_feetTouchFloor) {
|
|
||||||
skeletonOffset += _skeletonModel.getStandingOffset();
|
|
||||||
}
|
|
||||||
return _position + getOrientation() * FLIP * skeletonOffset;
|
|
||||||
}
|
}
|
||||||
return Avatar::getPosition();
|
return Avatar::getPosition();
|
||||||
}
|
}
|
||||||
|
@ -1622,7 +1614,6 @@ void MyAvatar::updateMotionBehavior() {
|
||||||
_motionBehaviors &= ~AVATAR_MOTION_SCRIPTED_MOTOR_ENABLED;
|
_motionBehaviors &= ~AVATAR_MOTION_SCRIPTED_MOTOR_ENABLED;
|
||||||
}
|
}
|
||||||
_characterController.setEnabled(menu->isOptionChecked(MenuOption::EnableCharacterController));
|
_characterController.setEnabled(menu->isOptionChecked(MenuOption::EnableCharacterController));
|
||||||
_feetTouchFloor = menu->isOptionChecked(MenuOption::ShiftHipsForIdleAnimations);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Renders sixense laser pointers for UI selection with controllers
|
//Renders sixense laser pointers for UI selection with controllers
|
||||||
|
|
|
@ -258,7 +258,6 @@ private:
|
||||||
|
|
||||||
QList<AnimationHandlePointer> _animationHandles;
|
QList<AnimationHandlePointer> _animationHandles;
|
||||||
|
|
||||||
bool _feetTouchFloor;
|
|
||||||
eyeContactTarget _eyeContactTarget;
|
eyeContactTarget _eyeContactTarget;
|
||||||
|
|
||||||
RecorderPointer _recorder;
|
RecorderPointer _recorder;
|
||||||
|
|
|
@ -24,12 +24,6 @@
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include "InterfaceLogging.h"
|
#include "InterfaceLogging.h"
|
||||||
|
|
||||||
enum StandingFootState {
|
|
||||||
LEFT_FOOT,
|
|
||||||
RIGHT_FOOT,
|
|
||||||
NO_FOOT
|
|
||||||
};
|
|
||||||
|
|
||||||
SkeletonModel::SkeletonModel(Avatar* owningAvatar, QObject* parent) :
|
SkeletonModel::SkeletonModel(Avatar* owningAvatar, QObject* parent) :
|
||||||
Model(parent),
|
Model(parent),
|
||||||
_triangleFanID(DependencyManager::get<GeometryCache>()->allocateID()),
|
_triangleFanID(DependencyManager::get<GeometryCache>()->allocateID()),
|
||||||
|
@ -37,9 +31,6 @@ SkeletonModel::SkeletonModel(Avatar* owningAvatar, QObject* parent) :
|
||||||
_boundingShape(),
|
_boundingShape(),
|
||||||
_boundingShapeLocalOffset(0.0f),
|
_boundingShapeLocalOffset(0.0f),
|
||||||
_defaultEyeModelPosition(glm::vec3(0.0f, 0.0f, 0.0f)),
|
_defaultEyeModelPosition(glm::vec3(0.0f, 0.0f, 0.0f)),
|
||||||
_standingFoot(NO_FOOT),
|
|
||||||
_standingOffset(0.0f),
|
|
||||||
_clampedFootPosition(0.0f),
|
|
||||||
_headClipDistance(DEFAULT_NEAR_CLIP),
|
_headClipDistance(DEFAULT_NEAR_CLIP),
|
||||||
_isFirstPerson(false)
|
_isFirstPerson(false)
|
||||||
{
|
{
|
||||||
|
@ -573,65 +564,6 @@ glm::vec3 SkeletonModel::getDefaultEyeModelPosition() const {
|
||||||
return _owningAvatar->getScale() * _defaultEyeModelPosition;
|
return _owningAvatar->getScale() * _defaultEyeModelPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// \return offset of hips after foot animation
|
|
||||||
void SkeletonModel::updateStandingFoot() {
|
|
||||||
if (_geometry == NULL) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
glm::vec3 offset(0.0f);
|
|
||||||
int leftFootIndex = _geometry->getFBXGeometry().leftToeJointIndex;
|
|
||||||
int rightFootIndex = _geometry->getFBXGeometry().rightToeJointIndex;
|
|
||||||
|
|
||||||
if (leftFootIndex != -1 && rightFootIndex != -1) {
|
|
||||||
glm::vec3 leftPosition, rightPosition;
|
|
||||||
getJointPosition(leftFootIndex, leftPosition);
|
|
||||||
getJointPosition(rightFootIndex, rightPosition);
|
|
||||||
|
|
||||||
int lowestFoot = (leftPosition.y < rightPosition.y) ? LEFT_FOOT : RIGHT_FOOT;
|
|
||||||
const float MIN_STEP_HEIGHT_THRESHOLD = 0.05f;
|
|
||||||
bool oneFoot = fabsf(leftPosition.y - rightPosition.y) > MIN_STEP_HEIGHT_THRESHOLD;
|
|
||||||
int currentFoot = oneFoot ? lowestFoot : _standingFoot;
|
|
||||||
|
|
||||||
if (_standingFoot == NO_FOOT) {
|
|
||||||
currentFoot = lowestFoot;
|
|
||||||
}
|
|
||||||
if (currentFoot != _standingFoot) {
|
|
||||||
if (_standingFoot == NO_FOOT) {
|
|
||||||
// pick the lowest foot
|
|
||||||
glm::vec3 lowestPosition = (currentFoot == LEFT_FOOT) ? leftPosition : rightPosition;
|
|
||||||
// we ignore zero length positions which can happen for a few frames until skeleton is fully loaded
|
|
||||||
if (glm::length(lowestPosition) > 0.0f) {
|
|
||||||
_standingFoot = currentFoot;
|
|
||||||
_clampedFootPosition = lowestPosition;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// swap feet
|
|
||||||
_standingFoot = currentFoot;
|
|
||||||
glm::vec3 nextPosition = leftPosition;
|
|
||||||
glm::vec3 prevPosition = rightPosition;
|
|
||||||
if (_standingFoot == RIGHT_FOOT) {
|
|
||||||
nextPosition = rightPosition;
|
|
||||||
prevPosition = leftPosition;
|
|
||||||
}
|
|
||||||
glm::vec3 oldOffset = _clampedFootPosition - prevPosition;
|
|
||||||
_clampedFootPosition = oldOffset + nextPosition;
|
|
||||||
offset = _clampedFootPosition - nextPosition;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
glm::vec3 nextPosition = (_standingFoot == LEFT_FOOT) ? leftPosition : rightPosition;
|
|
||||||
offset = _clampedFootPosition - nextPosition;
|
|
||||||
}
|
|
||||||
|
|
||||||
// clamp the offset to not exceed some max distance
|
|
||||||
const float MAX_STEP_OFFSET = 1.0f;
|
|
||||||
float stepDistance = glm::length(offset);
|
|
||||||
if (stepDistance > MAX_STEP_OFFSET) {
|
|
||||||
offset *= (MAX_STEP_OFFSET / stepDistance);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
_standingOffset = offset;
|
|
||||||
}
|
|
||||||
|
|
||||||
float DENSITY_OF_WATER = 1000.0f; // kg/m^3
|
float DENSITY_OF_WATER = 1000.0f; // kg/m^3
|
||||||
float MIN_JOINT_MASS = 1.0f;
|
float MIN_JOINT_MASS = 1.0f;
|
||||||
float VERY_BIG_MASS = 1.0e6f;
|
float VERY_BIG_MASS = 1.0e6f;
|
||||||
|
|
|
@ -96,10 +96,6 @@ public:
|
||||||
/// \return whether or not the head was found.
|
/// \return whether or not the head was found.
|
||||||
glm::vec3 getDefaultEyeModelPosition() const;
|
glm::vec3 getDefaultEyeModelPosition() const;
|
||||||
|
|
||||||
/// skeleton offset caused by moving feet
|
|
||||||
void updateStandingFoot();
|
|
||||||
const glm::vec3& getStandingOffset() const { return _standingOffset; }
|
|
||||||
|
|
||||||
void computeBoundingShape(const FBXGeometry& geometry);
|
void computeBoundingShape(const FBXGeometry& geometry);
|
||||||
void renderBoundingCollisionShapes(gpu::Batch& batch, float alpha);
|
void renderBoundingCollisionShapes(gpu::Batch& batch, float alpha);
|
||||||
float getBoundingShapeRadius() const { return _boundingShape.getRadius(); }
|
float getBoundingShapeRadius() const { return _boundingShape.getRadius(); }
|
||||||
|
@ -169,9 +165,6 @@ private:
|
||||||
glm::vec3 _boundingShapeLocalOffset;
|
glm::vec3 _boundingShapeLocalOffset;
|
||||||
|
|
||||||
glm::vec3 _defaultEyeModelPosition;
|
glm::vec3 _defaultEyeModelPosition;
|
||||||
int _standingFoot;
|
|
||||||
glm::vec3 _standingOffset;
|
|
||||||
glm::vec3 _clampedFootPosition;
|
|
||||||
|
|
||||||
float _headClipDistance; // Near clip distance to use if no separate head model
|
float _headClipDistance; // Near clip distance to use if no separate head model
|
||||||
|
|
||||||
|
|
|
@ -215,7 +215,6 @@ public:
|
||||||
SixenseEnabled,
|
SixenseEnabled,
|
||||||
SixenseMouseInput,
|
SixenseMouseInput,
|
||||||
SixenseLasers,
|
SixenseLasers,
|
||||||
ShiftHipsForIdleAnimations,
|
|
||||||
Stars,
|
Stars,
|
||||||
Stats,
|
Stats,
|
||||||
StereoAudio,
|
StereoAudio,
|
||||||
|
|
Loading…
Reference in a new issue