shaped-texture: Use non-deprecated cogl APIs
https://bugzilla.gnome.org/show_bug.cgi?id=706930
This commit is contained in:
parent
57258dc1d4
commit
c251ab5092
@ -150,11 +150,12 @@ meta_shaped_texture_paint (ClutterActor *actor)
|
|||||||
{
|
{
|
||||||
MetaShapedTexture *stex = (MetaShapedTexture *) actor;
|
MetaShapedTexture *stex = (MetaShapedTexture *) actor;
|
||||||
MetaShapedTexturePrivate *priv = stex->priv;
|
MetaShapedTexturePrivate *priv = stex->priv;
|
||||||
CoglTexture *paint_tex;
|
|
||||||
guint tex_width, tex_height;
|
guint tex_width, tex_height;
|
||||||
ClutterActorBox alloc;
|
|
||||||
CoglContext *ctx;
|
CoglContext *ctx;
|
||||||
CoglPipeline *pipeline;
|
CoglFramebuffer *fb;
|
||||||
|
CoglPipeline *pipeline = NULL;
|
||||||
|
CoglTexture *paint_tex;
|
||||||
|
ClutterActorBox alloc;
|
||||||
|
|
||||||
if (priv->clip_region && cairo_region_is_empty (priv->clip_region))
|
if (priv->clip_region && cairo_region_is_empty (priv->clip_region))
|
||||||
return;
|
return;
|
||||||
@ -192,6 +193,7 @@ meta_shaped_texture_paint (ClutterActor *actor)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
||||||
|
fb = cogl_get_draw_framebuffer ();
|
||||||
|
|
||||||
if (priv->mask_texture == NULL)
|
if (priv->mask_texture == NULL)
|
||||||
{
|
{
|
||||||
@ -208,12 +210,10 @@ meta_shaped_texture_paint (ClutterActor *actor)
|
|||||||
{
|
{
|
||||||
CoglColor color;
|
CoglColor color;
|
||||||
guchar opacity = clutter_actor_get_paint_opacity (actor);
|
guchar opacity = clutter_actor_get_paint_opacity (actor);
|
||||||
cogl_color_set_from_4ub (&color, opacity, opacity, opacity, opacity);
|
cogl_color_init_from_4ub (&color, opacity, opacity, opacity, opacity);
|
||||||
cogl_pipeline_set_color (pipeline, &color);
|
cogl_pipeline_set_color (pipeline, &color);
|
||||||
}
|
}
|
||||||
|
|
||||||
cogl_set_source (pipeline);
|
|
||||||
|
|
||||||
clutter_actor_get_allocation_box (actor, &alloc);
|
clutter_actor_get_allocation_box (actor, &alloc);
|
||||||
|
|
||||||
if (priv->clip_region)
|
if (priv->clip_region)
|
||||||
@ -256,20 +256,23 @@ meta_shaped_texture_paint (ClutterActor *actor)
|
|||||||
coords[6] = coords[2];
|
coords[6] = coords[2];
|
||||||
coords[7] = coords[3];
|
coords[7] = coords[3];
|
||||||
|
|
||||||
cogl_rectangle_with_multitexture_coords (x1, y1, x2, y2,
|
cogl_framebuffer_draw_multitextured_rectangle (fb, pipeline,
|
||||||
&coords[0], 8);
|
x1, y1, x2, y2,
|
||||||
|
&coords[0], 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cogl_rectangle (0, 0,
|
cogl_framebuffer_draw_rectangle (fb, pipeline,
|
||||||
alloc.x2 - alloc.x1,
|
0, 0,
|
||||||
alloc.y2 - alloc.y1);
|
alloc.x2 - alloc.x1,
|
||||||
|
alloc.y2 - alloc.y1);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
cogl_object_unref (pipeline);
|
if (pipeline != NULL)
|
||||||
|
cogl_object_unref (pipeline);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -281,13 +284,16 @@ meta_shaped_texture_pick (ClutterActor *actor,
|
|||||||
|
|
||||||
/* If there is no region then use the regular pick */
|
/* If there is no region then use the regular pick */
|
||||||
if (priv->mask_texture == NULL)
|
if (priv->mask_texture == NULL)
|
||||||
CLUTTER_ACTOR_CLASS (meta_shaped_texture_parent_class)
|
CLUTTER_ACTOR_CLASS (meta_shaped_texture_parent_class)->pick (actor, color);
|
||||||
->pick (actor, color);
|
|
||||||
else if (clutter_actor_should_pick_paint (actor))
|
else if (clutter_actor_should_pick_paint (actor))
|
||||||
{
|
{
|
||||||
CoglTexture *paint_tex;
|
CoglTexture *paint_tex;
|
||||||
ClutterActorBox alloc;
|
ClutterActorBox alloc;
|
||||||
guint tex_width, tex_height;
|
guint tex_width, tex_height;
|
||||||
|
CoglPipeline *pipeline;
|
||||||
|
CoglContext *ctx;
|
||||||
|
CoglFramebuffer *fb;
|
||||||
|
CoglColor cogl_color;
|
||||||
|
|
||||||
paint_tex = COGL_TEXTURE (priv->texture);
|
paint_tex = COGL_TEXTURE (priv->texture);
|
||||||
|
|
||||||
@ -300,17 +306,22 @@ meta_shaped_texture_pick (ClutterActor *actor,
|
|||||||
if (tex_width == 0 || tex_height == 0) /* no contents yet */
|
if (tex_width == 0 || tex_height == 0) /* no contents yet */
|
||||||
return;
|
return;
|
||||||
|
|
||||||
cogl_set_source_color4ub (color->red, color->green, color->blue,
|
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
||||||
color->alpha);
|
fb = cogl_get_draw_framebuffer ();
|
||||||
|
|
||||||
|
cogl_color_init_from_4ub (&cogl_color, color->red, color->green, color->blue, color->alpha);
|
||||||
|
|
||||||
|
pipeline = cogl_pipeline_new (ctx);
|
||||||
|
cogl_pipeline_set_layer_texture (pipeline, 0, priv->mask_texture);
|
||||||
|
cogl_pipeline_set_color (pipeline, &cogl_color);
|
||||||
|
|
||||||
clutter_actor_get_allocation_box (actor, &alloc);
|
clutter_actor_get_allocation_box (actor, &alloc);
|
||||||
|
|
||||||
/* Paint the mask rectangle in the given color */
|
cogl_framebuffer_draw_rectangle (fb, pipeline,
|
||||||
cogl_set_source_texture (priv->mask_texture);
|
0, 0,
|
||||||
cogl_rectangle_with_texture_coords (0, 0,
|
alloc.x2 - alloc.x1,
|
||||||
alloc.x2 - alloc.x1,
|
alloc.y2 - alloc.y1);
|
||||||
alloc.y2 - alloc.y1,
|
cogl_object_unref (pipeline);
|
||||||
0, 0, 1, 1);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user