diff options
Diffstat (limited to 'src/renderer')
-rw-r--r-- | src/renderer/mod.rs | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/src/renderer/mod.rs b/src/renderer/mod.rs index fe4ff29f..2d466f79 100644 --- a/src/renderer/mod.rs +++ b/src/renderer/mod.rs @@ -110,6 +110,9 @@ pub struct ShaderProgram { /// Cell dimensions (pixels) u_cell_dim: GLint, + /// Visual bell + u_visual_bell: GLint, + /// Background pass flag /// /// Rendering is split into two passes; 1 for backgrounds, and one for text @@ -321,6 +324,7 @@ pub struct RenderApi<'a> { atlas: &'a mut Vec<Atlas>, program: &'a mut ShaderProgram, colors: &'a ColorList, + visual_bell: f32, } #[derive(Debug)] @@ -646,6 +650,7 @@ impl QuadRenderer { atlas: &mut self.atlas, program: &mut self.program, colors: config.color_list(), + visual_bell: 0.0, }); unsafe { @@ -708,13 +713,18 @@ impl QuadRenderer { } impl<'a> RenderApi<'a> { + pub fn set_visual_bell(&mut self, visual_bell: f32) { + self.visual_bell = visual_bell; + self.program.set_visual_bell(visual_bell); + } + pub fn clear(&self) { let color = self.colors[NamedColor::Background]; unsafe { gl::ClearColor( - color.r as f32 / 255.0, - color.g as f32 / 255.0, - color.b as f32 / 255.0, + (self.visual_bell + color.r as f32 / 255.0).min(1.0), + (self.visual_bell + color.g as f32 / 255.0).min(1.0), + (self.visual_bell + color.b as f32 / 255.0).min(1.0), 1.0 ); gl::Clear(gl::COLOR_BUFFER_BIT); @@ -736,7 +746,6 @@ impl<'a> RenderApi<'a> { } unsafe { - self.program.set_background_pass(true); gl::DrawElementsInstanced(gl::TRIANGLES, 6, gl::UNSIGNED_INT, ptr::null(), @@ -941,11 +950,12 @@ impl ShaderProgram { } // get uniform locations - let (projection, term_dim, cell_dim, background) = unsafe { + let (projection, term_dim, cell_dim, visual_bell, background) = unsafe { ( gl::GetUniformLocation(program, cptr!(b"projection\0")), gl::GetUniformLocation(program, cptr!(b"termDim\0")), gl::GetUniformLocation(program, cptr!(b"cellDim\0")), + gl::GetUniformLocation(program, cptr!(b"visualBell\0")), gl::GetUniformLocation(program, cptr!(b"backgroundPass\0")), ) }; @@ -957,6 +967,7 @@ impl ShaderProgram { u_projection: projection, u_term_dim: term_dim, u_cell_dim: cell_dim, + u_visual_bell: visual_bell, u_background: background, }; @@ -988,6 +999,12 @@ impl ShaderProgram { } } + fn set_visual_bell(&self, visual_bell: f32) { + unsafe { + gl::Uniform1f(self.u_visual_bell, visual_bell); + } + } + fn set_background_pass(&self, background_pass: bool) { let value = if background_pass { 1 |