delete texturing;
}
+void RenderPass::finalize_material()
+{
+ ensure_private_shader_data();
+
+ if(!texturing)
+ texturing = new Texturing;
+ material->attach_textures_to(*texturing, *shdata);
+}
+
void RenderPass::ensure_private_shader_data()
{
if(!shprog)
{
material = mat;
material.keep();
+ finalize_material();
}
void RenderPass::set_texture(unsigned index, const Texture *tex)
void RenderPass::Loader::material_inline()
{
- RefPtr<Material> mat = new Material;
- if(coll)
- load_sub(*mat, get_collection());
- else
- load_sub(*mat);
- obj.material = mat;
+ Material::GenericLoader ldr(coll);
+ load_sub_with(ldr);
+ obj.material = ldr.get_material();
+ obj.finalize_material();
}
void RenderPass::Loader::material(const string &name)
{
obj.material = &get_collection().get<Material>(name);
obj.material.keep();
+ obj.finalize_material();
}
void RenderPass::Loader::texunit(unsigned i)