screenShield: Blur background
This is a moderately fast two-pass gaussian blur implementation. It downscales the framebuffer dynamically before applying the gaussian shader, which cuts down rendering time quite considerably. The blur shader takes 2 uniforms as input: the blur radius; and whether to blur vertically or horizontally. The blur radius is treated as an integer in C land to simplify calculations. The vertical parameter is treated as an integer by the shader simply due to Cogl not having proper boolean support in snippets. At last, brightness is also added to avoid needing to use an extra effect to achieve that. Brightness is applied in a different pipeline than blur, so we can control it more tightly. ShellBlurEffect also implements a "below" mode, where the contents beneath the actor are blurred, but not the actor itself. This mode is performance-heavy. Related: https://gitlab.gnome.org/GNOME/gnome-shell/issues/1848 https://gitlab.gnome.org/GNOME/gnome-shell/merge_requests/864
This commit is contained in:
parent
9115f6e796
commit
768193ab20
@ -27,6 +27,10 @@ const LOCKDOWN_SCHEMA = 'org.gnome.desktop.lockdown';
|
|||||||
const DISABLE_LOCK_KEY = 'disable-lock-screen';
|
const DISABLE_LOCK_KEY = 'disable-lock-screen';
|
||||||
|
|
||||||
const LOCKED_STATE_STR = 'screenShield.locked';
|
const LOCKED_STATE_STR = 'screenShield.locked';
|
||||||
|
|
||||||
|
const BLUR_BRIGHTNESS = 0.55;
|
||||||
|
const BLUR_RADIUS = 200;
|
||||||
|
|
||||||
// fraction of screen height the arrow must reach before completing
|
// fraction of screen height the arrow must reach before completing
|
||||||
// the slide up automatically
|
// the slide up automatically
|
||||||
var ARROW_DRAG_THRESHOLD = 0.1;
|
var ARROW_DRAG_THRESHOLD = 0.1;
|
||||||
@ -607,6 +611,11 @@ var ScreenShield = class {
|
|||||||
this._bgManagers.push(bgManager);
|
this._bgManagers.push(bgManager);
|
||||||
|
|
||||||
this._backgroundGroup.add_child(widget);
|
this._backgroundGroup.add_child(widget);
|
||||||
|
|
||||||
|
widget.add_effect(new Shell.BlurEffect({
|
||||||
|
brightness: BLUR_BRIGHTNESS,
|
||||||
|
blur_radius: BLUR_RADIUS,
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
_updateBackgrounds() {
|
_updateBackgrounds() {
|
||||||
|
@ -95,6 +95,7 @@ libshell_public_headers = [
|
|||||||
'shell-app.h',
|
'shell-app.h',
|
||||||
'shell-app-system.h',
|
'shell-app-system.h',
|
||||||
'shell-app-usage.h',
|
'shell-app-usage.h',
|
||||||
|
'shell-blur-effect.h',
|
||||||
'shell-embedded-window.h',
|
'shell-embedded-window.h',
|
||||||
'shell-glsl-effect.h',
|
'shell-glsl-effect.h',
|
||||||
'shell-gtk-embed.h',
|
'shell-gtk-embed.h',
|
||||||
@ -129,6 +130,7 @@ libshell_sources = [
|
|||||||
'shell-app.c',
|
'shell-app.c',
|
||||||
'shell-app-system.c',
|
'shell-app-system.c',
|
||||||
'shell-app-usage.c',
|
'shell-app-usage.c',
|
||||||
|
'shell-blur-effect.c',
|
||||||
'shell-embedded-window.c',
|
'shell-embedded-window.c',
|
||||||
'shell-embedded-window-private.h',
|
'shell-embedded-window-private.h',
|
||||||
'shell-global.c',
|
'shell-global.c',
|
||||||
|
1079
src/shell-blur-effect.c
Normal file
1079
src/shell-blur-effect.c
Normal file
File diff suppressed because it is too large
Load Diff
57
src/shell-blur-effect.h
Normal file
57
src/shell-blur-effect.h
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
/* shell-blur-effect.h
|
||||||
|
*
|
||||||
|
* Copyright 2019 Georges Basile Stavracas Neto <georges.stavracas@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ShellBlurMode:
|
||||||
|
* @SHELL_BLUR_MODE_ACTOR: blur the actor contents, and its children
|
||||||
|
* @SHELL_BLUR_MODE_BELOW: blur what's beneath the actor
|
||||||
|
*
|
||||||
|
* The mode of blurring of the effect.
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SHELL_BLUR_MODE_ACTOR,
|
||||||
|
SHELL_BLUR_MODE_BELOW,
|
||||||
|
} ShellBlurMode;
|
||||||
|
|
||||||
|
#define SHELL_TYPE_BLUR_EFFECT (shell_blur_effect_get_type())
|
||||||
|
G_DECLARE_FINAL_TYPE (ShellBlurEffect, shell_blur_effect, SHELL, BLUR_EFFECT, ClutterEffect)
|
||||||
|
|
||||||
|
ShellBlurEffect *shell_blur_effect_new (void);
|
||||||
|
|
||||||
|
int shell_blur_effect_get_blur_radius (ShellBlurEffect *self);
|
||||||
|
void shell_blur_effect_set_blur_radius (ShellBlurEffect *self,
|
||||||
|
int radius);
|
||||||
|
|
||||||
|
float shell_blur_effect_get_brightness (ShellBlurEffect *self);
|
||||||
|
void shell_blur_effect_set_brightness (ShellBlurEffect *self,
|
||||||
|
float brightness);
|
||||||
|
|
||||||
|
ShellBlurMode shell_blur_effect_get_mode (ShellBlurEffect *self);
|
||||||
|
void shell_blur_effect_set_mode (ShellBlurEffect *self,
|
||||||
|
ShellBlurMode mode);
|
||||||
|
|
||||||
|
G_END_DECLS
|
Loading…
Reference in New Issue
Block a user