X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fmaterials%2Frenderpass.cpp;h=a055f4786bfed69a39c871087d31b47a123c6f1c;hp=63ba695bae7fee718834cf2251863e64c527c8db;hb=HEAD;hpb=ad3d915bcba61059a9e371dda780670da8dd249b diff --git a/source/materials/renderpass.cpp b/source/materials/renderpass.cpp deleted file mode 100644 index 63ba695b..00000000 --- a/source/materials/renderpass.cpp +++ /dev/null @@ -1,252 +0,0 @@ -#include -#include -#include -#include -#include "error.h" -#include "renderpass.h" -#include "program.h" -#include "programdata.h" -#include "renderer.h" -#include "texture.h" -#include "texture2d.h" -#include "uniform.h" - -using namespace std; - -namespace Msp { -namespace GL { - -RenderPass::RenderPass(): - shprog(0), - shprog_from_material(false), - shdata(0), - material(0), - face_cull(CULL_BACK), - receive_shadows(false), - image_based_lighting(false) -{ } - -void RenderPass::set_material_textures() -{ - const Tag *material_texture_tags = material->get_texture_tags(); - for(const Tag *tag=material_texture_tags; tag->id; ++tag) - set_texture(*tag, material->get_texture(*tag), material->get_sampler(*tag)); -} - -void RenderPass::maybe_create_material_shader() -{ - if(shprog && !shprog_from_material) - return; - - map extra_spec; - if(receive_shadows) - extra_spec["use_shadow_map"] = true; - if(image_based_lighting) - extra_spec["use_image_based_lighting"] = true; - - shprog = material->create_compatible_shader(extra_spec); - - if(shdata) - shdata = new ProgramData(*shdata, shprog); - - shprog_from_material = true; -} - -void RenderPass::set_shader_program(const Program *prog, const ProgramData *data) -{ - shprog = prog; - shprog_from_material = false; - shdata = (data ? new ProgramData(*data) : 0); -} - -Tag RenderPass::get_slotted_uniform_tag(Tag slot) const -{ - auto i = uniform_slots.find(slot); - if(i==uniform_slots.end()) - return Tag(); - return i->second; -} - -void RenderPass::set_material(const Material *mat) -{ - material = mat; - maybe_create_material_shader(); - set_material_textures(); -} - -void RenderPass::set_texture(Tag tag, const Texture *tex, const Sampler *samp) -{ - auto i = find_member(textures, tag, &TextureSlot::tag); - if(i==textures.end()) - { - textures.push_back(TextureSlot(tag)); - i = textures.end()-1; - } - i->texture = tex; - if(samp) - i->sampler = samp; -} - -Tag RenderPass::get_texture_tag(const string &slot) const -{ - auto i = find_member(textures, slot, &TextureSlot::slot_name); - return (i!=textures.end() ? i->tag : Tag()); -} - -void RenderPass::set_face_cull(CullMode fc) -{ - face_cull = fc; -} - -void RenderPass::set_receive_shadows(bool rs) -{ - receive_shadows = rs; -} - -void RenderPass::apply(Renderer &renderer) const -{ - for(const TextureSlot &t: textures) - renderer.set_texture(t.tag, t.texture, t.sampler); - renderer.set_shader_program(shprog, shdata.get()); - if(material) - renderer.add_shader_data(material->get_shader_data()); - renderer.set_face_cull(face_cull); -} - -void RenderPass::set_debug_name(const string &name) -{ -#ifdef DEBUG - if(shdata.refcount()==1) - shdata->set_debug_name(name+" [UBO]"); -#else - (void)name; -#endif -} - - -DataFile::Loader::ActionMap RenderPass::Loader::shared_actions; - -RenderPass::Loader::Loader(RenderPass &p): - DataFile::CollectionObjectLoader(p, 0) -{ - set_actions(shared_actions); -} - -RenderPass::Loader::Loader(RenderPass &p, Collection &c): - DataFile::CollectionObjectLoader(p, &c) -{ - set_actions(shared_actions); -} - -void RenderPass::Loader::init_actions() -{ - add("face_cull", &RenderPass::face_cull); - add("shader", &Loader::shader); - add("image_based_lighting", &RenderPass::image_based_lighting); - add("material", &Loader::material_inline); - add("material", &Loader::material); - add("material_slot", &RenderPass::material_slot); - add("receive_shadows", &RenderPass::receive_shadows); - add("texture", &Loader::texture); - add("uniforms", &Loader::uniforms); - add("uniform_slot", &Loader::uniform_slot); - add("uniform_slot", &Loader::uniform_slot2); -} - -void RenderPass::Loader::set_inline_base_name(const string &n) -{ - inline_base_name = n; -} - -void RenderPass::Loader::finish() -{ - if(obj.material) - obj.maybe_create_material_shader(); -} - -// Temporary compatibility feature -string RenderPass::Loader::get_shader_name(const string &n) -{ - if(n.size()>=5 && !n.compare(n.size()-5, 5, ".glsl")) - { - IO::print(IO::cerr, "Warning: Loading module '%s' as shader is deprecated\n", n); - return n+".shader"; - } - return n; -} - -void RenderPass::Loader::material_inline() -{ - Material::GenericLoader ldr(coll); - load_sub_with(ldr); - RefPtr mat = ldr.get_material(); - get_collection().add(inline_base_name+".mat", mat.get()); - obj.material = mat.release(); - obj.set_material_textures(); -} - -void RenderPass::Loader::material(const string &name) -{ - obj.material = &get_collection().get(name); - obj.set_material_textures(); -} - -void RenderPass::Loader::shader(const string &n) -{ - obj.shprog = &get_collection().get(get_shader_name(n)); - obj.shprog_from_material = false; - if(obj.shdata) - obj.shdata = new ProgramData(*obj.shdata, obj.shprog); -} - -void RenderPass::Loader::texture(const string &n) -{ - auto i = find_member(obj.textures, Tag(n), &TextureSlot::tag); - if(i==obj.textures.end()) - { - obj.textures.push_back(TextureSlot(n)); - i = obj.textures.end()-1; - } - TextureSlot::Loader ldr(*i, n, coll); - load_sub_with(ldr); -} - -void RenderPass::Loader::uniforms() -{ - if(!obj.shprog || obj.shprog_from_material) - throw runtime_error("Shader is required for uniforms"); - if(!obj.shdata) - obj.shdata = new ProgramData(obj.shprog); - else if(obj.shdata.refcount()>1) - obj.shdata = new ProgramData(*obj.shdata); - load_sub(*obj.shdata); -} - -void RenderPass::Loader::uniform_slot(const string &name) -{ - uniform_slot2(name, name); -} - -void RenderPass::Loader::uniform_slot2(const string &name, const string &slot) -{ - obj.uniform_slots[slot] = name; -} - - -RenderPass::TextureSlot::Loader::Loader(TextureSlot &ts, const string &an, Collection *c): - CollectionObjectLoader(ts, c), - auto_slot_name(an) -{ - add("sampler", &TextureSlot::sampler); - add("slot", &Loader::slot_auto); - add("slot", &TextureSlot::slot_name); - add("texture", &TextureSlot::texture); -} - -void RenderPass::TextureSlot::Loader::slot_auto() -{ - obj.slot_name = auto_slot_name; -} - -} // namespace GL -} // namespace Msp