namespace GL {
TexEnv::TexEnv():
- mode(MODULATE)
+ mode(MODULATE),
+ color(0, 0, 0, 0)
{ }
+const TexEnv &TexEnv::default_object()
+{
+ static TexEnv obj;
+ return obj;
+}
+
+void TexEnv::update_parameter(int mask) const
+{
+ if(TexUnit::current().get_texenv()!=this)
+ {
+ TexUnit *unit = TexUnit::find_unit(this);
+ if(!unit)
+ return;
+
+ unit->bind();
+ }
+
+ if(mask&MODE)
+ glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, mode);
+ if(mask&COLOR)
+ glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, &color.r);
+}
+
void TexEnv::set_mode(TexEnvMode m)
{
mode = m;
- if(TexUnit::current().get_texenv()==this)
- glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, mode);
+ update_parameter(MODE);
}
void TexEnv::set_color(const Color &c)
{
color = c;
- if(TexUnit::current().get_texenv()==this)
- glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, &color.r);
+ update_parameter(COLOR);
}
void TexEnv::bind_to(unsigned i) const
if(unit.set_texenv(this))
{
unit.bind();
- glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, mode);
- glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, &color.r);
+ update_parameter(-1);
}
}
void TexEnv::unbind_from(unsigned i)
{
- TexUnit &unit = TexUnit::get_unit(i);
- if(unit.set_texenv(0))
- {
- unit.bind();
- Color black(0, 0, 0, 0);
- glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, MODULATE);
- glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, &black.r);
- }
+ default_object().bind_to(i);
}
} // namespace GL