70f104be07
* Move client list to ServerEnvironment and use RemotePlayer members instead of Player * ClientEnvironment only use setLocalPlayer to specify the current player * Remove ClientEnvironment dead code on player list (in fact other players are CAO not Player objects) * Drop LocalPlayer::getPlayer(xxx) functions which aren't used. * Improve a little bit performance by using const ref list for ClientEnvironment::getPlayerNames() & Client::getConnectedPlayerNames() * Drop isLocal() function from (Local)Player which is not needed anymore because of previous changes This change permits to cleanup shared client list which is very old code. ClientEnvironment doesn't use player list anymore, it only contains the local player, as addPlayer is only called from Client constructor client side. Clients are only CAO on client side, this cleanup permit to remove confusion about player list.
127 lines
3.3 KiB
C++
127 lines
3.3 KiB
C++
/*
|
|
Minetest
|
|
Copyright (C) 2010-2013 celeron55, Perttu Ahola <celeron55@gmail.com>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License along
|
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#ifndef LOCALPLAYER_HEADER
|
|
#define LOCALPLAYER_HEADER
|
|
|
|
#include "player.h"
|
|
#include "environment.h"
|
|
#include <list>
|
|
|
|
class Client;
|
|
class Environment;
|
|
class GenericCAO;
|
|
class ClientActiveObject;
|
|
class IGameDef;
|
|
|
|
enum LocalPlayerAnimations {NO_ANIM, WALK_ANIM, DIG_ANIM, WD_ANIM}; // no local animation, walking, digging, both
|
|
|
|
class LocalPlayer : public Player
|
|
{
|
|
public:
|
|
LocalPlayer(Client *gamedef, const char *name);
|
|
virtual ~LocalPlayer();
|
|
|
|
ClientActiveObject *parent;
|
|
|
|
bool got_teleported;
|
|
bool isAttached;
|
|
bool touching_ground;
|
|
// This oscillates so that the player jumps a bit above the surface
|
|
bool in_liquid;
|
|
// This is more stable and defines the maximum speed of the player
|
|
bool in_liquid_stable;
|
|
// Gets the viscosity of water to calculate friction
|
|
u8 liquid_viscosity;
|
|
bool is_climbing;
|
|
bool swimming_vertical;
|
|
|
|
float physics_override_speed;
|
|
float physics_override_jump;
|
|
float physics_override_gravity;
|
|
bool physics_override_sneak;
|
|
bool physics_override_sneak_glitch;
|
|
|
|
v3f overridePosition;
|
|
|
|
void move(f32 dtime, Environment *env, f32 pos_max_d);
|
|
void move(f32 dtime, Environment *env, f32 pos_max_d,
|
|
std::vector<CollisionInfo> *collision_info);
|
|
|
|
void applyControl(float dtime);
|
|
|
|
v3s16 getStandingNodePos();
|
|
|
|
// Used to check if anything changed and prevent sending packets if not
|
|
v3f last_position;
|
|
v3f last_speed;
|
|
float last_pitch;
|
|
float last_yaw;
|
|
unsigned int last_keyPressed;
|
|
|
|
float camera_impact;
|
|
|
|
int last_animation;
|
|
float last_animation_speed;
|
|
|
|
std::string hotbar_image;
|
|
std::string hotbar_selected_image;
|
|
|
|
video::SColor light_color;
|
|
|
|
float hurt_tilt_timer;
|
|
float hurt_tilt_strength;
|
|
|
|
GenericCAO* getCAO() const {
|
|
return m_cao;
|
|
}
|
|
|
|
void setCAO(GenericCAO* toset) {
|
|
assert( m_cao == NULL ); // Pre-condition
|
|
m_cao = toset;
|
|
}
|
|
|
|
u32 maxHudId() const { return hud.size(); }
|
|
|
|
private:
|
|
void accelerateHorizontal(const v3f &target_speed, const f32 max_increase);
|
|
void accelerateVertical(const v3f &target_speed, const f32 max_increase);
|
|
|
|
// This is used for determining the sneaking range
|
|
v3s16 m_sneak_node;
|
|
// Whether the player is allowed to sneak
|
|
bool m_sneak_node_exists;
|
|
// Whether recalculation of the sneak node is needed
|
|
bool m_need_to_get_new_sneak_node;
|
|
// Stores the max player uplift by m_sneak_node and is updated
|
|
// when m_need_to_get_new_sneak_node == true
|
|
f32 m_sneak_node_bb_ymax;
|
|
// Node below player, used to determine whether it has been removed,
|
|
// and its old type
|
|
v3s16 m_old_node_below;
|
|
std::string m_old_node_below_type;
|
|
bool m_can_jump;
|
|
|
|
GenericCAO* m_cao;
|
|
Client *m_gamedef;
|
|
};
|
|
|
|
#endif
|
|
|