shadow: Only use correctly sized textures for shortcut
When creating a shadow for a ClutterTexture, we currently use the underlying CoglTexture directly instead of rendering the actor to an offscreen buffer. This assumes that the CoglTexture is directly suitable as shadow source, which isn't necessarily the case - it may have a very different size than what is shown and scaled up or down by the hardware. In that case we end up with a scaled shadow texture as well, which messes up the desired blur effect - the result will be too light when scaling up, or too sharp when scaling down. To fix this, only take the shortcut when a ClutterTexture's underlying texture has the correct size and fall back to offscreen rendering otherwise. https://bugzilla.gnome.org/show_bug.cgi?id=788039
This commit is contained in:
parent
703187e996
commit
7015bb2ca9
@ -414,24 +414,8 @@ _st_create_shadow_pipeline_from_actor (StShadow *shadow_spec,
|
||||
ClutterActor *actor)
|
||||
{
|
||||
CoglPipeline *shadow_pipeline = NULL;
|
||||
|
||||
if (CLUTTER_IS_TEXTURE (actor))
|
||||
{
|
||||
CoglTexture *texture;
|
||||
|
||||
texture = clutter_texture_get_cogl_texture (CLUTTER_TEXTURE (actor));
|
||||
if (texture)
|
||||
shadow_pipeline = _st_create_shadow_pipeline (shadow_spec, texture);
|
||||
}
|
||||
else
|
||||
{
|
||||
CoglTexture *buffer;
|
||||
CoglOffscreen *offscreen;
|
||||
CoglFramebuffer *fb;
|
||||
ClutterActorBox box;
|
||||
CoglColor clear_color;
|
||||
float width, height;
|
||||
CoglError *catch_error = NULL;
|
||||
|
||||
clutter_actor_get_allocation_box (actor, &box);
|
||||
clutter_actor_box_get_size (&box, &width, &height);
|
||||
@ -439,6 +423,25 @@ _st_create_shadow_pipeline_from_actor (StShadow *shadow_spec,
|
||||
if (width == 0 || height == 0)
|
||||
return NULL;
|
||||
|
||||
if (CLUTTER_IS_TEXTURE (actor))
|
||||
{
|
||||
CoglTexture *texture;
|
||||
|
||||
texture = clutter_texture_get_cogl_texture (CLUTTER_TEXTURE (actor));
|
||||
if (texture &&
|
||||
cogl_texture_get_width (texture) == width &&
|
||||
cogl_texture_get_height (texture) == height)
|
||||
shadow_pipeline = _st_create_shadow_pipeline (shadow_spec, texture);
|
||||
}
|
||||
|
||||
if (shadow_pipeline == NULL)
|
||||
{
|
||||
CoglTexture *buffer;
|
||||
CoglOffscreen *offscreen;
|
||||
CoglFramebuffer *fb;
|
||||
CoglColor clear_color;
|
||||
CoglError *catch_error = NULL;
|
||||
|
||||
buffer = cogl_texture_new_with_size (width,
|
||||
height,
|
||||
COGL_TEXTURE_NO_SLICING,
|
||||
|
Loading…
Reference in New Issue
Block a user