mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 15:56:37 +00:00 
			
		
		
		
	CharacterController compiles
This commit is contained in:
		
							parent
							
								
									15164e20f7
								
							
						
					
					
						commit
						a3417a9c49
					
				
					 5 changed files with 51 additions and 22 deletions
				
			
		|  | @ -82,7 +82,7 @@ add_openmw_dir (mwmechanics | ||||||
|     drawstate spells activespells npcstats aipackage aisequence aipursue alchemy aiwander aitravel aifollow aiavoiddoor |     drawstate spells activespells npcstats aipackage aisequence aipursue alchemy aiwander aitravel aifollow aiavoiddoor | ||||||
|     aiescort aiactivate aicombat repair enchanting pathfinding pathgrid security spellsuccess spellcasting |     aiescort aiactivate aicombat repair enchanting pathfinding pathgrid security spellsuccess spellcasting | ||||||
|     disease pickpocket levelledlist combat steering obstacle autocalcspell difficultyscaling aicombataction actor summoning |     disease pickpocket levelledlist combat steering obstacle autocalcspell difficultyscaling aicombataction actor summoning | ||||||
| # character actors objects |     character actors objects | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| add_openmw_dir (mwstate | add_openmw_dir (mwstate | ||||||
|  |  | ||||||
|  | @ -252,7 +252,7 @@ namespace MWMechanics | ||||||
|                     .search("VFX_Soul_Trap"); |                     .search("VFX_Soul_Trap"); | ||||||
|             if (fx) |             if (fx) | ||||||
|                 MWBase::Environment::get().getWorld()->spawnEffect("meshes\\" + fx->mModel, |                 MWBase::Environment::get().getWorld()->spawnEffect("meshes\\" + fx->mModel, | ||||||
|                     "", Ogre::Vector3(mCreature.getRefData().getPosition().pos)); |                     "", mCreature.getRefData().getPosition().asVec3()); | ||||||
| 
 | 
 | ||||||
|             MWBase::Environment::get().getSoundManager()->playSound3D(mCreature, "conjuration hit", 1.f, 1.f, |             MWBase::Environment::get().getSoundManager()->playSound3D(mCreature, "conjuration hit", 1.f, 1.f, | ||||||
|                                                                       MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_NoTrack); |                                                                       MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_NoTrack); | ||||||
|  | @ -274,6 +274,7 @@ namespace MWMechanics | ||||||
|     void Actors::updateHeadTracking(const MWWorld::Ptr& actor, const MWWorld::Ptr& targetActor, |     void Actors::updateHeadTracking(const MWWorld::Ptr& actor, const MWWorld::Ptr& targetActor, | ||||||
|                                     MWWorld::Ptr& headTrackTarget, float& sqrHeadTrackDistance) |                                     MWWorld::Ptr& headTrackTarget, float& sqrHeadTrackDistance) | ||||||
|     { |     { | ||||||
|  |         /*
 | ||||||
|         static const float fMaxHeadTrackDistance = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>() |         static const float fMaxHeadTrackDistance = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>() | ||||||
|                 .find("fMaxHeadTrackDistance")->getFloat(); |                 .find("fMaxHeadTrackDistance")->getFloat(); | ||||||
|         static const float fInteriorHeadTrackMult = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>() |         static const float fInteriorHeadTrackMult = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>() | ||||||
|  | @ -306,6 +307,7 @@ namespace MWMechanics | ||||||
|             sqrHeadTrackDistance = sqrDist; |             sqrHeadTrackDistance = sqrDist; | ||||||
|             headTrackTarget = targetActor; |             headTrackTarget = targetActor; | ||||||
|         } |         } | ||||||
|  |         */ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Actors::engageCombat (const MWWorld::Ptr& actor1, const MWWorld::Ptr& actor2, bool againstPlayer) |     void Actors::engageCombat (const MWWorld::Ptr& actor1, const MWWorld::Ptr& actor2, bool againstPlayer) | ||||||
|  |  | ||||||
|  | @ -27,7 +27,7 @@ | ||||||
| #include "creaturestats.hpp" | #include "creaturestats.hpp" | ||||||
| #include "security.hpp" | #include "security.hpp" | ||||||
| 
 | 
 | ||||||
| #include <openengine/misc/rng.hpp> | #include <components/misc/rng.hpp> | ||||||
| 
 | 
 | ||||||
| #include <components/settings/settings.hpp> | #include <components/settings/settings.hpp> | ||||||
| 
 | 
 | ||||||
|  | @ -222,7 +222,7 @@ std::string CharacterController::chooseRandomGroup (const std::string& prefix, i | ||||||
|     while (mAnimation->hasAnimation(prefix + Ogre::StringConverter::toString(numAnims+1))) |     while (mAnimation->hasAnimation(prefix + Ogre::StringConverter::toString(numAnims+1))) | ||||||
|         ++numAnims; |         ++numAnims; | ||||||
| 
 | 
 | ||||||
|     int roll = OEngine::Misc::Rng::rollDice(numAnims) + 1; // [1, numAnims]
 |     int roll = Misc::Rng::rollDice(numAnims) + 1; // [1, numAnims]
 | ||||||
|     if (num) |     if (num) | ||||||
|         *num = roll; |         *num = roll; | ||||||
|     return prefix + Ogre::StringConverter::toString(roll); |     return prefix + Ogre::StringConverter::toString(roll); | ||||||
|  | @ -654,7 +654,7 @@ CharacterController::CharacterController(const MWWorld::Ptr &ptr, MWRender::Anim | ||||||
|     { |     { | ||||||
|         /* Accumulate along X/Y only for now, until we can figure out how we should
 |         /* Accumulate along X/Y only for now, until we can figure out how we should
 | ||||||
|          * handle knockout and death which moves the character down. */ |          * handle knockout and death which moves the character down. */ | ||||||
|         mAnimation->setAccumulation(Ogre::Vector3(1.0f, 1.0f, 0.0f)); |         mAnimation->setAccumulation(osg::Vec3f(1.0f, 1.0f, 0.0f)); | ||||||
| 
 | 
 | ||||||
|         if (cls.hasInventoryStore(mPtr)) |         if (cls.hasInventoryStore(mPtr)) | ||||||
|         { |         { | ||||||
|  | @ -685,7 +685,7 @@ CharacterController::CharacterController(const MWWorld::Ptr &ptr, MWRender::Anim | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         /* Don't accumulate with non-actors. */ |         /* Don't accumulate with non-actors. */ | ||||||
|         mAnimation->setAccumulation(Ogre::Vector3(0.0f)); |         mAnimation->setAccumulation(osg::Vec3f(0.f, 0.f, 0.f)); | ||||||
| 
 | 
 | ||||||
|         mIdleState = CharState_Idle; |         mIdleState = CharState_Idle; | ||||||
|     } |     } | ||||||
|  | @ -710,12 +710,14 @@ void CharacterController::updatePtr(const MWWorld::Ptr &ptr) | ||||||
| void CharacterController::updateIdleStormState() | void CharacterController::updateIdleStormState() | ||||||
| { | { | ||||||
|     bool inStormDirection = false; |     bool inStormDirection = false; | ||||||
|  |     /*
 | ||||||
|     if (MWBase::Environment::get().getWorld()->isInStorm()) |     if (MWBase::Environment::get().getWorld()->isInStorm()) | ||||||
|     { |     { | ||||||
|         Ogre::Vector3 stormDirection = MWBase::Environment::get().getWorld()->getStormDirection(); |         Ogre::Vector3 stormDirection = MWBase::Environment::get().getWorld()->getStormDirection(); | ||||||
|         Ogre::Vector3 characterDirection = mPtr.getRefData().getBaseNode()->getOrientation().yAxis(); |         Ogre::Vector3 characterDirection = mPtr.getRefData().getBaseNode()->getOrientation().yAxis(); | ||||||
|         inStormDirection = stormDirection.angleBetween(characterDirection) > Ogre::Degree(120); |         inStormDirection = stormDirection.angleBetween(characterDirection) > Ogre::Degree(120); | ||||||
|     } |     } | ||||||
|  |     */ | ||||||
|     if (inStormDirection && mUpperBodyState == UpperCharState_Nothing && mAnimation->hasAnimation("idlestorm")) |     if (inStormDirection && mUpperBodyState == UpperCharState_Nothing && mAnimation->hasAnimation("idlestorm")) | ||||||
|     { |     { | ||||||
|         float complete = 0; |         float complete = 0; | ||||||
|  | @ -831,7 +833,7 @@ bool CharacterController::updateCreatureState() | ||||||
|             } |             } | ||||||
|             if (weapType != WeapType_Spell || !mAnimation->hasAnimation("spellcast")) // Not all creatures have a dedicated spellcast animation
 |             if (weapType != WeapType_Spell || !mAnimation->hasAnimation("spellcast")) // Not all creatures have a dedicated spellcast animation
 | ||||||
|             { |             { | ||||||
|                 int roll = OEngine::Misc::Rng::rollDice(3); // [0, 2]
 |                 int roll = Misc::Rng::rollDice(3); // [0, 2]
 | ||||||
|                 if (roll == 0) |                 if (roll == 0) | ||||||
|                     mCurrentWeapon = "attack1"; |                     mCurrentWeapon = "attack1"; | ||||||
|                 else if (roll == 1) |                 else if (roll == 1) | ||||||
|  | @ -1030,12 +1032,12 @@ bool CharacterController::updateWeaponState() | ||||||
|                     effect = store.get<ESM::MagicEffect>().find(effectentry.mEffectID); |                     effect = store.get<ESM::MagicEffect>().find(effectentry.mEffectID); | ||||||
| 
 | 
 | ||||||
|                     const ESM::Static* castStatic = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>().find ("VFX_Hands"); |                     const ESM::Static* castStatic = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>().find ("VFX_Hands"); | ||||||
|                     if (mAnimation->getNode("Left Hand")) |                     if (mAnimation->hasNode("Left Hand")) | ||||||
|                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Left Hand", effect->mParticle); |                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Left Hand", effect->mParticle); | ||||||
|                     else |                     else | ||||||
|                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Bip01 L Hand", effect->mParticle); |                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Bip01 L Hand", effect->mParticle); | ||||||
| 
 | 
 | ||||||
|                     if (mAnimation->getNode("Right Hand")) |                     if (mAnimation->hasNode("Right Hand")) | ||||||
|                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Right Hand", effect->mParticle); |                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Right Hand", effect->mParticle); | ||||||
|                     else |                     else | ||||||
|                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Bip01 R Hand", effect->mParticle); |                         mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Bip01 R Hand", effect->mParticle); | ||||||
|  | @ -1127,7 +1129,7 @@ bool CharacterController::updateWeaponState() | ||||||
|                 // most creatures don't actually have an attack wind-up animation, so use a uniform random value
 |                 // most creatures don't actually have an attack wind-up animation, so use a uniform random value
 | ||||||
|                 // (even some creatures that can use weapons don't have a wind-up animation either, e.g. Rieklings)
 |                 // (even some creatures that can use weapons don't have a wind-up animation either, e.g. Rieklings)
 | ||||||
|                 // Note: vanilla MW uses a random value for *all* non-player actors, but we probably don't need to go that far.
 |                 // Note: vanilla MW uses a random value for *all* non-player actors, but we probably don't need to go that far.
 | ||||||
|                 attackStrength = std::min(1.f, 0.1f + OEngine::Misc::Rng::rollClosedProbability()); |                 attackStrength = std::min(1.f, 0.1f + Misc::Rng::rollClosedProbability()); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if(mWeaponType != WeapType_Crossbow && mWeaponType != WeapType_BowAndArrow) |             if(mWeaponType != WeapType_Crossbow && mWeaponType != WeapType_BowAndArrow) | ||||||
|  | @ -1690,26 +1692,26 @@ void CharacterController::update(float duration) | ||||||
|         world->queueMovement(mPtr, Ogre::Vector3(0.0f)); |         world->queueMovement(mPtr, Ogre::Vector3(0.0f)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Ogre::Vector3 moved = mAnimation->runAnimation(mSkipAnim ? 0.f : duration); |     osg::Vec3f moved = mAnimation->runAnimation(mSkipAnim ? 0.f : duration); | ||||||
|     if(duration > 0.0f) |     if(duration > 0.0f) | ||||||
|         moved /= duration; |         moved /= duration; | ||||||
|     else |     else | ||||||
|         moved = Ogre::Vector3(0.0f); |         moved = osg::Vec3f(0.f, 0.f, 0.f); | ||||||
| 
 | 
 | ||||||
|     // Ensure we're moving in generally the right direction...
 |     // Ensure we're moving in generally the right direction...
 | ||||||
|     if(mMovementSpeed > 0.f) |     if(mMovementSpeed > 0.f) | ||||||
|     { |     { | ||||||
|         float l = moved.length(); |         float l = moved.length(); | ||||||
| 
 | 
 | ||||||
|         if((movement.x < 0.0f && movement.x < moved.x*2.0f) || |         if((movement.x < 0.0f && movement.x < moved.x()*2.0f) || | ||||||
|            (movement.x > 0.0f && movement.x > moved.x*2.0f)) |            (movement.x > 0.0f && movement.x > moved.x()*2.0f)) | ||||||
|             moved.x = movement.x; |             moved.x() = movement.x; | ||||||
|         if((movement.y < 0.0f && movement.y < moved.y*2.0f) || |         if((movement.y < 0.0f && movement.y < moved.y()*2.0f) || | ||||||
|            (movement.y > 0.0f && movement.y > moved.y*2.0f)) |            (movement.y > 0.0f && movement.y > moved.y()*2.0f)) | ||||||
|             moved.y = movement.y; |             moved.y() = movement.y; | ||||||
|         if((movement.z < 0.0f && movement.z < moved.z*2.0f) || |         if((movement.z < 0.0f && movement.z < moved.z()*2.0f) || | ||||||
|            (movement.z > 0.0f && movement.z > moved.z*2.0f)) |            (movement.z > 0.0f && movement.z > moved.z()*2.0f)) | ||||||
|             moved.z = movement.z; |             moved.z() = movement.z; | ||||||
|         // but keep the original speed
 |         // but keep the original speed
 | ||||||
|         float newLength = moved.length(); |         float newLength = moved.length(); | ||||||
|         if (newLength > 0) |         if (newLength > 0) | ||||||
|  | @ -1721,7 +1723,7 @@ void CharacterController::update(float duration) | ||||||
| 
 | 
 | ||||||
|     // Update movement
 |     // Update movement
 | ||||||
|     if(mMovementAnimationControlled && mPtr.getClass().isActor()) |     if(mMovementAnimationControlled && mPtr.getClass().isActor()) | ||||||
|         world->queueMovement(mPtr, moved); |         world->queueMovement(mPtr, Ogre::Vector3(moved.x(), moved.y(), moved.z())); | ||||||
| 
 | 
 | ||||||
|     mSkipAnim = false; |     mSkipAnim = false; | ||||||
| 
 | 
 | ||||||
|  | @ -1904,6 +1906,7 @@ void CharacterController::setHeadTrackTarget(const MWWorld::Ptr &target) | ||||||
| 
 | 
 | ||||||
| void CharacterController::updateHeadTracking(float duration) | void CharacterController::updateHeadTracking(float duration) | ||||||
| { | { | ||||||
|  |     /*
 | ||||||
|     Ogre::Node* head = mAnimation->getNode("Bip01 Head"); |     Ogre::Node* head = mAnimation->getNode("Bip01 Head"); | ||||||
|     if (!head) |     if (!head) | ||||||
|         return; |         return; | ||||||
|  | @ -1946,6 +1949,7 @@ void CharacterController::updateHeadTracking(float duration) | ||||||
| 
 | 
 | ||||||
|     mAnimation->setHeadPitch(xAngle); |     mAnimation->setHeadPitch(xAngle); | ||||||
|     mAnimation->setHeadYaw(zAngle); |     mAnimation->setHeadYaw(zAngle); | ||||||
|  |     */ | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1050,6 +1050,12 @@ namespace MWRender | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     bool Animation::hasNode(const std::string &name) | ||||||
|  |     { | ||||||
|  |         std::string lowerName = Misc::StringUtils::lowerCase(name); | ||||||
|  |         return (mNodeMap.find(lowerName) != mNodeMap.end()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     float Animation::AnimationTime::getValue(osg::NodeVisitor*) |     float Animation::AnimationTime::getValue(osg::NodeVisitor*) | ||||||
|     { |     { | ||||||
|         // FIXME: hold a pointer instead of searching every frame
 |         // FIXME: hold a pointer instead of searching every frame
 | ||||||
|  |  | ||||||
|  | @ -338,6 +338,23 @@ public: | ||||||
|     /// This is typically called as part of runAnimation, but may be called manually if needed.
 |     /// This is typically called as part of runAnimation, but may be called manually if needed.
 | ||||||
|     void updateEffects(float duration); |     void updateEffects(float duration); | ||||||
| 
 | 
 | ||||||
|  |     /// Is there a node with the specified name?
 | ||||||
|  |     /// @note The matching is case-insensitive.
 | ||||||
|  |     bool hasNode(const std::string& name); | ||||||
|  | 
 | ||||||
|  |     virtual void showWeapons(bool showWeapon) {} | ||||||
|  |     virtual void showCarriedLeft(bool show) {} | ||||||
|  |     virtual void setWeaponGroup(const std::string& group) {} | ||||||
|  |     virtual void setVampire(bool vampire) {} | ||||||
|  |     virtual void setAlpha(float alpha) {} | ||||||
|  |     virtual void setPitchFactor(float factor) {} | ||||||
|  |     virtual void attachArrow() {} | ||||||
|  |     virtual void enableHeadAnimation(bool enable) {} | ||||||
|  |     // TODO: move outside of this class
 | ||||||
|  |     /// Makes this object glow, by placing a Light in its center.
 | ||||||
|  |     /// @param effect Controls the radius and intensity of the light.
 | ||||||
|  |     virtual void setLightEffect(float effect) {} | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
|     Animation(const Animation&); |     Animation(const Animation&); | ||||||
|     void operator=(Animation&); |     void operator=(Animation&); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue