From 3e3769f912aa5b9605e51057c11fffe78655eedb Mon Sep 17 00:00:00 2001 From: HappyTanuki Date: Thu, 19 Jun 2025 17:34:34 +0900 Subject: [PATCH] =?UTF-8?q?=EC=9D=BC=EB=8B=A8=20=EC=B6=A9=EB=8F=8C=20?= =?UTF-8?q?=EA=B5=AC=ED=98=84...=3F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Client/src/asteroid/begin_play.cpp | 24 ++++++++++- Client/src/asteroid/tick.cpp | 26 +++++++----- Server/src/server.cpp | 2 +- impl/vulkan_engine/vulkan/engine.cpp | 41 +++++++------------ impl/vulkan_engine/vulkan/physics.cpp | 46 +++++++++------------- include/utils/thread_pool.h | 4 +- include/vulkan_engine/asset/object/model.h | 4 +- include/vulkan_engine/vulkan/physics.h | 7 ++-- 8 files changed, 81 insertions(+), 73 deletions(-) diff --git a/Client/src/asteroid/begin_play.cpp b/Client/src/asteroid/begin_play.cpp index e3888ff..5adf155 100644 --- a/Client/src/asteroid/begin_play.cpp +++ b/Client/src/asteroid/begin_play.cpp @@ -14,7 +14,8 @@ void BeginPlay(veng::Engine& engine) { player->position = glm::vec3(jitterDist(gen), jitterDist(gen), 0.f); player->scale = glm::vec3(.02f); player->colision = true; - player->OnColision = [](std::shared_ptr self, + player->OnColision = [](utils::ThreadPool* thread_pool, + std::shared_ptr self, std::shared_ptr other) { auto self_owner = self->owner.lock(); auto other_owner = other->owner.lock(); @@ -51,6 +52,27 @@ void BeginPlay(veng::Engine& engine) { std::lock_guard lock(other_player->modding); other_player->position = glm::vec3(1.f, 0.f, 0.f); other_player->scale = glm::vec3(.02f); + player->colision = true; + player->OnColision = [](utils::ThreadPool* thread_pool, + std::shared_ptr self, + std::shared_ptr other) { + auto self_owner = self->owner.lock(); + auto other_owner = other->owner.lock(); + if (other_owner == nullptr || self_owner == nullptr) return; + if (other_owner->ID == self->ID) return; + spdlog::info("[{}:{}] and [{}:{}] is nearby.", self->name, + self->ID.snowflake, other->name, other->ID.snowflake); + + spdlog::info("[{}:{}] 's owner: [{}:{}]", self->name, self->ID.snowflake, + self_owner->name, self_owner->ID.snowflake); + spdlog::info("[{}:{}] 's owner: [{}:{}]", other->name, + other->ID.snowflake, other_owner->name, + other_owner->ID.snowflake); + + other->colision = false; + other->visible = false; + other->shouldBeDestroyed = true; + }; other_player->colision = true; } diff --git a/Client/src/asteroid/tick.cpp b/Client/src/asteroid/tick.cpp index 1dff33f..377f16d 100644 --- a/Client/src/asteroid/tick.cpp +++ b/Client/src/asteroid/tick.cpp @@ -86,8 +86,9 @@ void Tick(veng::Engine& engine, std::float_t delta_time) { bullet->owner = player; bullet->scale = player->scale; bullet->colision = true; - bullet->OnColision = [](std::shared_ptr self, - std::shared_ptr other) { + bullet->OnColision = [](utils::ThreadPool* thread_pool, + std::shared_ptr self, + std::shared_ptr other) { auto self_owner = self->owner.lock(); auto other_owner = other->owner.lock(); if (other_owner == nullptr || self_owner == nullptr) return; @@ -112,30 +113,35 @@ void Tick(veng::Engine& engine, std::float_t delta_time) { } static bool ad_laststate = false; + right = player->rotation * glm::vec3(0, 0, 1); if (glfwGetKey(engine.vulkan_graphics->window->GetHandle(), GLFW_KEY_A) == GLFW_PRESS) { - right = player->rotation * glm::vec3(0, 0, 1); player->angular_velocity = right * 6.f; if (!ad_laststate) { player->needsUpdate = true; - player->updateRedundantCount = 0; + player->updateRedundantCount = 1; ad_laststate = true; } - } else if (glfwGetKey(engine.vulkan_graphics->window->GetHandle(), + } + + if (glfwGetKey(engine.vulkan_graphics->window->GetHandle(), GLFW_KEY_D) == GLFW_PRESS) { - right = player->rotation * glm::vec3(0, 0, 1); player->angular_velocity = right * -6.f; if (!ad_laststate) { player->needsUpdate = true; - player->updateRedundantCount = 0; + player->updateRedundantCount = 1; ad_laststate = true; } - } else { - right = player->rotation * glm::vec3(0, 0, 1); + } + + if (glfwGetKey(engine.vulkan_graphics->window->GetHandle(), GLFW_KEY_A) == + GLFW_RELEASE && + glfwGetKey(engine.vulkan_graphics->window->GetHandle(), GLFW_KEY_D) == + GLFW_RELEASE) { player->angular_velocity = right * 0.f; if (ad_laststate) { player->needsUpdate = true; - player->updateRedundantCount = 0; + player->updateRedundantCount = 2; ad_laststate = false; } } diff --git a/Server/src/server.cpp b/Server/src/server.cpp index 31b25e0..f2016db 100644 --- a/Server/src/server.cpp +++ b/Server/src/server.cpp @@ -13,7 +13,7 @@ #define LISTENIP "::" #define LISTENPORT 9010 -#define TICKRATE 60 +#define TICKRATE 30 constexpr double TICKDELAY = (1 / TICKRATE); std::uint8_t CLIENTID = 0; diff --git a/impl/vulkan_engine/vulkan/engine.cpp b/impl/vulkan_engine/vulkan/engine.cpp index cbe3f7a..4337617 100644 --- a/impl/vulkan_engine/vulkan/engine.cpp +++ b/impl/vulkan_engine/vulkan/engine.cpp @@ -20,15 +20,16 @@ void Engine::init() { } void Engine::LoadModelAsset(std::string path, std::string name) { - veng::Model model(vulkan_graphics); + model_assets_[name] = veng::Model(vulkan_graphics); asset_loader_.setPath(path); - asset_loader_.loadModel(model); + asset_loader_.loadModel(model_assets_[name]); - model.vertex_buffer = vulkan_graphics->CreateVertexBuffer(model.vertices); - model.index_buffer = vulkan_graphics->CreateIndexBuffer(model.indices); - model.material.texture_handle = + model_assets_[name].vertex_buffer = + vulkan_graphics->CreateVertexBuffer(model_assets_[name].vertices); + model_assets_[name].index_buffer = + vulkan_graphics->CreateIndexBuffer(model_assets_[name].indices); + model_assets_[name].material.texture_handle = vulkan_graphics->CreateTexture(asset_loader_.readTexture()); - model_assets_[name] = std::move(model); } const Model* Engine::GetStaticModel(std::string name) { @@ -117,15 +118,11 @@ void Engine::Update() { if (Tick != nullptr) Tick(*this, delta_time); - std::vector> models; - models.reserve(models_.size()); - for (auto it = models_.begin(); it != models_.end();) { auto& model = it->second; if (std::abs(model->lifespan + 1.f) < std::numeric_limits::epsilon()) { - models.push_back(model); ++it; continue; } @@ -141,8 +138,6 @@ void Engine::Update() { } model->lifespan -= delta_time; - - models.push_back(model); ++it; } @@ -151,7 +146,7 @@ void Engine::Update() { vulkan_graphics->RenderModel(it.second); } - physics_controller_.invokeOnColisionEvent(thread_pool_, models); + physics_controller_.invokeOnColisionEvent(thread_pool_, models_); vulkan_graphics->EndFrame(); } @@ -176,11 +171,10 @@ void Engine::NetworkUpload(std::shared_ptr sock) { data.insert(data.end(), header_serialized.begin(), header_serialized.end()); data.insert(data.end(), model.begin(), model.end()); - if (it.second->updateRedundantCount >= 2) { + if (it.second->updateRedundantCount <= 1) { it.second->needsUpdate = false; - it.second->updateRedundantCount = 0; } else { - it.second->updateRedundantCount++; + it.second->updateRedundantCount--; } spdlog::debug("{} uploaded", it.second->name); } @@ -188,7 +182,7 @@ void Engine::NetworkUpload(std::shared_ptr sock) { } float GetAlpha(double old_time, double new_time) { - return (glfwGetTime() - old_time) / (new_time - old_time); + return (glfwGetTime() - old_time) / (new_time - old_time) * 0.5; } void Interpolation(Packet::Header header, std::shared_ptr local, @@ -256,17 +250,8 @@ void Engine::ResponseToServerAndRefresh(std::shared_ptr sock) { auto spawnedModel = SpawnLifedModel(model->asset_name, model->name, model->lifespan); std::lock_guard lock(spawnedModel->modding); + spawnedModel->ID = model->ID; - spawnedModel->position = model->position; - spawnedModel->linear_velocity = model->linear_velocity; - spawnedModel->linear_acceleration = model->linear_acceleration; - - spawnedModel->rotation = model->rotation; - spawnedModel->angular_velocity = model->angular_velocity; - spawnedModel->angular_acceleration = model->angular_acceleration; - - spawnedModel->scale = model->scale; - spawnedModel->transform = model->transform; spawnedModel->original_offset = model->original_offset; spawnedModel->radius = model->radius; @@ -275,6 +260,8 @@ void Engine::ResponseToServerAndRefresh(std::shared_ptr sock) { spawnedModel->visible = model->visible; spawnedModel->colision = model->colision; spawnedModel->networkReplicated = false; + + Interpolation(header, spawnedModel, model); spdlog::info("model spawned: {}", model->ID.snowflake); } } break; diff --git a/impl/vulkan_engine/vulkan/physics.cpp b/impl/vulkan_engine/vulkan/physics.cpp index 39f8b9f..a9bfb69 100644 --- a/impl/vulkan_engine/vulkan/physics.cpp +++ b/impl/vulkan_engine/vulkan/physics.cpp @@ -5,37 +5,27 @@ namespace veng { void Physics::invokeOnColisionEvent( - gsl::not_null thread_pool, std::vector> models) { + gsl::not_null thread_pool, + std::unordered_map>& models) { constexpr std::float_t EPSILON = std::numeric_limits::epsilon(); - for (int first = 0; first < models.size(); first++) { - auto first_model = models[first]; - if (first_model != nullptr || !first_model->colision) continue; - for (int second = first + 1; second < models.size(); second++) { - auto second_model = models[second]; - if (second_model != nullptr || !second_model->colision) continue; + for (std::unordered_map>::iterator + iter_A = models.begin(); + iter_A != models.end(); iter_A++) { + auto model_A = iter_A->second; + if (!model_A->colision) continue; + for (auto iter_B = std::next(iter_A); iter_B != models.end(); iter_B++) { + auto model_B = iter_B->second; + if (!model_B->colision) continue; std::float_t distance = - glm::distance(first_model->position, second_model->position); - std::float_t model1_radius = first_model->radius * first_model->scale.x; - std::float_t model2_radius = second_model->radius * second_model->scale.x; - if (distance <= model1_radius + model2_radius) { - if (first_model->OnColision != nullptr) - thread_pool->enqueueJob( - [OnColision = first_model->OnColision]( - utils::ThreadPool* thread_pool, std::shared_ptr self, - std::shared_ptr other) { - OnColision(self, other); - }, - first_model, second_model); - if (second_model->OnColision != nullptr) - thread_pool->enqueueJob( - [OnColision = second_model->OnColision]( - utils::ThreadPool* thread_pool, std::shared_ptr self, - std::shared_ptr other) { - OnColision(self, other); - }, - first_model, second_model); - break; + glm::distance(model_A->position, model_B->position); + std::float_t modelA_radius = model_A->radius * model_A->scale.x; + std::float_t modelB_radius = model_B->radius * model_B->scale.x; + if (distance <= modelA_radius + modelB_radius) { + if (model_A->OnColision) + thread_pool->enqueueJob(model_A->OnColision, model_A, model_B); + if (model_B->OnColision) + thread_pool->enqueueJob(model_B->OnColision, model_A, model_B); } } } diff --git a/include/utils/thread_pool.h b/include/utils/thread_pool.h index 0766490..c92462e 100644 --- a/include/utils/thread_pool.h +++ b/include/utils/thread_pool.h @@ -51,8 +51,8 @@ class ThreadPool { } std::lock_guard lock(jobQueueMutex); - auto boundFunc = [this, __job, ... __args = std::move(__args)]() mutable { - __job(this, std::move(__args)...); + auto boundFunc = [this, __job, ... __args = __args]() mutable { + __job(this, __args...); }; auto task = std::packaged_task(std::move(boundFunc)); jobs_.push(std::move(task)); diff --git a/include/vulkan_engine/asset/object/model.h b/include/vulkan_engine/asset/object/model.h index 28dd209..149a254 100644 --- a/include/vulkan_engine/asset/object/model.h +++ b/include/vulkan_engine/asset/object/model.h @@ -8,6 +8,7 @@ #include "utils/snowflake.h" #include "vulkan_engine/vulkan/buffer_handle.h" #include "vulkan_engine/vulkan/vertex.h" +#include "utils/thread_pool.h" extern std::uint8_t CLIENTID; @@ -152,7 +153,8 @@ struct Model { std::float_t lifespan = -1.f; - std::function self, std::shared_ptr other)> + std::function self, + std::shared_ptr other)> OnColision = nullptr; bool visible = true; diff --git a/include/vulkan_engine/vulkan/physics.h b/include/vulkan_engine/vulkan/physics.h index d1a24ac..c68d8c5 100644 --- a/include/vulkan_engine/vulkan/physics.h +++ b/include/vulkan_engine/vulkan/physics.h @@ -1,14 +1,15 @@ #pragma once +#include "utils/thread_pool.h" #include "vulkan_engine/asset/object/model.h" #include "vulkan_engine/vulkan/vertex.h" -#include "utils/thread_pool.h" namespace veng { class Physics { public: - void invokeOnColisionEvent(gsl::not_null thread_pool, - std::vector> models); + void invokeOnColisionEvent( + gsl::not_null thread_pool, + std::unordered_map>& models); bool RayTrace(const glm::vec3& rayOrigin, const glm::vec3& rayDir, const glm::vec3& v0, const glm::vec3& v1, const glm::vec3& v2,