90 lines
2.3 KiB
C++
Raw Normal View History

2013-08-30 22:23:05 +09:00
//
// Tracer.cpp
// OpenSpades
//
// Created by Tomoaki Kawada on 8/30/13.
// Copyright (c) 2013 yvt.jp. All rights reserved.
//
#include "Tracer.h"
#include "Client.h"
#include "IRenderer.h"
#include <Draw/SWRenderer.h>
2013-08-30 22:23:05 +09:00
namespace spades {
namespace client {
Tracer::Tracer(Client *cli, Vector3 p1, Vector3 p2, float bulletVel)
: client(cli), startPos(p1), velocity(bulletVel) {
2013-08-30 22:23:05 +09:00
dir = (p2 - p1).Normalize();
length = (p2 - p1).GetLength();
2017-01-09 03:45:37 +09:00
velocity *= 0.5f; // make it slower for visual effect
2017-01-09 03:45:37 +09:00
const float maxTimeSpread = 1.0f / 30.f;
const float shutterTime = 1.0f / 30.f;
visibleLength = shutterTime * velocity;
2013-08-30 22:23:05 +09:00
curDistance = -visibleLength;
curDistance += maxTimeSpread * SampleRandomFloat();
2013-08-30 22:23:05 +09:00
firstUpdate = true;
image = cli->GetRenderer().RegisterImage("Gfx/Ball.png");
2013-08-30 22:23:05 +09:00
}
2013-08-30 22:23:05 +09:00
bool Tracer::Update(float dt) {
if (!firstUpdate) {
2013-08-30 22:23:05 +09:00
curDistance += dt * velocity;
if (curDistance > length) {
2013-08-30 22:23:05 +09:00
return false;
}
}
firstUpdate = false;
return true;
}
2013-08-30 22:23:05 +09:00
void Tracer::Render3D() {
IRenderer &r = client->GetRenderer();
if (dynamic_cast<draw::SWRenderer *>(&r)) {
// SWRenderer doesn't support long sprites (yet)
2017-01-09 03:45:37 +09:00
float startDist = curDistance;
float endDist = curDistance + visibleLength;
startDist = std::max(startDist, 0.f);
endDist = std::min(endDist, length);
if (startDist >= endDist) {
return;
2017-01-09 03:45:37 +09:00
}
Vector3 pos1 = startPos + dir * startDist;
Vector3 pos2 = startPos + dir * endDist;
Vector4 col = {1.f, .6f, .2f, 0.f};
r.AddDebugLine(pos1, pos2, Vector4{1.0f, 0.6f, 0.2f, 1.0f});
} else {
for (float step = 0.0f; step <= 1.0f; step += 0.1f) {
float startDist = curDistance;
float endDist = curDistance + visibleLength;
float midDist = (startDist + endDist) * 0.5f;
startDist = Mix(startDist, midDist, step);
endDist = Mix(endDist, midDist, step);
startDist = std::max(startDist, 0.f);
endDist = std::min(endDist, length);
if (startDist >= endDist) {
continue;
}
Vector3 pos1 = startPos + dir * startDist;
Vector3 pos2 = startPos + dir * endDist;
Vector4 col = {1.f, .6f, .2f, 0.f};
r.SetColorAlphaPremultiplied(col * 0.4f);
r.AddLongSprite(*image, pos1, pos2, .05f);
}
2017-01-09 03:45:37 +09:00
}
2013-08-30 22:23:05 +09:00
}
Tracer::~Tracer() {}
2013-08-30 22:23:05 +09:00
}
}