X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbuilders%2Fsequencetemplate.cpp;h=03c8c7fe1cafa0b26f3fc20e37080e94c8fafe0a;hb=fd75f65f5bfbf9593449b6d505875e6f83597e52;hp=e8e451fc9a54d78a5b6d1d1bfc415a64ffef90be;hpb=38712d8ecc57d043a2419ffbaeeb57f7a6586f14;p=libs%2Fgl.git diff --git a/source/builders/sequencetemplate.cpp b/source/builders/sequencetemplate.cpp index e8e451fc..03c8c7fe 100644 --- a/source/builders/sequencetemplate.cpp +++ b/source/builders/sequencetemplate.cpp @@ -22,16 +22,16 @@ SequenceTemplate::~SequenceTemplate() delete p.postprocessor_template; } - -SequenceTemplate::PostProcessorRegistry &SequenceTemplate::get_postprocessor_registry() +template<> +SequenceTemplate::TemplateRegistry &SequenceTemplate::get_registry() { - static PostProcessorRegistry registry; + static TemplateRegistry registry; static bool initialized = false; if(!initialized) { - registry.register_type("ambient_occlusion"); - registry.register_type("bloom"); - registry.register_type("colorcurve"); + registry.register_type("ambient_occlusion"); + registry.register_type("bloom"); + registry.register_type("colorcurve"); initialized = true; } return registry; @@ -43,14 +43,15 @@ SequenceTemplate::PostProcessor::PostProcessor(GL::PostProcessor::Template *ppt) { } -SequenceTemplate::PostProcLoader::PostProcLoader() +DataFile::Loader::ActionMap SequenceTemplate::Loader::shared_actions; + +SequenceTemplate::Loader::Loader(SequenceTemplate &t, Collection &c): + CollectionObjectLoader(t, &c) { - get_postprocessor_registry().invoke_all(*this); + set_actions(shared_actions); } - -SequenceTemplate::Loader::Loader(SequenceTemplate &t, Collection &c): - DataFile::CollectionObjectLoader(t, &c) +void SequenceTemplate::Loader::init_actions() { add("hdr", &SequenceTemplate::hdr); add("alpha", &SequenceTemplate::alpha); @@ -58,16 +59,10 @@ SequenceTemplate::Loader::Loader(SequenceTemplate &t, Collection &c): add("multisample", &Loader::multisample); add("multisample", &Loader::multisample_range); add("postprocessor", &Loader::postprocessor); + add("postprocessor", &Loader::postprocessor_with_slot); + add("renderable", &Loader::renderable); + add("renderable", &Loader::renderable_with_default); add("step", &Loader::step); - add("step", &Loader::step_with_slot); - - // Deprecated - add("pass", &Loader::step_with_slot); -} - -void SequenceTemplate::Loader::postprocessor_loaded() -{ - obj.postprocessors.push_back(get_postprocessor_template()); } void SequenceTemplate::Loader::clear() @@ -89,27 +84,42 @@ void SequenceTemplate::Loader::multisample_range(unsigned req, unsigned max) obj.max_multisample = max; } -void SequenceTemplate::Loader::postprocessor(const string &slot) +void SequenceTemplate::Loader::postprocessor() { - PostProcLoader ldr; + postprocessor_with_slot(string()); +} + +void SequenceTemplate::Loader::postprocessor_with_slot(const string &slot) +{ + TemplateLoader ldr(get_collection()); load_sub_with(ldr); PostProcessor pp; - pp.postprocessor_template = ldr.get_postprocessor_template(); + pp.postprocessor_template = ldr.get_object(); pp.slot_name = slot; obj.postprocessors.push_back(pp); } -void SequenceTemplate::Loader::step(const string &tag) +void SequenceTemplate::Loader::renderable(const string &slot) { - step_with_slot(tag, string()); + Renderable rend; + rend.slot_name = slot; + obj.renderables.push_back(rend); } -void SequenceTemplate::Loader::step_with_slot(const string &tag, const string &rend) +void SequenceTemplate::Loader::renderable_with_default(const string &slot, const string &name) +{ + Renderable rend; + rend.renderable = &get_collection().get(name); + rend.slot_name = slot; + obj.renderables.push_back(rend); +} + +void SequenceTemplate::Loader::step(const string &tag, const string &rend) { Step stp; stp.tag = tag; - stp.slot_name = rend; - Step::Loader ldr(stp, *coll); + stp.renderable_name = rend; + Step::Loader ldr(stp, get_collection()); ldr.set_inline_base_name(format("%s/%d.step", get_source(), obj.steps.size())); load_sub_with(ldr); @@ -117,8 +127,15 @@ void SequenceTemplate::Loader::step_with_slot(const string &tag, const string &r } +DataFile::Loader::ActionMap SequenceTemplate::ClearLoader::shared_actions; + SequenceTemplate::ClearLoader::ClearLoader(SequenceTemplate &t): ObjectLoader(t) +{ + set_actions(shared_actions); +} + +void SequenceTemplate::ClearLoader::init_actions() { add("color", &ClearLoader::color); add("depth", &ClearLoader::depth); @@ -141,17 +158,20 @@ void SequenceTemplate::ClearLoader::stencil(int s) } +DataFile::Loader::ActionMap SequenceTemplate::Step::Loader::shared_actions; + SequenceTemplate::Step::Loader::Loader(Step &p, Collection &c): DataFile::CollectionObjectLoader(p, &c) { - add("blend", &Loader::blend); - add("blend", &Loader::blend_factors); + set_actions(shared_actions); +} + +void SequenceTemplate::Step::Loader::init_actions() +{ add("depth_test", &Loader::depth_test); add("depth_test", &Loader::depth_compare); add("lighting", &Loader::lighting); add("lighting", &Loader::lighting_inline); - add("object", &Loader::object); - add("scene", &Loader::scene); add("stencil_test", &Loader::stencil_test); } @@ -160,16 +180,6 @@ void SequenceTemplate::Step::Loader::set_inline_base_name(const string &n) inline_base_name = n; } -void SequenceTemplate::Step::Loader::blend() -{ - load_sub(obj.blend); -} - -void SequenceTemplate::Step::Loader::blend_factors(BlendFactor src, BlendFactor dest) -{ - obj.blend = Blend(src, dest); -} - void SequenceTemplate::Step::Loader::depth_test() { load_sub(obj.depth_test); @@ -193,16 +203,6 @@ void SequenceTemplate::Step::Loader::lighting(const string &name) obj.lighting = &get_collection().get(name); } -void SequenceTemplate::Step::Loader::object(const string &name) -{ - obj.default_renderable = &get_collection().get(name); -} - -void SequenceTemplate::Step::Loader::scene(const string &name) -{ - obj.default_renderable = &get_collection().get(name); -} - void SequenceTemplate::Step::Loader::stencil_test() { load_sub(obj.stencil_test);