Skip to content

Commit

Permalink
Revert "Avoid iterating appear animation node when it's invisible (su…
Browse files Browse the repository at this point in the history
…pertuxkart#5200)"

This reverts commit 26caafa.
  • Loading branch information
Nomagno committed Dec 23, 2024
1 parent 4a479ed commit 94412d6
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 47 deletions.
90 changes: 46 additions & 44 deletions src/items/item.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -223,8 +223,7 @@ Item::Item(ItemType type, const Vec3& xyz, const Vec3& normal,
{
m_icon_node = NULL;
m_was_available_previously = true;
// Prevent appear animation at start
m_animation_start_ticks = -9999;
m_animation_start_ticks = 0;
m_distance_2 = 1.2f;
initItem(type, xyz, normal);
m_graphical_type = getGrahpicalType();
Expand Down Expand Up @@ -252,7 +251,6 @@ Item::Item(ItemType type, const Vec3& xyz, const Vec3& normal,
// when already quite far.
lodnode->autoComputeLevel(24); // The distance grows with the square root of the scaling factor
m_node = lodnode;
m_appear_anime_node = irr_driver->getSceneManager()->addEmptySceneNode(m_node);
}
setType(type);
handleNewMesh(getGrahpicalType());
Expand All @@ -275,7 +273,7 @@ Item::Item(ItemType type, const Vec3& xyz, const Vec3& normal,
{
scene::ISceneNode* billboard =
irr_driver->addBillboard(core::dimension2df(SPARK_SIZE, SPARK_SIZE),
"item_spark.png", m_appear_anime_node);
"item_spark.png", m_node);
#ifdef DEBUG
billboard->setName("spark");
#endif
Expand Down Expand Up @@ -363,11 +361,9 @@ Item::~Item()
if (m_node != NULL)
{
for (auto* node : m_spark_nodes)
m_appear_anime_node->removeChild(node);
m_node->removeChild(node);
if (m_icon_node)
m_appear_anime_node->removeChild(m_icon_node);

m_node->removeChild(m_appear_anime_node);
m_node->removeChild(m_icon_node);

irr_driver->removeNode(m_node);
m_node->drop();
Expand All @@ -384,7 +380,7 @@ Item::~Item()
void Item::reset()
{
m_was_available_previously = true;
m_animation_start_ticks = -9999;
m_animation_start_ticks = 0;
ItemState::reset();

if (m_node != NULL)
Expand Down Expand Up @@ -421,7 +417,7 @@ void Item::handleNewMesh(ItemType type)
if (!icon.empty())
{
m_icon_node = irr_driver->addBillboard(core::dimension2df(1.0f, 1.0f),
icon, m_appear_anime_node);
icon, m_node);

m_icon_node->setPosition(core::vector3df(0.0f, 0.5f, 0.0f));
m_icon_node->setVisible(false);
Expand Down Expand Up @@ -507,54 +503,60 @@ void Item::updateGraphics(float dt)
m_node->setRotation(hpr.toIrrHPR());
} // if item is available

bool is_in_appear_anime = time_since_return < 1.0f
|| (!isAvailable() && time_till_return < 1.0f);
m_appear_anime_node->setVisible(is_in_appear_anime);

if (is_in_appear_anime)
for (size_t i = 0; i < SPARK_AMOUNT; i++)
{
for (size_t i = 0; i < SPARK_AMOUNT; i++)
if (time_since_return >= 1.0f)
{
float t = time_since_return + 0.5f;
float t2 = time_since_return + 1.0f;
m_spark_nodes[i]->setVisible(false);
continue;
}

float node_angle = !rotating() ? 0.0f :
fmodf((float)World::getWorld()->getTicksSinceStart() / 40.0f,
M_PI * 2);
float t = time_since_return + 0.5f;
float t2 = time_since_return + 1.0f;

float x = sin(float(i) / float(SPARK_AMOUNT) * 2.0f * M_PI - node_angle)
* t * SPARK_SPEED_H;
float y = 2.0f * t2 - t2 * t2 - 0.5f;
float z = cos(float(i) / float(SPARK_AMOUNT) * 2.0f * M_PI - node_angle)
* t * SPARK_SPEED_H;
float node_angle = !rotating() ? 0.0f :
fmodf((float)World::getWorld()->getTicksSinceStart() / 40.0f,
M_PI * 2);

m_spark_nodes[i]->setPosition(core::vector3df(x, y, z));
float x = sin(float(i) / float(SPARK_AMOUNT) * 2.0f * M_PI - node_angle)
* t * SPARK_SPEED_H;
float y = 2.0f * t2 - t2 * t2 - 0.5f;
float z = cos(float(i) / float(SPARK_AMOUNT) * 2.0f * M_PI - node_angle)
* t * SPARK_SPEED_H;

float factor = std::max(0.0f, 1.0f - t / 2.0f);
m_spark_nodes[i]->setPosition(core::vector3df(x, y, z));

float factor = std::max(0.0f, 1.0f - t / 2.0f);

if (factor < 0.001f)
{
m_spark_nodes[i]->setVisible(false);
}
else
{
m_spark_nodes[i]->setVisible(true);

((scene::IBillboardSceneNode*)m_spark_nodes[i])
->setSize(core::dimension2df(factor * SPARK_SIZE,
factor * SPARK_SIZE));
factor * SPARK_SIZE));
}
}

if (m_icon_node)
if (m_icon_node)
{
if (!isAvailable() && time_till_return <= 1.0f)
{
m_icon_node->setVisible(true);
float size = 1.0f / (pow(6.0f, -time_till_return - 0.2f) *
(-time_till_return - 0.2f)) + 7.0f;

((scene::IBillboardSceneNode*)m_icon_node)
->setSize(core::dimension2df(size * ICON_SIZE,
size * ICON_SIZE));
}
else
{
if (!isAvailable())
{
m_icon_node->setVisible(true);
float size = 1.0f / (pow(6.0f, -time_till_return - 0.2f) *
(-time_till_return - 0.2f)) + 7.0f;

((scene::IBillboardSceneNode*)m_icon_node)
->setSize(core::dimension2df(size * ICON_SIZE,
size * ICON_SIZE));
}
else
{
m_icon_node->setVisible(false);
}
m_icon_node->setVisible(false);
}
}

Expand Down
3 changes: 0 additions & 3 deletions src/items/item.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -330,9 +330,6 @@ class Item : public ItemState, public NoCopy
/** Graphical type of the mesh. */
ItemType m_graphical_type;

/** The parent of m_spark_nodes and m_icon_node */
scene::ISceneNode* m_appear_anime_node;

/** Vector containing the sparks */
std::vector<scene::ISceneNode*> m_spark_nodes;

Expand Down

0 comments on commit 94412d6

Please sign in to comment.