[gtk+/wip/baedert/gl: 93/95] gl renderer: Fix shadow nodes if the child is a container
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/baedert/gl: 93/95] gl renderer: Fix shadow nodes if the child is a container
- Date: Sun, 10 Dec 2017 21:30:47 +0000 (UTC)
commit 227e45e880bf6abdc4ea23ddfa45d4a6248e5f50
Author: Timm Bäder <mail baedert org>
Date: Sat Dec 9 18:26:29 2017 +0100
gl renderer: Fix shadow nodes if the child is a container
gsk/gl/gskglrenderer.c | 47 +++++++++++++++++++++------------------
gsk/gl/gskglrenderops.c | 9 +++++++
gsk/gl/gskglrenderopsprivate.h | 5 ++++
3 files changed, 39 insertions(+), 22 deletions(-)
---
diff --git a/gsk/gl/gskglrenderer.c b/gsk/gl/gskglrenderer.c
index 9f76a7e..f0f5508 100644
--- a/gsk/gl/gskglrenderer.c
+++ b/gsk/gl/gskglrenderer.c
@@ -328,17 +328,15 @@ render_text_node (GskGLRenderer *self,
GskRenderNode *node,
RenderOpBuilder *builder,
const GdkRGBA *color,
- gboolean force_color,
- float dx,
- float dy)
+ gboolean force_color)
{
const PangoFont *font = gsk_text_node_peek_font (node);
const PangoGlyphInfo *glyphs = gsk_text_node_peek_glyphs (node);
guint num_glyphs = gsk_text_node_get_num_glyphs (node);
int i;
int x_position = 0;
- int x = gsk_text_node_get_x (node) + dx;
- int y = gsk_text_node_get_y (node) + dy;
+ int x = gsk_text_node_get_x (node) + builder->dx;
+ int y = gsk_text_node_get_y (node) + builder->dy;
/* If the font has color glyphs, we don't need to recolor anything */
if (!force_color && font_has_color_glyphs (font))
@@ -925,19 +923,29 @@ render_shadow_node (GskGLRenderer *self,
for (i = 0; i < n_shadows; i ++)
{
const GskShadow *shadow = gsk_shadow_node_peek_shadow (node, i);
+ const float dx = shadow->dx;
+ const float dy = shadow->dy;
int texture_id;
gboolean is_offscreen;
- float dx, dy;
-
- dx = shadow->dx;
- dy = shadow->dy;
+ float prev_dx;
+ float prev_dy;
g_assert (shadow->radius <= 0);
+ min_x = shadow_child->bounds.origin.x;
+ min_y = shadow_child->bounds.origin.y;
+ max_x = min_x + shadow_child->bounds.size.width;
+ max_y = min_y + shadow_child->bounds.size.height;
+
+ prev_dx = builder->dx;
+ prev_dy = builder->dy;
+
+ ops_offset (builder, dx, dy);
+
if (gsk_render_node_get_node_type (shadow_child) == GSK_TEXT_NODE)
{
- render_text_node (self, shadow_child, builder, &shadow->color, TRUE,
- shadow->dx, shadow->dy);
+ render_text_node (self, shadow_child, builder, &shadow->color, TRUE);
+ ops_offset (builder, prev_dx, prev_dy);
continue;
}
@@ -945,6 +953,8 @@ render_shadow_node (GskGLRenderer *self,
dx + min_x, dx + max_x, dy + min_y, dy + max_y,
shadow_child, &texture_id, &is_offscreen);
+ ops_offset (builder, prev_dx, prev_dy);
+
ops_set_program (builder, &self->shadow_program);
ops_set_color (builder, &shadow->color);
ops_set_texture (builder, texture_id);
@@ -959,18 +969,11 @@ render_shadow_node (GskGLRenderer *self,
{ { dx + min_x, dy + max_y }, { 0, 0 }, },
{ { dx + max_x, dy + min_y }, { 1, 1 }, },
};
- ops_draw (builder, vertex_data);
+ ops_draw (builder, vertex_data);
}
else
{
- min_x = shadow_child->bounds.origin.x;
- min_y = shadow_child->bounds.origin.y;
- max_x = min_x + shadow_child->bounds.size.width;
- max_y = min_y + shadow_child->bounds.size.height;
-
- /* XXX We are inside a loop and the 4 lines above modify min_x/min_y/...
- * so this is potentially wrong for >1 shadow. */
const GskQuadVertex vertex_data[GL_N_VERTICES] = {
{ { dx + min_x, dy + min_y }, { 0, 0 }, },
{ { dx + min_x, dy + max_y }, { 0, 1 }, },
@@ -1406,8 +1409,8 @@ gsk_gl_renderer_add_render_ops (GskGLRenderer *self,
GskRenderNode *node,
RenderOpBuilder *builder)
{
- const float min_x = node->bounds.origin.x;
- const float min_y = node->bounds.origin.y;
+ const float min_x = builder->dx + node->bounds.origin.x;
+ const float min_y = builder->dy + node->bounds.origin.y;
const float max_x = min_x + node->bounds.size.width;
const float max_y = min_y + node->bounds.size.height;
@@ -1480,7 +1483,7 @@ gsk_gl_renderer_add_render_ops (GskGLRenderer *self,
case GSK_TEXT_NODE:
render_text_node (self, node, builder,
- gsk_text_node_peek_color (node), FALSE, 0, 0);
+ gsk_text_node_peek_color (node), FALSE);
break;
case GSK_COLOR_MATRIX_NODE:
diff --git a/gsk/gl/gskglrenderops.c b/gsk/gl/gskglrenderops.c
index d3fa195..7b9a6a2 100644
--- a/gsk/gl/gskglrenderops.c
+++ b/gsk/gl/gskglrenderops.c
@@ -382,6 +382,15 @@ ops_draw (RenderOpBuilder *builder,
}
void
+ops_offset (RenderOpBuilder *builder,
+ float x,
+ float y)
+{
+ builder->dx = x;
+ builder->dy = y;
+}
+
+void
ops_add (RenderOpBuilder *builder,
const RenderOp *op)
{
diff --git a/gsk/gl/gskglrenderopsprivate.h b/gsk/gl/gskglrenderopsprivate.h
index 7a7ed39..89dca55 100644
--- a/gsk/gl/gskglrenderopsprivate.h
+++ b/gsk/gl/gskglrenderopsprivate.h
@@ -198,6 +198,7 @@ typedef struct
graphene_matrix_t current_projection;
graphene_rect_t current_viewport;
float current_opacity;
+ float dx, dy;
gsize buffer_size;
@@ -246,6 +247,10 @@ void ops_set_border_color (RenderOpBuilder *builder,
void ops_draw (RenderOpBuilder *builder,
const GskQuadVertex vertex_data[GL_N_VERTICES]);
+void ops_offset (RenderOpBuilder *builder,
+ float x,
+ float y);
+
void ops_add (RenderOpBuilder *builder,
const RenderOp *op);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]