X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fbuilders%2Fsequencebuilder.cpp;h=5af62127ca4ff02712390793e70ec2735a401e7c;hp=8fd4b956a3287efbc9dfc2cf19be92f1151e94b2;hb=f44366c8785eb7a88755cd71250a8b85289eeed2;hpb=e9a898f315b5d1396f196d785913a283c30940f2 diff --git a/source/builders/sequencebuilder.cpp b/source/builders/sequencebuilder.cpp index 8fd4b956..5af62127 100644 --- a/source/builders/sequencebuilder.cpp +++ b/source/builders/sequencebuilder.cpp @@ -6,6 +6,7 @@ #include "sequence.h" #include "sequencebuilder.h" #include "sequencetemplate.h" +#include "view.h" using namespace std; @@ -15,8 +16,8 @@ namespace GL { SequenceBuilder::SequenceBuilder(const SequenceTemplate &t): tmpl(t) { - for(const SequenceTemplate::Step &s: tmpl.get_steps()) - renderables[s.slot_name] = s.default_renderable; + for(const SequenceTemplate::Renderable &r: tmpl.get_renderables()) + renderables[r.slot_name] = r.renderable; for(const SequenceTemplate::PostProcessor &p: tmpl.get_postprocessors()) if(!p.slot_name.empty()) postprocessors[p.slot_name] = 0; @@ -48,14 +49,21 @@ void SequenceBuilder::build(Sequence &sequence) const sequence.set_debug_name(debug_name); #endif + sequence.set_clear_enabled(tmpl.is_clear_enabled()); + if(tmpl.is_clear_enabled()) + { + sequence.set_clear_colors(tmpl.get_clear_colors()); + sequence.set_clear_depth(tmpl.get_clear_depth()); + sequence.set_clear_stencil(tmpl.get_clear_stencil()); + } + for(const SequenceTemplate::Step &s: tmpl.get_steps()) { - Renderable *renderable = get_item(renderables, s.slot_name); + Renderable *renderable = get_item(renderables, s.renderable_name); if(!renderable) continue; Sequence::Step &step = sequence.add_step(s.tag, *renderable); - step.set_blend(s.blend); step.set_depth_test(s.depth_test); step.set_stencil_test(s.stencil_test); step.set_lighting(s.lighting); @@ -66,7 +74,7 @@ void SequenceBuilder::build(Sequence &sequence) const #endif for(const SequenceTemplate::PostProcessor &p: tmpl.get_postprocessors()) { - PostProcessor *proc = 0; + RefPtr proc = 0; if(!p.slot_name.empty()) proc = get_item(postprocessors, p.slot_name); if(proc) @@ -80,12 +88,20 @@ void SequenceBuilder::build(Sequence &sequence) const if(!debug_name.empty()) proc->set_debug_name(format("%s/%d.pproc", debug_name, index++)); #endif - sequence.add_postprocessor_owned(proc); + sequence.add_postprocessor(*proc.get()); + sequence.add_owned(proc.release()); } } } } +Sequence *SequenceBuilder::build() const +{ + RefPtr sequence = new Sequence(); + build(*sequence); + return sequence.release(); +} + Sequence *SequenceBuilder::build(unsigned w, unsigned h) const { RefPtr sequence = new Sequence(w, h, create_frame_format()); @@ -95,21 +111,21 @@ Sequence *SequenceBuilder::build(unsigned w, unsigned h) const Sequence *SequenceBuilder::build(const View &view) const { - RefPtr sequence = new Sequence(view, create_frame_format()); + RefPtr sequence = new Sequence(view.get_width(), view.get_height(), create_frame_format()); build(*sequence); return sequence.release(); } Sequence *SequenceBuilder::build(const Framebuffer &fbo) const { - RefPtr sequence = new Sequence(fbo, create_frame_format()); + RefPtr sequence = new Sequence(fbo.get_width(), fbo.get_height(), create_frame_format()); build(*sequence); return sequence.release(); } FrameFormat SequenceBuilder::create_frame_format() const { - unsigned samples = min(tmpl.get_maximum_multisample(), Limits::get_global().max_samples); + unsigned samples = min(tmpl.get_maximum_multisample(), DeviceInfo::get_global().limits.max_samples); if(samples