mirror of
https://github.com/celisej567/mcpe.git
synced 2026-01-02 01:48:27 +03:00
* WIP C++03 + Xbox 360 Support * math.h & _USE_MATH_DEFINES on Level.hpp Updated Xenon vcxproj file for new file structure. * * Fix bad GUI scale setup. * * Gui: Use ratios instead of hardcoded sub-1 floating point values, to make the mechanism more clear. * Add Direct Connect Button and Screen (#30) * Add Direct Connect Button and Screen * Remove accidental extra build directories for wasm * Add DirectConnectScreen.cpp to the CMake * Use Hungarian coding style notation * * Fix errors caused by #30 * * Improve the Chat Screen * * Improve the DirectConnectScreen, among other things. * * Update the game title once again. * * Add build-wasm.bat. * * Add info about compiling for wasm * * Fix send to specific GUID actually broadcasting to everyone * * Add command manager. * * Add writeable configuration. * * Allow dynamic screen size change on windows * * Allow the same thing on the emscripten version. * WIP C++03 + Xbox 360 Support * Fixed a possible merging issue that broke RakNet? * Additional Xbox 360 compatability fixes --------- Co-authored-by: Brent Da Mage <BrentDaMage@users.noreply.github.com> Co-authored-by: iProgramInCpp <iprogramincpp@gmail.com> Co-authored-by: ts <124226059+uniformization@users.noreply.github.com>
107 lines
1.9 KiB
C++
107 lines
1.9 KiB
C++
/********************************************************************
|
|
Minecraft: Pocket Edition - Decompilation Project
|
|
Copyright (C) 2023 iProgramInCpp
|
|
|
|
The following code is licensed under the BSD 1 clause license.
|
|
SPDX-License-Identifier: BSD-1-Clause
|
|
********************************************************************/
|
|
|
|
#include "TripodCamera.hpp"
|
|
#include "Player.hpp"
|
|
#include "world/level/Level.hpp"
|
|
|
|
TripodCamera::TripodCamera(Level* level, Player* player, float x, float y, float z) : Mob(level)
|
|
{
|
|
field_B8C = 0;
|
|
field_B90 = 80;
|
|
m_bActive = false;
|
|
|
|
m_owner = player;
|
|
field_C8 = RENDER_CAMERA;
|
|
|
|
field_60 = m_pitch = player->m_pitch;
|
|
field_5C = m_yaw = player->m_yaw;
|
|
|
|
field_34 = 1;
|
|
|
|
setSize(1.0f, 1.5f);
|
|
field_84 = field_8C * 0.5f - 0.25f;
|
|
|
|
setPos(x, y, z);
|
|
field_3C.x = x;
|
|
field_3C.y = y;
|
|
field_3C.z = z;
|
|
}
|
|
|
|
void TripodCamera::defineSynchedData()
|
|
{
|
|
|
|
}
|
|
|
|
float TripodCamera::getShadowHeightOffs()
|
|
{
|
|
return 0.0f;
|
|
}
|
|
|
|
bool TripodCamera::interact(Player* player)
|
|
{
|
|
// @BUG-ish: No check for owner?
|
|
m_bActive = true;
|
|
return true;
|
|
}
|
|
|
|
int TripodCamera::interactPreventDefault()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
bool TripodCamera::isPickable()
|
|
{
|
|
return !m_bRemoved;
|
|
}
|
|
|
|
bool TripodCamera::isPushable()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
void TripodCamera::tick()
|
|
{
|
|
field_3C = m_pos;
|
|
|
|
m_vel.y -= 0.04f;
|
|
move(m_vel.x, m_vel.y, m_vel.z);
|
|
|
|
m_vel *= 0.98f;
|
|
if (field_7C)
|
|
{
|
|
m_vel.x *= 0.7f;
|
|
m_vel.z *= 0.7f;
|
|
m_vel.y *= -0.5f;
|
|
}
|
|
|
|
if (!m_bActive)
|
|
return;
|
|
|
|
field_B90--;
|
|
if (field_B90 == 0)
|
|
{
|
|
remove();
|
|
return;
|
|
}
|
|
|
|
if (field_B90 == 8)
|
|
{
|
|
m_pLevel->takePicture(this, m_owner);
|
|
m_pLevel->addParticle("explode", m_pos.x, m_pos.y + 0.6f, m_pos.z, 0.0f, 0.0f, 0.0f);
|
|
m_pLevel->addParticle("explode", m_pos.x, m_pos.y + 0.8f, m_pos.z, 0.0f, 0.0f, 0.0f);
|
|
m_pLevel->addParticle("explode", m_pos.x, m_pos.y + 1.0f, m_pos.z, 0.0f, 0.0f, 0.0f);
|
|
return;
|
|
}
|
|
|
|
if (field_B90 > 8)
|
|
{
|
|
m_pLevel->addParticle("smoke", m_pos.x, m_pos.y + 1.0f, m_pos.z, 0.0f, 0.0f, 0.0f);
|
|
}
|
|
}
|