X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fstage.cpp;h=e1ce3522753683e38d3941db0c2d2df05ab803f7;hb=e2032cbdb8d2ae52e42d400c5cc90ddad844f665;hp=cbe576fa24ba566d2e33bcb2e04201c8c40be027;hpb=423a982cb00a9ec74fc154d729cbf88518adc6d8;p=libs%2Fdemoscene.git diff --git a/source/stage.cpp b/source/stage.cpp index cbe576f..e1ce352 100644 --- a/source/stage.cpp +++ b/source/stage.cpp @@ -14,6 +14,24 @@ Stage::~Stage() delete pipeline; } +void Stage::add_things(Demo::ThingMap &things, const string &prefix) +{ + things[prefix+"camera"] = static_cast(&camera); +} + +void Stage::add_postprocessor(GL::PostProcessor &pp) +{ + pipeline->add_postprocessor(pp); +} + +void Stage::set_camera(const GL::Camera &c) +{ + camera.set_object_matrix(c.get_object_matrix()); + camera.set_up_direction(c.get_up_direction()); + camera.set_field_of_view(c.get_field_of_view()); + camera.set_depth_clip(c.get_near_clip(), c.get_far_clip()); +} + Stage::UseInView::UseInView(): view(0), @@ -35,16 +53,45 @@ void Stage::UseInView::validate() const void Stage::UseInView::start(float, float) { - view->set_camera(&stage->camera_control.get_camera()); + view->set_camera(&stage->camera); view->set_content(stage->pipeline); } +Stage::SetCamera::SetCamera(): + stage(0), + camera(0) +{ } + +Stage::SetCamera::SetCamera(Stage &s, const GL::Camera &c): + stage(&s), + camera(&c) +{ } + +void Stage::SetCamera::validate() const +{ + if(!stage) + throw logic_error("null stage"); + if(!camera) + throw logic_error("null camera"); +} + +void Stage::SetCamera::start(float, float) +{ + stage->set_camera(*camera); +} + + Stage::UseInView::Loader::Loader(UseInView &u, Demo &d): DataFile::DerivedObjectLoader(u, d) { - add("view", &Loader::view); add("stage", &Loader::stage); + add("view", &Loader::view); +} + +void Stage::UseInView::Loader::stage(const string &n) +{ + obj.stage = &demo.get_thing(n); } void Stage::UseInView::Loader::view(const string &n) @@ -52,7 +99,20 @@ void Stage::UseInView::Loader::view(const string &n) obj.view = &demo.get_thing(n); } -void Stage::UseInView::Loader::stage(const string &n) + +Stage::SetCamera::Loader::Loader(SetCamera &s, Demo &d): + DataFile::DerivedObjectLoader(s, d) +{ + add("camera", &Loader::camera); + add("stage", &Loader::stage); +} + +void Stage::SetCamera::Loader::stage(const string &n) { obj.stage = &demo.get_thing(n); } + +void Stage::SetCamera::Loader::camera(const string &n) +{ + obj.camera = &demo.get_resources().get(n); +}