2021-09-19 15:44:31 +03:00
|
|
|
//
|
|
|
|
// Created by Иван Ильин on 19.09.2021.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "PlayerController.h"
|
2021-10-02 20:36:07 +03:00
|
|
|
#include "utils/Log.h"
|
|
|
|
#include "animation/AColor.h"
|
|
|
|
#include "animation/AFunction.h"
|
|
|
|
#include "animation/AWait.h"
|
|
|
|
#include "animation/ATranslate.h"
|
|
|
|
#include "animation/ATranslateToPoint.h"
|
2021-10-02 21:17:03 +03:00
|
|
|
#include "animation/Timeline.h"
|
2021-09-19 15:44:31 +03:00
|
|
|
|
|
|
|
PlayerController::PlayerController(std::shared_ptr<Player> player,
|
|
|
|
std::shared_ptr<Keyboard> keyboard,
|
2021-10-02 20:36:07 +03:00
|
|
|
std::shared_ptr<Mouse> mouse) : _player(player), _keyboard(keyboard), _mouse(mouse) {
|
2021-09-19 15:44:31 +03:00
|
|
|
_slowMoSound.setBuffer(*ResourceManager::loadSoundBuffer("../sound/slow_mo.ogg"));
|
|
|
|
_unSlowMoSound.setBuffer(*ResourceManager::loadSoundBuffer("../sound/unslow_mo.ogg"));
|
|
|
|
}
|
|
|
|
|
|
|
|
void PlayerController::update() {
|
|
|
|
// friction
|
|
|
|
if(_player->inCollision())
|
|
|
|
_player->setVelocity(_player->velocity()*(1.0 - Time::deltaTime() * 2));
|
|
|
|
|
|
|
|
if(_isInSlowMo) {
|
|
|
|
if(_player->ability() > 0)
|
|
|
|
_player->setAbility(_player->ability() - Time::deltaTime());
|
|
|
|
else {
|
|
|
|
_player->setAbility(0);
|
|
|
|
_isInSlowMo = false;
|
|
|
|
_player->setVelocity(_player->velocity() * _slowMoCoefficient);
|
|
|
|
_player->setAcceleration(_player->acceleration() * _slowMoCoefficient * _slowMoCoefficient);
|
|
|
|
_slowMoSound.stop();
|
|
|
|
_unSlowMoSound.play();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
double coeff = _isInSlowMo ? 1.0 / _slowMoCoefficient : 1.0;
|
|
|
|
|
|
|
|
bool inRunning_old = _inRunning;
|
|
|
|
_inRunning = ( Keyboard::isKeyPressed(sf::Keyboard::A) ||
|
|
|
|
Keyboard::isKeyPressed(sf::Keyboard::D) ||
|
|
|
|
Keyboard::isKeyPressed(sf::Keyboard::W) ||
|
|
|
|
Keyboard::isKeyPressed(sf::Keyboard::S));
|
|
|
|
|
2021-10-02 20:36:07 +03:00
|
|
|
std::shared_ptr<Object> camera = _player->attached("camera");
|
|
|
|
if(_inRunning) {
|
2021-10-02 21:17:03 +03:00
|
|
|
if (!Timeline::isInAnimList("camera_hor_oscil")) {
|
|
|
|
Timeline::animate("camera_hor_oscil", new ATranslate(camera, -camera->left() / 6, 0.3,Animation::LoopOut::None, Animation::cos));
|
|
|
|
Timeline::animate("camera_hor_oscil", new AWait(0));
|
|
|
|
Timeline::animate("camera_hor_oscil", new ATranslate(camera, camera->left() / 6, 0.3, Animation::LoopOut::None, Animation::cos));
|
2021-10-02 20:36:07 +03:00
|
|
|
|
2021-10-02 21:17:03 +03:00
|
|
|
Timeline::animate("camera_vert_oscil", new ATranslate(camera, -Point4D{0, 1, 0} / 12, 0.15, Animation::LoopOut::None, Animation::cos));
|
|
|
|
Timeline::animate("camera_vert_oscil", new AWait(0));
|
|
|
|
Timeline::animate("camera_vert_oscil", new ATranslate(camera, Point4D{0, 1, 0} / 12, 0.15, Animation::LoopOut::None,Animation::cos));
|
|
|
|
Timeline::animate("camera_vert_oscil", new AWait(0));
|
|
|
|
Timeline::animate("camera_vert_oscil", new ATranslate(camera, -Point4D{0, 1, 0} / 12, 0.15, Animation::LoopOut::None, Animation::cos));
|
|
|
|
Timeline::animate("camera_vert_oscil", new AWait(0));
|
|
|
|
Timeline::animate("camera_vert_oscil", new ATranslate(camera, Point4D{0, 1, 0} / 12, 0.15, Animation::LoopOut::None, Animation::cos));
|
2021-10-02 20:36:07 +03:00
|
|
|
|
2021-10-02 21:17:03 +03:00
|
|
|
Timeline::animate("camera_init", new ATranslateToPoint( camera, _player->position() + Point4D{0, 1.8, 0}, 0.3, Animation::None, Animation::cos));
|
2021-10-02 20:36:07 +03:00
|
|
|
}
|
2021-09-19 15:44:31 +03:00
|
|
|
} else if(inRunning_old && !_inRunning) {
|
2021-10-02 21:17:03 +03:00
|
|
|
Timeline::deleteAnimationList("camera_hor_oscil");
|
|
|
|
Timeline::deleteAnimationList("camera_vert_oscil");
|
|
|
|
Timeline::deleteAnimationList("camera_init");
|
|
|
|
Timeline::animate("camera_init", new ATranslateToPoint( camera, _player->position() + Point4D{0, 1.8, 0}, 0.15, Animation::None, Animation::cos));
|
2021-09-19 15:44:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Left and right
|
2021-10-02 20:36:07 +03:00
|
|
|
|
2021-09-19 15:44:31 +03:00
|
|
|
if (Keyboard::isKeyPressed(sf::Keyboard::A)) {
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->translate(_player->left() * Time::deltaTime() * _walkSpeed * coeff);
|
2021-09-19 15:44:31 +03:00
|
|
|
if(_player->inCollision())
|
|
|
|
_player->setVelocity(Point4D{0,0,0});
|
|
|
|
}
|
|
|
|
if (Keyboard::isKeyPressed(sf::Keyboard::D)) {
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->translate(-_player->left() * Time::deltaTime() * _walkSpeed * coeff);
|
2021-09-19 15:44:31 +03:00
|
|
|
if(_player->inCollision())
|
|
|
|
_player->setVelocity(Point4D{0,0,0});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Forward and backward
|
|
|
|
if (Keyboard::isKeyPressed(sf::Keyboard::W)) {
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->translate(_player->lookAt() * Time::deltaTime() * _walkSpeed * coeff);
|
2021-09-19 15:44:31 +03:00
|
|
|
if(_player->inCollision())
|
|
|
|
_player->setVelocity(Point4D{0,0,0});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Keyboard::isKeyPressed(sf::Keyboard::S)) {
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->translate(-_player->lookAt() * Time::deltaTime() * _walkSpeed * coeff);
|
2021-09-19 15:44:31 +03:00
|
|
|
|
|
|
|
if(_player->inCollision())
|
|
|
|
_player->setVelocity(Point4D{0,0,0});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_player->ability() > 0 && !_isInSlowMo && Keyboard::isKeyPressed(sf::Keyboard::LShift)) {
|
|
|
|
// slow mo
|
|
|
|
_isInSlowMo = true;
|
|
|
|
_player->setVelocity(_player->velocity() / _slowMoCoefficient);
|
|
|
|
_player->setAcceleration(_player->acceleration() / (_slowMoCoefficient * _slowMoCoefficient));
|
|
|
|
_unSlowMoSound.stop();
|
|
|
|
_slowMoSound.play();
|
|
|
|
} else if (_isInSlowMo && !Keyboard::isKeyPressed(sf::Keyboard::LShift)) {
|
|
|
|
_isInSlowMo = false;
|
|
|
|
_player->setVelocity(_player->velocity() * _slowMoCoefficient);
|
|
|
|
_player->setAcceleration(_player->acceleration() * _slowMoCoefficient * _slowMoCoefficient);
|
|
|
|
_slowMoSound.stop();
|
|
|
|
_unSlowMoSound.play();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Keyboard::isKeyPressed(sf::Keyboard::Space) && _player->inCollision()) {
|
|
|
|
_player->addVelocity(Point4D{0, std::abs(_player->collisionNormal().y()) * sqrt(2 * _g * _jumpHeight) * coeff, 0});
|
|
|
|
_player->translate(Point4D{0, Time::deltaTime() * _walkSpeed * 2 * coeff, 0});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Mouse movement
|
2021-10-02 20:36:07 +03:00
|
|
|
Point4D displacement = _mouse->getMouseDisplacement();
|
2021-09-19 15:44:31 +03:00
|
|
|
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->rotate(Point4D{0, -displacement.x() / 1000.0, 0});
|
|
|
|
_player->setVelocity(Matrix4x4::RotationY(-displacement.x() / 1000.0) * _player->velocity());
|
2021-09-19 15:44:31 +03:00
|
|
|
|
2021-10-02 20:36:07 +03:00
|
|
|
double rotationLeft = displacement.y() / 1000.0;
|
2021-09-19 15:44:31 +03:00
|
|
|
|
|
|
|
// You can only see in range [-90 : 90] grad
|
2021-10-02 20:36:07 +03:00
|
|
|
if (_player->headAngle() + rotationLeft > M_PI / 2)
|
|
|
|
rotationLeft = M_PI / 2 - _player->headAngle();
|
|
|
|
if (_player->headAngle() + rotationLeft < -M_PI / 2)
|
|
|
|
rotationLeft = -M_PI / 2 - _player->headAngle();
|
2021-09-19 15:44:31 +03:00
|
|
|
|
2021-10-02 20:36:07 +03:00
|
|
|
_player->setHeadAngle(_player->headAngle() + rotationLeft);
|
|
|
|
_player->rotateWeaponsRelativePoint(_player->position() + Point4D{0, 1.8, 0}, _player->left(), rotationLeft);
|
2021-09-19 15:44:31 +03:00
|
|
|
|
|
|
|
if (_keyboard->isKeyTapped(sf::Keyboard::Right) || _keyboard->isKeyTapped(sf::Keyboard::E)) {
|
|
|
|
_player->nextWeapon();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_keyboard->isKeyTapped(sf::Keyboard::Left) || _keyboard->isKeyTapped(sf::Keyboard::Q)) {
|
|
|
|
_player->previousWeapon();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Mouse::isButtonPressed(sf::Mouse::Button::Left)) {
|
|
|
|
_player->fire();
|
|
|
|
}
|
|
|
|
|
|
|
|
if(Keyboard::isKeyPressed(sf::Keyboard::R)) {
|
|
|
|
_player->reload();
|
|
|
|
}
|
|
|
|
|
2021-10-02 20:36:07 +03:00
|
|
|
if ((_inRunning || _player->velocity().sqrAbs() > 3) && _player->inCollision() && _walkSound.getStatus() != sf::Sound::Status::Playing) {
|
|
|
|
int soundNum = round((double) rand() / RAND_MAX * 5) + 1;
|
|
|
|
_walkSound.setBuffer(*ResourceManager::loadSoundBuffer("../sound/stonestep" + std::to_string(soundNum) + ".ogg"));
|
|
|
|
_walkSound.play();
|
2021-09-19 15:44:31 +03:00
|
|
|
}
|
|
|
|
}
|