From 7ba24dd27a1c8e8720c7d52d29ceb48a4a3f38db Mon Sep 17 00:00:00 2001 From: iWas-Coder Date: Mon, 7 Oct 2024 13:00:04 +0200 Subject: [PATCH] [WIP] fix: invalidate rvalue instead of curr instance Also, use props from `Transform` instead of from `SpriteRenderer`. --- src/Renderer/Sprite.cc | 6 +++--- src/Runtime/Scene.cc | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/Renderer/Sprite.cc b/src/Renderer/Sprite.cc index e8f9c9c..086b580 100644 --- a/src/Renderer/Sprite.cc +++ b/src/Renderer/Sprite.cc @@ -34,10 +34,10 @@ namespace volt::renderer { { // NOTE: leave the rvalue Sprite object in an invalid state (id <= 0), so when it gets destroyed (after it's moved) // it doesn't get unloaded from GPU's VRAM (i.e. leave the moved-from object as a hollow object (empty state)). - m_width = 0; - m_height = 0; + s.m_width = 0; + s.m_height = 0; s.m_data = {}; - m_name.clear(); + s.m_name.clear(); } Sprite::~Sprite(void) { diff --git a/src/Runtime/Scene.cc b/src/Runtime/Scene.cc index 741553f..8fc6f4f 100644 --- a/src/Runtime/Scene.cc +++ b/src/Runtime/Scene.cc @@ -65,7 +65,7 @@ namespace volt::runtime { m_worldID = b2CreateWorld(&worldDef); } ForAll([this](auto e, auto &t, auto &rb, auto &sr) { - rb.SetExtent({sr.scale * sr.sprite.width() * 0.5f, sr.scale * sr.sprite.height() * 0.5f}); + rb.SetExtent({t.scale * sr.sprite.width() * 0.5f, t.scale * sr.sprite.height() * 0.5f}); b2BodyDef bodyDef { b2DefaultBodyDef() }; bodyDef.type = static_cast(rb.type); bodyDef.gravityScale = rb.gravityScale;