Feat : + Show the texture of the object in the Object Window Fix : - No warning for now...
204 lines
4.6 KiB
C++
204 lines
4.6 KiB
C++
#include "positionclass.h"
|
|
|
|
PositionClass::PositionClass()
|
|
{
|
|
m_frameTime = 0.0f;
|
|
m_rotationY = 0.0f;
|
|
m_rotationX = 0.0f;
|
|
m_positionX = 0.0f;
|
|
m_positionY = 0.0f;
|
|
m_positionZ = 0.0f;
|
|
m_leftTurnSpeed = 0.0f;
|
|
m_rightTurnSpeed = 0.0f;
|
|
}
|
|
|
|
|
|
PositionClass::PositionClass(const PositionClass& other)
|
|
{
|
|
}
|
|
|
|
|
|
PositionClass::~PositionClass()
|
|
{
|
|
}
|
|
|
|
void PositionClass::SetFrameTime(float time)
|
|
{
|
|
m_frameTime = time;
|
|
return;
|
|
}
|
|
|
|
void PositionClass::GetRotation(float& y, float& x)
|
|
{
|
|
y = m_rotationY;
|
|
x = m_rotationX;
|
|
return;
|
|
}
|
|
|
|
void PositionClass::GetPosition(float& x, float& y, float& z)
|
|
{
|
|
x = m_positionX;
|
|
y = m_positionY;
|
|
z = m_positionZ;
|
|
return;
|
|
}
|
|
|
|
void PositionClass::TurnLeft(bool keydown)
|
|
{
|
|
// If the key is pressed increase the speed at which the camera turns left. If not slow down the turn speed.
|
|
if (keydown)
|
|
{
|
|
m_leftTurnSpeed += m_frameTime * 1.5f;
|
|
|
|
if (m_leftTurnSpeed > (m_frameTime * 200.0f))
|
|
{
|
|
m_leftTurnSpeed = m_frameTime * 200.0f;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
m_leftTurnSpeed -= m_frameTime * 1.0f;
|
|
|
|
if (m_leftTurnSpeed < 0.0f)
|
|
{
|
|
m_leftTurnSpeed = 0.0f;
|
|
}
|
|
}
|
|
|
|
// Update the rotation using the turning speed.
|
|
m_rotationY -= m_leftTurnSpeed;
|
|
if (m_rotationY < 0.0f)
|
|
{
|
|
m_rotationY += 360.0f;
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
void PositionClass::TurnRight(bool keydown)
|
|
{
|
|
// If the key is pressed increase the speed at which the camera turns right. If not slow down the turn speed.
|
|
if (keydown)
|
|
{
|
|
m_rightTurnSpeed += m_frameTime * 1.5f;
|
|
|
|
if (m_rightTurnSpeed > (m_frameTime * 200.0f))
|
|
{
|
|
m_rightTurnSpeed = m_frameTime * 200.0f;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
m_rightTurnSpeed -= m_frameTime * 1.0f;
|
|
|
|
if (m_rightTurnSpeed < 0.0f)
|
|
{
|
|
m_rightTurnSpeed = 0.0f;
|
|
}
|
|
}
|
|
|
|
// Update the rotation using the turning speed.
|
|
m_rotationY += m_rightTurnSpeed;
|
|
if (m_rotationY > 360.0f)
|
|
{
|
|
m_rotationY -= 360.0f;
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
void PositionClass::TurnMouse(int deltaX, int deltaY, bool rightMouseDown)
|
|
{
|
|
float speed = 0.1f;
|
|
// The turning speed is proportional to the horizontal mouse movement
|
|
m_horizontalTurnSpeed = deltaX * speed;
|
|
|
|
if (rightMouseDown)
|
|
{
|
|
// Update the rotation using the turning speed
|
|
m_rotationY += m_horizontalTurnSpeed;
|
|
if (m_rotationY < 0.0f)
|
|
{
|
|
m_rotationY += 360.0f;
|
|
}
|
|
else if (m_rotationY > 360.0f)
|
|
{
|
|
m_rotationY -= 360.0f;
|
|
}
|
|
|
|
// The turning speed is proportional to the vertical mouse movement
|
|
m_verticalTurnSpeed = deltaY * speed;
|
|
|
|
// Update the rotation using the turning speed
|
|
m_rotationX += m_verticalTurnSpeed;
|
|
if (m_rotationX < -90.0f)
|
|
{
|
|
m_rotationX = -90.0f;
|
|
}
|
|
else if (m_rotationX > 90.0f)
|
|
{
|
|
m_rotationX = 90.0f;
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
|
|
void PositionClass::MoveCamera(bool forward, bool backward, bool left, bool right, bool up, bool down)
|
|
{
|
|
float radiansY, radiansX;
|
|
float speed;
|
|
|
|
// Set the speed of the camera.
|
|
speed = 2.0f * m_frameTime;
|
|
|
|
// Convert degrees to radians.
|
|
radiansY = m_rotationY * 0.0174532925f;
|
|
radiansX = m_rotationX * 0.0174532925f;
|
|
|
|
// Update the position.
|
|
|
|
// If moving forward, the position moves in the direction of the camera and accordingly to its angle.
|
|
if (forward)
|
|
{
|
|
m_positionX += sinf(radiansY) * cosf(radiansX) * speed;
|
|
m_positionZ += cosf(radiansY) * cosf(radiansX) * speed;
|
|
m_positionY -= sinf(radiansX) * speed;
|
|
}
|
|
|
|
// If moving backward, the position moves in the opposite direction of the camera and accordingly to its angle.
|
|
if (backward)
|
|
{
|
|
m_positionX -= sinf(radiansY) * cosf(radiansX) * speed;
|
|
m_positionZ -= cosf(radiansY) * cosf(radiansX) * speed;
|
|
m_positionY += sinf(radiansX) * speed;
|
|
}
|
|
|
|
// If moving left, the position moves to the left of the camera and accordingly to its angle.
|
|
if (left)
|
|
{
|
|
m_positionX -= cosf(radiansY) * speed;
|
|
m_positionZ += sinf(radiansY) * speed;
|
|
}
|
|
|
|
// If moving right, the position moves to the right of the camera and accordingly to its angle.
|
|
if (right)
|
|
{
|
|
m_positionX += cosf(radiansY) * speed;
|
|
m_positionZ -= sinf(radiansY) * speed;
|
|
}
|
|
|
|
// If moving up, the position moves up.
|
|
if (up)
|
|
{
|
|
m_positionY += speed;
|
|
}
|
|
|
|
// If moving down, the position moves down.
|
|
if (down)
|
|
{
|
|
m_positionY -= speed;
|
|
}
|
|
|
|
return;
|
|
} |