X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fbuilders%2Fsequencebuilder.cpp;h=5a68d4142a90bd777f058a9a3c3e4160c9367cf0;hp=6cf34c0ee1b38307654699c43969e78b082cb59f;hb=a3cc9f4469153396c7ad0868f3cbb2d2f698d710;hpb=1863f17c5c5563be8492d7f01e5c613a740ea1e9 diff --git a/source/builders/sequencebuilder.cpp b/source/builders/sequencebuilder.cpp index 6cf34c0e..5a68d414 100644 --- a/source/builders/sequencebuilder.cpp +++ b/source/builders/sequencebuilder.cpp @@ -1,8 +1,8 @@ #include #include #include +#include "deviceinfo.h" #include "error.h" -#include "renderbuffer.h" #include "sequence.h" #include "sequencebuilder.h" #include "sequencetemplate.h" @@ -50,14 +50,6 @@ void SequenceBuilder::build(Sequence &sequence) const sequence.set_debug_name(debug_name); #endif - sequence.set_hdr(tmpl.get_hdr()); - sequence.set_alpha(tmpl.get_alpha()); - unsigned samples = min(tmpl.get_maximum_multisample(), Renderbuffer::get_max_samples()); - if(samples &steps = tmpl.get_steps(); for(vector::const_iterator i=steps.begin(); i!=steps.end(); ++i) { @@ -66,8 +58,9 @@ void SequenceBuilder::build(Sequence &sequence) const continue; Sequence::Step &step = sequence.add_step(i->tag, *renderable); - step.set_blend(i->blend.get()); - step.set_depth_test(i->depth_test.get()); + step.set_blend(i->blend); + step.set_depth_test(i->depth_test); + step.set_stencil_test(i->stencil_test); step.set_lighting(i->lighting); } @@ -96,24 +89,37 @@ void SequenceBuilder::build(Sequence &sequence) const Sequence *SequenceBuilder::build(unsigned w, unsigned h) const { - RefPtr sequence = new Sequence(w, h); + RefPtr sequence = new Sequence(w, h, create_frame_format()); build(*sequence); return sequence.release(); } Sequence *SequenceBuilder::build(const View &view) const { - RefPtr sequence = new Sequence(view); + RefPtr sequence = new Sequence(view, create_frame_format()); build(*sequence); return sequence.release(); } Sequence *SequenceBuilder::build(const Framebuffer &fbo) const { - RefPtr sequence = new Sequence(fbo); + RefPtr sequence = new Sequence(fbo, 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); + if(samples