[gtk/wip/chergert/glproto: 177/526] implement unblurred inset shadow
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/chergert/glproto: 177/526] implement unblurred inset shadow
- Date: Tue, 16 Feb 2021 01:14:28 +0000 (UTC)
commit 85aab05ef58b1f4e93fd7e71ecb1bd474efda2e3
Author: Christian Hergert <chergert redhat com>
Date: Fri Jan 1 23:57:22 2021 -0800
implement unblurred inset shadow
gsk/next/gskglrenderjob.c | 43 ++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 42 insertions(+), 1 deletion(-)
---
diff --git a/gsk/next/gskglrenderjob.c b/gsk/next/gskglrenderjob.c
index 123954a530..24d9d0bad3 100644
--- a/gsk/next/gskglrenderjob.c
+++ b/gsk/next/gskglrenderjob.c
@@ -1158,6 +1158,41 @@ gsk_gl_render_job_visit_transform_node (GskGLRenderJob *job,
}
}
+static void
+gsk_gl_render_job_visit_unblurred_inset_shadow_node (GskGLRenderJob *job,
+ GskRenderNode *node)
+{
+ GskGLRenderModelview *modelview = gsk_gl_render_job_get_modelview (job);
+
+ gsk_gl_program_begin_draw (job->driver->inset_shadow,
+ &job->viewport,
+ &job->projection,
+ &modelview->matrix,
+ gsk_gl_render_job_get_clip (job));
+ gsk_gl_program_set_uniform_rounded_rect (job->driver->inset_shadow,
+ UNIFORM_INSET_SHADOW_OUTLINE_RECT,
+ gsk_inset_shadow_node_get_outline (node));
+ gsk_gl_program_set_uniform_color (job->driver->inset_shadow,
+ UNIFORM_INSET_SHADOW_COLOR,
+ gsk_inset_shadow_node_get_color (node));
+ gsk_gl_program_set_uniform1f (job->driver->inset_shadow,
+ UNIFORM_INSET_SHADOW_SPREAD,
+ gsk_inset_shadow_node_get_spread (node));
+ gsk_gl_program_set_uniform2f (job->driver->inset_shadow,
+ UNIFORM_INSET_SHADOW_OFFSET,
+ gsk_inset_shadow_node_get_dx (node),
+ gsk_inset_shadow_node_get_dy (node));
+ gsk_gl_render_job_draw_rect (job, &node->bounds);
+ gsk_gl_program_end_draw (job->driver->inset_shadow);
+}
+
+static void
+gsk_gl_render_job_visit_blurred_inset_shadow_node (GskGLRenderJob *job,
+ GskRenderNode *node)
+{
+ g_warning ("TODO: blurred inset shadow");
+}
+
static void
gsk_gl_render_job_visit_node (GskGLRenderJob *job,
GskRenderNode *node)
@@ -1229,6 +1264,13 @@ gsk_gl_render_job_visit_node (GskGLRenderJob *job,
gsk_gl_render_job_visit_border_node (job, node);
break;
+ case GSK_INSET_SHADOW_NODE:
+ if (gsk_inset_shadow_node_get_blur_radius (node) > 0)
+ gsk_gl_render_job_visit_blurred_inset_shadow_node (job, node);
+ else
+ gsk_gl_render_job_visit_unblurred_inset_shadow_node (job, node);
+ break;
+
case GSK_BLEND_NODE:
case GSK_BLUR_NODE:
case GSK_CAIRO_NODE:
@@ -1236,7 +1278,6 @@ gsk_gl_render_job_visit_node (GskGLRenderJob *job,
case GSK_CONIC_GRADIENT_NODE:
case GSK_CROSS_FADE_NODE:
case GSK_GL_SHADER_NODE:
- case GSK_INSET_SHADOW_NODE:
case GSK_OPACITY_NODE:
case GSK_OUTSET_SHADOW_NODE:
case GSK_RADIAL_GRADIENT_NODE:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]