mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-25 06:35:30 +00:00
replaced old movement input system
This commit is contained in:
parent
3cd1088695
commit
f773cf27cb
@ -41,8 +41,6 @@ namespace MWInput
|
|||||||
|
|
||||||
A_MoveLeft, // Move player left / right
|
A_MoveLeft, // Move player left / right
|
||||||
A_MoveRight,
|
A_MoveRight,
|
||||||
A_MoveUp, // Move up / down
|
|
||||||
A_MoveDown,
|
|
||||||
A_MoveForward, // Forward / Backward
|
A_MoveForward, // Forward / Backward
|
||||||
A_MoveBackward,
|
A_MoveBackward,
|
||||||
|
|
||||||
@ -143,17 +141,12 @@ namespace MWInput
|
|||||||
|
|
||||||
void toggleAutoMove()
|
void toggleAutoMove()
|
||||||
{
|
{
|
||||||
if (player.getAutoMove() == false)
|
player.setAutoMove (!player.getAutoMove());
|
||||||
{
|
|
||||||
player.setAutoMove(true);
|
|
||||||
} else {
|
|
||||||
player.setAutoMove(false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void toggleWalking()
|
void toggleWalking()
|
||||||
{
|
{
|
||||||
player.setisWalking(true);
|
player.toggleRunning();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Exit program now button (which is disabled in GUI mode)
|
// Exit program now button (which is disabled in GUI mode)
|
||||||
@ -262,10 +255,6 @@ namespace MWInput
|
|||||||
poller.bind(A_MoveRight, KC_D);
|
poller.bind(A_MoveRight, KC_D);
|
||||||
poller.bind(A_MoveForward, KC_W);
|
poller.bind(A_MoveForward, KC_W);
|
||||||
poller.bind(A_MoveBackward, KC_S);
|
poller.bind(A_MoveBackward, KC_S);
|
||||||
|
|
||||||
// Use shift and ctrl for up and down
|
|
||||||
poller.bind(A_MoveUp, KC_LSHIFT);
|
|
||||||
poller.bind(A_MoveDown, KC_LCONTROL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//NOTE: Used to check for movement keys
|
//NOTE: Used to check for movement keys
|
||||||
@ -283,50 +272,35 @@ namespace MWInput
|
|||||||
windows.update();
|
windows.update();
|
||||||
|
|
||||||
// Disable movement in Gui mode
|
// Disable movement in Gui mode
|
||||||
if(windows.isGuiMode()) return true;
|
if (windows.isGuiMode()) return true;
|
||||||
|
|
||||||
float speed = 300 * evt.timeSinceLastFrame; //placeholder player speed?
|
// Configure player movement according to keyboard input. Actual movement will
|
||||||
//float TESTwalkSpeed = 100 * evt.timeSinceLastFrame; //How about another?
|
// be done in the physics system.
|
||||||
|
if (poller.isDown(A_MoveLeft))
|
||||||
float moveX = 0, moveY = 0, moveZ = 0;
|
|
||||||
|
|
||||||
//execute Automove - condition checked in function
|
|
||||||
player.executeAutoMove((float)evt.timeSinceLastFrame); //or since last frame?
|
|
||||||
|
|
||||||
//Poll and execute movement keys - will disable automove if pressed.
|
|
||||||
if(poller.isDown(A_MoveLeft))
|
|
||||||
{
|
{
|
||||||
player.setAutoMove(false);
|
player.setAutoMove (false);
|
||||||
moveX -= speed;
|
player.setLeftRight (1);
|
||||||
}
|
}
|
||||||
|
else if (poller.isDown(A_MoveRight))
|
||||||
if(poller.isDown(A_MoveRight))
|
|
||||||
{
|
{
|
||||||
player.setAutoMove(false);
|
player.setAutoMove (false);
|
||||||
moveX += speed;
|
player.setLeftRight (-1);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
player.setLeftRight (0);
|
||||||
|
|
||||||
if(poller.isDown(A_MoveForward))
|
if (poller.isDown(A_MoveForward))
|
||||||
{
|
{
|
||||||
player.setAutoMove(false);
|
player.setAutoMove (false);
|
||||||
moveZ -= speed;
|
player.setForwardBackward (1);
|
||||||
}
|
}
|
||||||
|
else if (poller.isDown(A_MoveBackward))
|
||||||
if(poller.isDown(A_MoveBackward))
|
|
||||||
{
|
{
|
||||||
player.setAutoMove(false);
|
player.setAutoMove (false);
|
||||||
moveZ += speed;
|
player.setForwardBackward (-1);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
player.setForwardBackward (0);
|
||||||
// TODO: These should be enabled for floating modes (like
|
|
||||||
// swimming and levitation) and disabled for everything else.
|
|
||||||
if(poller.isDown(A_MoveUp)) moveY += speed;
|
|
||||||
if(poller.isDown(A_MoveDown)) moveY -= speed;
|
|
||||||
|
|
||||||
if(moveX != 0 || moveY != 0 || moveZ != 0)
|
|
||||||
player.moveRel(moveX, moveY, moveZ);
|
|
||||||
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -4,11 +4,13 @@
|
|||||||
#include "../mwrender/player.hpp"
|
#include "../mwrender/player.hpp"
|
||||||
|
|
||||||
#include "world.hpp"
|
#include "world.hpp"
|
||||||
|
#include "class.hpp"
|
||||||
|
|
||||||
namespace MWWorld
|
namespace MWWorld
|
||||||
{
|
{
|
||||||
Player::Player (MWRender::Player *renderer, const ESM::NPC *player, MWWorld::World& world) :
|
Player::Player (MWRender::Player *renderer, const ESM::NPC *player, MWWorld::World& world) :
|
||||||
mCellStore (0), mRenderer (renderer), mWorld (world), mClass (0), mCollisionMode (true)
|
mCellStore (0), mRenderer (renderer), mWorld (world), mClass (0), mCollisionMode (true),
|
||||||
|
mAutoMove (false), mForwardBackward (0)
|
||||||
{
|
{
|
||||||
mPlayer.base = player;
|
mPlayer.base = player;
|
||||||
mName = player->name;
|
mName = player->name;
|
||||||
@ -16,8 +18,6 @@ namespace MWWorld
|
|||||||
mRace = player->race;
|
mRace = player->race;
|
||||||
mPlayer.ref.pos.pos[0] = mPlayer.ref.pos.pos[1] = mPlayer.ref.pos.pos[2] = 0;
|
mPlayer.ref.pos.pos[0] = mPlayer.ref.pos.pos[1] = mPlayer.ref.pos.pos[2] = 0;
|
||||||
mClass = new ESM::Class (*world.getStore().classes.find (player->cls));
|
mClass = new ESM::Class (*world.getStore().classes.find (player->cls));
|
||||||
mAutoMove = false;
|
|
||||||
misWalking = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Player::~Player()
|
Player::~Player()
|
||||||
@ -64,4 +64,45 @@ namespace MWWorld
|
|||||||
mClass = new_class;
|
mClass = new_class;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Player::setAutoMove (bool enable)
|
||||||
|
{
|
||||||
|
MWWorld::Ptr ptr = getPlayer();
|
||||||
|
|
||||||
|
mAutoMove = enable;
|
||||||
|
|
||||||
|
int value = mForwardBackward;
|
||||||
|
|
||||||
|
if (mAutoMove)
|
||||||
|
value = 1;
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getMovementSettings (ptr).mForwardBackward = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Player::setLeftRight (int value)
|
||||||
|
{
|
||||||
|
MWWorld::Ptr ptr = getPlayer();
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getMovementSettings (ptr).mLeftRight = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Player::setForwardBackward (int value)
|
||||||
|
{
|
||||||
|
MWWorld::Ptr ptr = getPlayer();
|
||||||
|
|
||||||
|
mForwardBackward = value;
|
||||||
|
|
||||||
|
if (mAutoMove)
|
||||||
|
value = 1;
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getMovementSettings (ptr).mForwardBackward = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Player::toggleRunning()
|
||||||
|
{
|
||||||
|
MWWorld::Ptr ptr = getPlayer();
|
||||||
|
|
||||||
|
bool running = MWWorld::Class::get (ptr).getStance (ptr, MWWorld::Class::Run, true);
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).setStance (ptr, MWWorld::Class::Run, !running);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,9 +30,8 @@ namespace MWWorld
|
|||||||
std::string mBirthsign;
|
std::string mBirthsign;
|
||||||
ESM::Class *mClass;
|
ESM::Class *mClass;
|
||||||
bool mCollisionMode;
|
bool mCollisionMode;
|
||||||
|
|
||||||
bool mAutoMove;
|
bool mAutoMove;
|
||||||
bool misWalking;//Testing...
|
int mForwardBackward;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -117,33 +116,13 @@ namespace MWWorld
|
|||||||
return mAutoMove;
|
return mAutoMove;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setAutoMove(bool setMe)
|
void setAutoMove (bool enable);
|
||||||
{
|
|
||||||
mAutoMove = setMe;
|
|
||||||
}
|
|
||||||
|
|
||||||
//NOTE: we don't have speed being calculated yet, so for now this function only requires a frame duration.
|
void setLeftRight (int value);
|
||||||
/// <param name="duration">float value representing time since last call</param>
|
|
||||||
void executeAutoMove(float duration)
|
|
||||||
{
|
|
||||||
float X_Val = 0.0f;
|
|
||||||
float Y_Val = 0.0f;
|
|
||||||
float Z_Val = 300.0f * duration * -1.0f;
|
|
||||||
if (mAutoMove == true)
|
|
||||||
{
|
|
||||||
moveRel(X_Val, Y_Val, Z_Val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool getisWalking()
|
void setForwardBackward (int value);
|
||||||
{
|
|
||||||
return misWalking;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setisWalking(bool setMe)
|
void toggleRunning();
|
||||||
{
|
|
||||||
misWalking = setMe;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user