Fix T49180: Cycles MIS Map for Animated Environment Texture Movie Doesn't Update on Frame Change

Not really ideal fix at all, but we are at RC today, so better to play really safe.
This commit is contained in:
2016-09-02 09:58:41 +02:00
parent fce8f24628
commit b399a6d33f
3 changed files with 23 additions and 0 deletions

View File

@@ -177,6 +177,16 @@ LightManager::~LightManager()
{ {
} }
bool LightManager::has_background_light(Scene *scene)
{
foreach(Light *light, scene->lights) {
if(light->type == LIGHT_BACKGROUND) {
return true;
}
}
return false;
}
void LightManager::disable_ineffective_light(Device *device, Scene *scene) void LightManager::disable_ineffective_light(Device *device, Scene *scene)
{ {
/* Make all lights enabled by default, and perform some preliminary checks /* Make all lights enabled by default, and perform some preliminary checks

View File

@@ -91,6 +91,9 @@ public:
void tag_update(Scene *scene); void tag_update(Scene *scene);
/* Check whether there is a background light. */
bool has_background_light(Scene *scene);
protected: protected:
/* Optimization: disable light which is either unsupported or /* Optimization: disable light which is either unsupported or
* which doesn't contribute to the scene or which is only used for MIS * which doesn't contribute to the scene or which is only used for MIS

View File

@@ -221,6 +221,16 @@ void Shader::tag_update(Scene *scene)
if(use_mis && has_surface_emission) if(use_mis && has_surface_emission)
scene->light_manager->need_update = true; scene->light_manager->need_update = true;
/* Special handle of background MIS light for now: for some reason it
* has use_mis set to false. We are quite close to release now, so
* better to be safe.
*/
if(this == scene->default_background &&
scene->light_manager->has_background_light(scene))
{
scene->light_manager->need_update = true;
}
/* quick detection of which kind of shaders we have to avoid loading /* quick detection of which kind of shaders we have to avoid loading
* e.g. surface attributes when there is only a volume shader. this could * e.g. surface attributes when there is only a volume shader. this could
* be more fine grained but it's better than nothing */ * be more fine grained but it's better than nothing */