-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.cpp
74 lines (55 loc) · 1.75 KB
/
main.cpp
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
#include <SFML/Graphics.hpp>
#include"GravitySource.h"
#include"Particle.h"
#include <iostream>
#include <random>
#include <vector>
int whitetored(int n) {
int r, g, b;
r = 255;
g = 255 - n;
b = g;
return r, g, b;
};
int main()
{
sf::RenderWindow window(sf::VideoMode(1600, 1000), "SFML-Gravity");
window.setFramerateLimit(60);
GravitySource source(400, 500, 6000);
GravitySource source2(1200, 500, 6000);
Particle particle(600, 700, 4, 1);
Particle particle2(600, 500, 4, 2);
while (window.isOpen())
{
sf::Event event;
while (window.pollEvent(event))
{
if (event.type == sf::Event::Closed) window.close();
if (sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) window.close();
}
window.clear();
/*
int n = 0; // number of particles
Particle* particle[4];
for (int i = 0; i < sizeof(particle) / sizeof(*particle); i++) {
particle[i] = new Particle(600 + i, 700 - 2*i, 4, 0);
std::cout << particle[i] << std::endl;
//Particle obj = particle[i];
//obj.update_physics(source);
}
for (int i = 0; i < sizeof(particle) / sizeof(*particle); i++)
delete particle[i];
*/
particle.update_physics(source);
particle.update_physics(source2);
particle2.update_physics(source);
particle2.update_physics(source2);
source.render(window);
source2.render(window);
particle.render(window);
particle2.render(window);
// draw calls
window.display();
}
return 0;
}