OpenMiner/include/player.h
2013-05-22 23:43:05 +02:00

69 lines
2.0 KiB
C++

/*---------------------------------------------------------------------------------
KubKraft
Copyright (C) 2013 Quentin Bazin <quent42340@gmail.com>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
---------------------------------------------------------------------------------*/
#ifndef PLAYER_H
#define PLAYER_H
#define RADIANS_PER_DEGREES 0.0174532925199
class Player {
public:
Player(float x, float y, float z, float angle);
void move(float distance, float direction);
void update();
void jump();
void fly();
void land();
void turnH(float angle);
void turnV(float angle);
void watch();
float x() const { return m_x; }
float y() const { return m_y; }
float z() const { return m_eyeheight; }
bool isJumping() const { return m_isJumping; }
void setJumpSpeed(float jumpSpeed) { m_speed.z = jumpSpeed; }
void setJumping(bool isJumping) { m_isJumping = isJumping; }
float pointTargetedx() { return m_x + cos(m_angleH * RADIANS_PER_DEGREES) * cos(m_angleV * RADIANS_PER_DEGREES); }
float pointTargetedy() { return m_y + sin(m_angleH * RADIANS_PER_DEGREES) * cos(m_angleV * RADIANS_PER_DEGREES); }
float pointTargetedz() { return m_eyeheight + sin(m_angleV * RADIANS_PER_DEGREES); }
private:
float m_x;
float m_y;
float m_eyeheight;
float m_angleH;
float m_angleV;
bool m_isJumping;
vect3D m_speed;
void testPoint(vect3D pos, vect3D *speed, bool playerFoots = false);
};
#endif // PLAYER_H