X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fmaterials%2Flighting.h;h=833e7d2ba1277e916f6dd3f6f8c917c30f9d428b;hb=a275d25eccad43716c5dcf91f8bc4af2a53c0445;hp=226dee1c05a740e27a23d53baec2e4416e4a558a;hpb=a8383f1163cd020e2ce2c030e93defd2f9909a1d;p=libs%2Fgl.git diff --git a/source/materials/lighting.h b/source/materials/lighting.h index 226dee1c..833e7d2b 100644 --- a/source/materials/lighting.h +++ b/source/materials/lighting.h @@ -19,13 +19,14 @@ sources. class Lighting { public: - class Loader: public DataFile::ObjectLoader + class Loader: public DataFile::CollectionObjectLoader { private: static ActionMap shared_actions; public: Loader(Lighting &); + Loader(Lighting &, Collection &); private: virtual void init_actions(); @@ -35,21 +36,31 @@ public: void fog_density(float); void fog_half_distance(float); void horizon_angle(float); - void light(); - void light_index(unsigned); + void light(const std::string &); + void light_inline(); + void light_inline_index(unsigned); void sky_color(float, float, float); void zenith_direction(float, float, float); }; private: + struct AttachedLight + { + const Light *light; + mutable unsigned generation; + + AttachedLight(const Light *l): light(l), generation(0) { } + }; + Color ambient; Color sky_color; Vector3 zenith_direction; Geometry::Angle horizon_angle; Color fog_color; float fog_density; - std::vector lights; + std::vector lights; std::vector owned_data; + mutable ProgramData shdata; public: Lighting(); @@ -95,11 +106,13 @@ public: is returned. */ DEPRECATED const Light *get_attached_light(unsigned) const; - const std::vector &get_attached_lights() const { return lights; } - /** Updates a ProgramData object with the uniforms for the Lighting, including all attached light sources. A view matrix must be passed in. */ - void update_shader_data(ProgramData &, const Matrix &) const; + DEPRECATED void update_shader_data(ProgramData &, const Matrix &) const; + + const ProgramData &get_shader_data() const; + + void set_debug_name(const std::string &); }; } // namespace GL