forked from bobsayshilol/engine-sim
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathsimulation_object.cpp
More file actions
91 lines (74 loc) · 2.45 KB
/
simulation_object.cpp
File metadata and controls
91 lines (74 loc) · 2.45 KB
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
88
89
90
91
#include "../include/simulation_object.h"
#include "../include/piston.h"
#include "../include/cylinder_bank.h"
#include "../include/engine_sim_application.h"
SimulationObject::SimulationObject() {
m_app = nullptr;
}
SimulationObject::~SimulationObject() {
/* void */
}
void SimulationObject::initialize(EngineSimApplication *app) {
m_app = app;
}
void SimulationObject::generateGeometry() {
/* void */
}
void SimulationObject::render(const ViewParameters *settings) {
/* void */
}
void SimulationObject::process(float dt) {
/* void */
}
void SimulationObject::destroy() {
/* void */
}
Piston *SimulationObject::getForemostPiston(CylinderBank *bank, int layer) {
Engine *engine = m_app->getSimulator()->getEngine();
Piston *frontmostPiston = nullptr;
const int cylinderCount = engine->getCylinderCount();
for (int i = 0; i < cylinderCount; ++i) {
Piston *piston = engine->getPiston(i);
if (piston->getCylinderBank() == bank) {
if (piston->getRod()->getJournal() >= layer) {
if (frontmostPiston == nullptr
|| piston->getRod()->getJournal() < frontmostPiston->getRod()->getJournal()) {
frontmostPiston = piston;
}
}
}
}
return frontmostPiston;
}
void SimulationObject::resetShader() {
m_app->getShaders()->ResetBaseColor();
m_app->getShaders()->SetObjectTransform(ysMath::LoadIdentity());
}
void SimulationObject::setTransform(
atg_scs::RigidBody *rigidBody,
float scale,
float lx,
float ly,
float angle)
{
double p_x, p_y;
rigidBody->localToWorld(lx, ly, &p_x, &p_y);
const ysMatrix rot = ysMath::RotationTransform(
ysMath::Constants::ZAxis,
(float)rigidBody->theta + angle);
const ysMatrix trans = ysMath::TranslationTransform(
ysMath::LoadVector((float)p_x, (float)p_y, 0.0f));
const ysMatrix scaleTransform = ysMath::ScaleTransform(ysMath::LoadScalar(scale));
m_app->getShaders()->SetObjectTransform(
ysMath::MatMult(ysMath::MatMult(trans, rot), scaleTransform));
}
ysVector SimulationObject::tintByLayer(const ysVector &col, int layers) const {
ysVector result = col;
for (int i = 0; i < layers; ++i) {
result = ysMath::Add(
ysMath::Mul(result, ysMath::LoadScalar(0.3f)),
ysMath::Mul(m_app->getBackgroundColor(), ysMath::LoadScalar(0.7f))
);
}
return result;
}