From da664b8500517fd892af5b9df6634a082423dbdd Mon Sep 17 00:00:00 2001 From: yvt Date: Mon, 3 May 2021 00:57:02 +0900 Subject: [PATCH] feat(client): make tracers actually glow --- Sources/Client/Tracer.cpp | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/Sources/Client/Tracer.cpp b/Sources/Client/Tracer.cpp index 7bed2159d..01afb4790 100644 --- a/Sources/Client/Tracer.cpp +++ b/Sources/Client/Tracer.cpp @@ -9,8 +9,11 @@ #include "Tracer.h" #include "Client.h" #include "IRenderer.h" +#include #include +DEFINE_SPADES_SETTING(cg_tracerLights, "1"); + namespace spades { namespace client { Tracer::Tracer(Client &_client, Vector3 p1, Vector3 p2, float bulletVel) @@ -82,6 +85,31 @@ namespace spades { r.AddLongSprite(*image, pos1, pos2, .05f); } } + + // Add subtle dynamic light + if (cg_tracerLights) { + float startDist = curDistance; + float endDist = curDistance + visibleLength; + + startDist = std::max(startDist, 0.f); + endDist = std::min(endDist, length); + if (startDist >= endDist) { + return; + } + + Vector3 pos1 = startPos + dir * startDist; + Vector3 pos2 = startPos + dir * endDist; + + DynamicLightParam light; + light.origin = pos1; + light.point2 = pos2; + light.color = + MakeVector3(1.f, 0.5f, 0.2f) * 0.1f * ((endDist - startDist) / visibleLength); + light.radius = 10.f; + light.type = DynamicLightTypeLinear; + light.image = nullptr; + r.AddLight(light); + } } Tracer::~Tracer() {}