openspades/Sources/Client/HurtRingView.cpp

117 lines
3.0 KiB
C++
Raw Normal View History

2013-08-29 11:45:22 +09:00
/*
Copyright (c) 2013 yvt
2013-08-29 11:45:22 +09:00
This file is part of OpenSpades.
2013-08-29 11:45:22 +09:00
OpenSpades is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
2013-08-29 11:45:22 +09:00
OpenSpades is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
2013-08-29 11:45:22 +09:00
You should have received a copy of the GNU General Public License
along with OpenSpades. If not, see <http://www.gnu.org/licenses/>.
2013-08-29 11:45:22 +09:00
*/
2013-08-18 16:18:06 +09:00
#include "HurtRingView.h"
#include "Client.h"
#include "IImage.h"
#include "IRenderer.h"
2013-08-18 16:18:06 +09:00
#include "Player.h"
#include "World.h"
2013-08-18 16:18:06 +09:00
#include <Core/Debug.h>
2013-08-18 16:18:06 +09:00
namespace spades {
namespace client {
HurtRingView::HurtRingView(Client *cli) : client(cli), renderer(cli->GetRenderer()) {
2013-08-18 16:18:06 +09:00
SPADES_MARK_FUNCTION();
image = renderer.RegisterImage("Gfx/HurtRing2.png");
2013-08-18 16:18:06 +09:00
}
HurtRingView::~HurtRingView() {}
void HurtRingView::ClearAll() { items.clear(); }
void HurtRingView::Add(spades::Vector3 dir) {
2013-08-18 16:18:06 +09:00
SPADES_MARK_FUNCTION();
2013-08-18 16:18:06 +09:00
Item item;
item.dir = dir;
item.fade = 3;
items.push_back(item);
}
2013-08-18 16:18:06 +09:00
void HurtRingView::Update(float dt) {
SPADES_MARK_FUNCTION();
2013-08-18 16:18:06 +09:00
std::list<Item>::iterator it;
std::vector<std::list<Item>::iterator> its;
for (it = items.begin(); it != items.end(); it++) {
Item &ent = *it;
2013-08-18 16:18:06 +09:00
ent.fade -= dt;
if (ent.fade < 0) {
2013-08-18 16:18:06 +09:00
its.push_back(it);
}
}
for (size_t i = 0; i < its.size(); i++)
2013-08-18 16:18:06 +09:00
items.erase(its[i]);
}
void HurtRingView::Draw() {
2013-08-18 16:18:06 +09:00
SPADES_MARK_FUNCTION();
2013-08-18 16:18:06 +09:00
Vector3 playerFront;
World *w = client->GetWorld();
if (!w) {
2013-08-18 16:18:06 +09:00
ClearAll();
return;
}
auto p = w->GetLocalPlayer();
if (!p || !p->IsAlive()) {
2013-08-18 16:18:06 +09:00
ClearAll();
return;
}
2013-08-18 16:18:06 +09:00
playerFront = p->GetFront2D();
float hurtRingSize = renderer.ScreenHeight() * .3f;
float cx = renderer.ScreenWidth() * .5f;
float cy = renderer.ScreenHeight() * .5f;
static const float coords[][2] = {{-1, 1}, {1, 1}, {-1, 0}};
2013-08-18 16:18:06 +09:00
std::list<Item>::iterator it;
for (it = items.begin(); it != items.end(); it++) {
Item &item = *it;
2013-08-18 16:18:06 +09:00
float fade = item.fade * 2.f;
if (fade > 1.f)
fade = 1.f;
Vector4 color = {fade, fade, fade, 0};
renderer.SetColorAlphaPremultiplied(color);
2013-08-18 16:18:06 +09:00
Vector3 dir = -item.dir;
float c = dir.x * playerFront.x + dir.y * playerFront.y;
float s = dir.y * playerFront.x - dir.x * playerFront.y;
2013-08-18 16:18:06 +09:00
Vector2 verts[3];
for (int i = 0; i < 3; i++) {
2013-08-18 16:18:06 +09:00
verts[i] = MakeVector2(coords[i][0] * c - coords[i][1] * s,
coords[i][0] * s + coords[i][1] * c);
2013-08-18 16:18:06 +09:00
verts[i] = verts[i] * hurtRingSize + MakeVector2(cx, cy);
}
renderer.DrawImage(image, verts[0], verts[1], verts[2],
AABB2(0, 0, image->GetWidth(), image->GetHeight()));
2013-08-18 16:18:06 +09:00
}
}
2019-07-17 00:31:22 +09:00
} // namespace client
} // namespace spades