本文整理汇总了C++中Universe::addBody方法的典型用法代码示例。如果您正苦于以下问题:C++ Universe::addBody方法的具体用法?C++ Universe::addBody怎么用?C++ Universe::addBody使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Universe
的用法示例。
在下文中一共展示了Universe::addBody方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
int main() {
SDL_Init(SDL_INIT_VIDEO);
SDL_Surface *screen = SDL_SetVideoMode(1024, 768, 32, SDL_HWSURFACE);
SDL_Surface *trace = SDL_CreateRGBSurface(SDL_HWSURFACE, 1024, 768, 32, 0, 0, 0, 0);
SDL_WM_SetCaption("Solar system demo", NULL);
Uint32 white = SDL_MapRGB(screen->format, 255, 255, 255);
Uint32 black = SDL_MapRGB(screen->format, 0, 0, 0);
Uint32 red = SDL_MapRGB(screen->format, 255, 0, 0);
Uint32 green = SDL_MapRGB(screen->format, 0, 255, 0);
Uint32 blue = SDL_MapRGB(screen->format, 0, 0, 255);
// Universe U;
// Sun *sun = new Sun(1e+10);
// U.addBody(sun);
// U.addBody(new SpaceBody(0, sun, 0.7, 150));
// U.addBody(new SpaceBody(0, sun, 0.5, 150, 0, 0, M_PI/4));
Universe U;
double sunmass = 1e+10;
StaticIntegrator si;
U.addBody(new Body(sunmass, si));
KeplerIntegrator ki1(Orbit(sunmass, 0, 0.7, 150));
U.addBody(new Body(0, ki1));
// KeplerIntegrator ki2(Orbit(sunmass, 0, 0, 150, M_PI/2));
// U.addBody(new Body(0, ki2));
EulerIntegrator ei(Vector3D(150, 0, 0), Vector3D(0, -sqrt((sunmass * G)/150), 0));
Body *eulerbody = new Body(0, ei);
U.addBody(eulerbody);
LeapfrogIntegrator lfi(Vector3D(150, 0, 0), Vector3D(0, -sqrt((sunmass * G)/150), 0));
Body *leapfrogbody = new Body(0, lfi);
U.addBody(leapfrogbody);
SDL_Rect pos1, pos2;
pos2.x = pos2.y = 0;
Vector3D v;
SDL_Surface *rect = SDL_CreateRGBSurface(SDL_HWSURFACE, 10, 10, 32, 0, 0, 0, 0);
SDL_FillRect(rect, NULL, white);
SDL_Surface *littlerect = SDL_CreateRGBSurface(SDL_HWSURFACE, 1, 1, 32, 0, 0, 0, 0);
bool ok = true;
SDL_Event evt;
Uint32 color;
Uint32 startTime = SDL_GetTicks();
while (ok) {
SDL_PollEvent(&evt);
switch (evt.type) {
case SDL_QUIT:
ok = false;
break;
}
SDL_FillRect(screen, NULL, black);
SDL_BlitSurface(trace, NULL, screen, &pos2);
// for(int i=0;i<2000;i++)
U.evolve(200);
for (std::shared_ptr<Body> &it : U.getBodies()) {
color=it.get() == eulerbody ? green : (it.get() == leapfrogbody ? red : blue);
v = Vector3D(512, 384, 0) + it->getPosition();
if(it.get() == leapfrogbody)
v+=Vector3D(2,0,0);
pos1.x = v.getX();
pos1.y = v.getY();
SDL_FillRect(littlerect, NULL, color);
SDL_BlitSurface(littlerect, NULL, trace, &pos1);
pos1.x -= 5;
pos1.y -= 5;
SDL_FillRect(rect, NULL, color);
SDL_BlitSurface(rect, NULL, screen, &pos1);
}
SDL_Flip(screen);
}
SDL_Quit();
return EXIT_SUCCESS;
}