]> git.tdb.fi Git - libs/gl.git/blobdiff - source/renderpass.h
Immediate update camera aspect in View::set_camera
[libs/gl.git] / source / renderpass.h
index 5af733dc8b6ed2961510779621502377a2d8f284..eec60793ea3ca23b9052ae27dd75cdcfbfd97c52 100644 (file)
@@ -11,7 +11,7 @@ namespace GL {
 class Material;
 class Program;
 class ProgramData;
-class TexEnv;
+class Renderer;
 class Texture;
 class Texturing;
 
@@ -45,23 +45,22 @@ private:
        private:
                unsigned index;
                RefPtr<Texture> tex;
-               RefPtr<TexEnv> env;
 
        public:
                TextureLoader(Texturing &, unsigned, Collection *);
        private:
                virtual void finish();
 
-               void texenv();
                void texture(const std::string &);
                void texture2d();
        };
 
-       Program *shprog;
-       ProgramData *shdata;
+       const Program *shprog;
+       RefPtr<const ProgramData> shdata;
        RefPtr<const Material> material;
        Texturing *texturing;
        std::map<std::string, unsigned> tex_names;
+       bool back_faces;
 
        RenderPass &operator=(const RenderPass &);
 public:
@@ -69,13 +68,18 @@ public:
        RenderPass(const RenderPass &);
        ~RenderPass();
 
+       void set_shader_program(const Program *, const ProgramData *);
        const Program *get_shader_program() const { return shprog; }
-       const ProgramData *get_shader_data() const { return shdata; }
+       const ProgramData *get_shader_data() const { return shdata.get(); }
        void set_material(const Material *);
        const Material *get_material() const { return material.get(); }
        void set_texture(unsigned, const Texture *);
        const Texturing *get_texturing() const { return texturing; }
        int get_texture_index(const std::string &) const;
+       void set_back_faces(bool);
+       bool get_back_faces() const { return back_faces; }
+
+       void apply(Renderer &) const;
 };
 
 } // namespace GL