1
0

89 lines
2.1 KiB
C
Raw Normal View History

#include "particlesystem.h"
#include "initOpenGL.h"
2020-03-18 12:29:08 +01:00
#include "utils.h"
2020-03-20 16:33:43 +01:00
#define PARTICLE_AMOUNT 10000
void calcPos(particle *p, float dt);
void calcCol(particle *p);
int main()
{
/************* INIT *************/
// Init OpenGL and GLFW
initGLFW();
setErrorCallbackGL();
int width = WIDTH, height = HEIGHT;
GLFWwindow *window = createGLFWWindow(WIDTH, HEIGHT, "Informatikprojekt - OpenGL CPU");
setCurrentContextGL(window);
setFramebufferSizeCallbackGL(window);
// glad
initGlad();
/************* PARTICLE SYSTEM *************/
vector3f *epos1 = initVector3f(0, 0, 0);
emitter *e1 = initEmitter(epos1, PARTICLE_AMOUNT);
particle_system *ps = initParticleSystem(1);
(ps->emitters)[0] = e1;
initRandomParticles(e1);
/************* RENDER LOOP *************/
double time, tFrame, tLast = 0;
while (!glfwWindowShouldClose(window))
{
time = glfwGetTime();
tFrame = time - tLast;
tLast = time;
/*** UPDATE ***/
updateParticles((float) tFrame, ps, calcPos, calcCol);
/*** RENDER ***/
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT);
glfwGetFramebufferSize(window, &width, &height);
emitter *e;
particle *p;
vector3f *pos;
2020-04-01 22:17:35 +02:00
for (int y = 0; y < ps->eamount; y++)
{
2020-04-01 22:17:35 +02:00
e = (ps->emitters)[y];
for (int x = 0; x < e->pamount; x++)
{
2020-04-01 22:17:35 +02:00
p = (e->particles)[x];
pos = p->position;
glColor3f(p->color->x, p->color->y, p->color->z);
glBegin(GL_POINTS);
glVertex3f(pos->x, pos->y, pos->z);
glEnd();
}
}
glfwSwapBuffers(window);
glfwPollEvents();
}
//END
terminateGLFW(window);
freeParticleSystem(ps);
return 0;
}
void calcPos(particle *p, float dt)
{
p->position->x += p->velocity->x * dt;
p->position->y += p->velocity->y * dt;
p->position->z += p->velocity->z * dt;
}
void calcCol(particle *p)
{
p->color->x -= 0.00001f;
p->color->y -= 0.00001f;
p->color->z -= 0.00001f;
2020-04-01 22:17:35 +02:00
}