1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
/**
* @file physics.cpp
*
* Copyright (C) 2019 Belle-Isle, Andrew <drumsetmonkey@gmail.com>
*
* This program 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.
*
* This program 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.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "physics.hpp"
#include "components/Physics.hpp"
#include "components/Position.hpp"
#include "components/Velocity.hpp"
void PhysicsSystem::configure([[maybe_unused]]entityx::EntityManager& entities,
[[maybe_unused]]entityx::EventManager& events)
{
events.subscribe<WorldChangeEvent>(*this);
}
void PhysicsSystem::update([[maybe_unused]]entityx::EntityManager& entities,
[[maybe_unused]]entityx::EventManager& events,
[[maybe_unused]]entityx::TimeDelta dt)
{
entities.each<Position, Velocity>
([this, dt](entityx::Entity e, Position &pos, Velocity &vel){
bool has_phys = e.has_component<Physics>();
// If the entity has physics
if (has_phys) {
Physics *p = e.component<Physics>().get();
glm::vec3 start = pos.vec();
glm::vec3 goal = pos.vec();
goal.x += (vel.x * dt/1000.0);
goal.y += (vel.y * dt/1000.0);
glm::vec3 end = currentWorld->collide(start, goal, *p);
(void)end;
//std::cout << end.x << "," << end.y << std::endl;
pos.x = goal.x;
pos.y = goal.y;
pos.z = goal.z;
//float fallPosition = currentWorld->getHeight(pos.x, pos.y, 0.0);
// TODO only make this occur when the entity has a hitbox
//if (pos.y == fallPosition) {
// p->standing = true;
// return;
//}
//if (pos.y < fallPosition) {
// pos.y = fallPosition;
// vel.y = 0;
// p->standing = true;
//} else {
// p->standing = false;
//if (p->gravity)
// vel.y -= 32.2 * (dt/1000.0f);
//}
} else {
pos.x += (vel.x * dt/1000.0);
pos.y += (vel.y * dt/1000.0);
}
});
}
void PhysicsSystem::receive(const WorldChangeEvent& wce)
{
currentWorld = wce.newWorld;
}
|