cloth
annotate src/simworld.h @ 0:92983e143a03
initial commit
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Mon, 11 Feb 2013 19:40:36 +0200 |
parents | |
children | 76d4b3e8e941 |
rev | line source |
---|---|
nuclear@0 | 1 #ifndef SIMWORLD_H_ |
nuclear@0 | 2 #define SIMWORLD_H_ |
nuclear@0 | 3 |
nuclear@0 | 4 #include <vector> |
nuclear@0 | 5 #include "particle.h" |
nuclear@0 | 6 #include "vmath/vmath.h" |
nuclear@0 | 7 |
nuclear@0 | 8 struct Collision { |
nuclear@0 | 9 Vector3 pos; |
nuclear@0 | 10 Vector3 normal; |
nuclear@0 | 11 float elast; |
nuclear@0 | 12 }; |
nuclear@0 | 13 |
nuclear@0 | 14 class SimWorld { |
nuclear@0 | 15 private: |
nuclear@0 | 16 std::vector<Object*> objects; |
nuclear@0 | 17 std::vector<Particle*> part; |
nuclear@0 | 18 Vector3 grav; |
nuclear@0 | 19 float damping; |
nuclear@0 | 20 |
nuclear@0 | 21 public: |
nuclear@0 | 22 SimWorld(); |
nuclear@0 | 23 |
nuclear@0 | 24 void set_bounds(float xmin, float xmax, float ymin, float ymax); |
nuclear@0 | 25 |
nuclear@0 | 26 void set_gravity(const Vector3 &f); |
nuclear@0 | 27 |
nuclear@0 | 28 void add_particle(Particle *p); |
nuclear@0 | 29 |
nuclear@0 | 30 bool collision(const Ray &ray, float rad, Collision *col) const; |
nuclear@0 | 31 |
nuclear@0 | 32 void step(float dt); |
nuclear@0 | 33 |
nuclear@0 | 34 void draw_particles() const; |
nuclear@0 | 35 |
nuclear@0 | 36 friend class Particle; |
nuclear@0 | 37 }; |
nuclear@0 | 38 |
nuclear@0 | 39 #endif // SIMWORLD_H_ |