diff options
author | Alexander Orzechowski <alex@ozal.ski> | 2023-06-19 13:16:34 -0400 |
---|---|---|
committer | Alexander Orzechowski <alex@ozal.ski> | 2023-06-19 13:16:34 -0400 |
commit | 2044cc2311ad534f8f188f8d486f1ce7aa3e1421 (patch) | |
tree | 975c5b3e8c7045f8d8d01deba7d33c16c570f283 /render/gles2 | |
parent | 693005ac99cfdab5a71c4a689932f13134b0c729 (diff) |
render: Introduce wlr_render_texture_options.blend_mode
Diffstat (limited to 'render/gles2')
-rw-r--r-- | render/gles2/pass.c | 33 |
1 files changed, 14 insertions, 19 deletions
diff --git a/render/gles2/pass.c b/render/gles2/pass.c index b1d21616..9003f08c 100644 --- a/render/gles2/pass.c +++ b/render/gles2/pass.c @@ -121,6 +121,17 @@ static void set_tex_matrix(GLint loc, enum wl_output_transform trans, glUniformMatrix3fv(loc, 1, GL_FALSE, tex_matrix); } +static void setup_blending(enum wlr_render_blend_mode mode) { + switch (mode) { + case WLR_RENDER_BLEND_MODE_PREMULTIPLIED: + glEnable(GL_BLEND); + break; + case WLR_RENDER_BLEND_MODE_NONE: + glDisable(GL_BLEND); + break; + } +} + static void render_pass_add_texture(struct wlr_render_pass *wlr_pass, const struct wlr_render_texture_options *options) { struct wlr_gles2_render_pass *pass = get_render_pass(wlr_pass); @@ -159,12 +170,8 @@ static void render_pass_add_texture(struct wlr_render_pass *wlr_pass, src_fbox.height /= options->texture->height; push_gles2_debug(renderer); - - if (!texture->has_alpha && alpha == 1.0) { - glDisable(GL_BLEND); - } else { - glEnable(GL_BLEND); - } + setup_blending(!texture->has_alpha && alpha == 1.0 ? + WLR_RENDER_BLEND_MODE_NONE : options->blend_mode); glUseProgram(shader->program); @@ -202,19 +209,7 @@ static void render_pass_add_rect(struct wlr_render_pass *wlr_pass, const struct wlr_box *box = &options->box; push_gles2_debug(renderer); - - switch (options->blend_mode) { - case WLR_RENDER_BLEND_MODE_PREMULTIPLIED: - if (color->a == 1.0) { - glDisable(GL_BLEND); - } else { - glEnable(GL_BLEND); - } - break; - case WLR_RENDER_BLEND_MODE_NONE: - glDisable(GL_BLEND); - break; - } + setup_blending(color->a == 1.0 ? WLR_RENDER_BLEND_MODE_NONE : options->blend_mode); glUseProgram(renderer->shaders.quad.program); |