| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 | import GObject from 'gi://GObject';import * as utils from '../conveniences/utils.js';const St = await utils.import_in_shell_only('gi://St');const Shell = await utils.import_in_shell_only('gi://Shell');const Clutter = await utils.import_in_shell_only('gi://Clutter');const SHADER_FILENAME = 'monte_carlo_blur.glsl';const DEFAULT_PARAMS = {    radius: 2., iterations: 5, brightness: .6,    width: 0, height: 0, use_base_pixel: true,    prefer_closer_pixels: true,};export const MonteCarloBlurEffect = utils.IS_IN_PREFERENCES ?    { default_params: DEFAULT_PARAMS } :    new GObject.registerClass({        GTypeName: "MonteCarloBlurEffect",        Properties: {            'radius': GObject.ParamSpec.double(                `radius`,                `Radius`,                `Blur radius`,                GObject.ParamFlags.READWRITE,                0.0, 2000.0,                2.0,            ),            'iterations': GObject.ParamSpec.int(                `iterations`,                `Iterations`,                `Blur iterations`,                GObject.ParamFlags.READWRITE,                0, 64,                5,            ),            'brightness': GObject.ParamSpec.double(                `brightness`,                `Brightness`,                `Blur brightness`,                GObject.ParamFlags.READWRITE,                0.0, 1.0,                0.6,            ),            'width': GObject.ParamSpec.double(                `width`,                `Width`,                `Width`,                GObject.ParamFlags.READWRITE,                0.0, Number.MAX_SAFE_INTEGER,                0.0,            ),            'height': GObject.ParamSpec.double(                `height`,                `Height`,                `Height`,                GObject.ParamFlags.READWRITE,                0.0, Number.MAX_SAFE_INTEGER,                0.0,            ),            'use_base_pixel': GObject.ParamSpec.boolean(                `use_base_pixel`,                `Use base pixel`,                `Use base pixel`,                GObject.ParamFlags.READWRITE,                true,            ),            'prefer_closer_pixels': GObject.ParamSpec.boolean(                `prefer_closer_pixels`,                `Prefer closer pixels`,                `Prefer closer pixels`,                GObject.ParamFlags.READWRITE,                true,            ),        }    }, class MonteCarloBlurEffect extends Clutter.ShaderEffect {        constructor(params) {            super(params);            utils.setup_params(this, params);            // set shader source            this._source = utils.get_shader_source(Shell, SHADER_FILENAME, import.meta.url);            if (this._source)                this.set_shader_source(this._source);            const theme_context = St.ThemeContext.get_for_stage(global.stage);            theme_context.connectObject(                'notify::scale-factor',                _ => this.set_uniform_value('radius',                    parseFloat(this._radius * theme_context.scale_factor - 1e-6)                ),                this            );        }        static get default_params() {            return DEFAULT_PARAMS;        }        get radius() {            return this._radius;        }        set radius(value) {            if (this._radius !== value) {                this._radius = value;                const scale_factor = St.ThemeContext.get_for_stage(global.stage).scale_factor;                this.set_uniform_value('radius', parseFloat(this._radius * scale_factor - 1e-6));                this.set_enabled(this.radius > 0. && this.iterations > 0);            }        }        get iterations() {            return this._iterations;        }        set iterations(value) {            if (this._iterations !== value) {                this._iterations = value;                this.set_uniform_value('iterations', this._iterations);                this.set_enabled(this.radius > 0. && this.iterations > 0);            }        }        get brightness() {            return this._brightness;        }        set brightness(value) {            if (this._brightness !== value) {                this._brightness = value;                this.set_uniform_value('brightness', parseFloat(this._brightness - 1e-6));            }        }        get width() {            return this._width;        }        set width(value) {            if (this._width !== value) {                this._width = value;                this.set_uniform_value('width', parseFloat(this._width + 3.0 - 1e-6));            }        }        get height() {            return this._height;        }        set height(value) {            if (this._height !== value) {                this._height = value;                this.set_uniform_value('height', parseFloat(this._height + 3.0 - 1e-6));            }        }        get use_base_pixel() {            return this._use_base_pixel;        }        set use_base_pixel(value) {            if (this._use_base_pixel !== value) {                this._use_base_pixel = value;                this.set_uniform_value('use_base_pixel', this._use_base_pixel ? 1 : 0);            }        }        get prefer_closer_pixels() {            return this._prefer_closer_pixels;        }        set prefer_closer_pixels(value) {            if (this._prefer_closer_pixels !== value) {                this._prefer_closer_pixels = value;                this.set_uniform_value('prefer_closer_pixels', this._prefer_closer_pixels ? 1 : 0);            }        }        vfunc_set_actor(actor) {            if (this._actor_connection_size_id) {                let old_actor = this.get_actor();                old_actor?.disconnect(this._actor_connection_size_id);            }            if (actor) {                this.width = actor.width;                this.height = actor.height;                this._actor_connection_size_id = actor.connect('notify::size', _ => {                    this.width = actor.width;                    this.height = actor.height;                });            }            else                this._actor_connection_size_id = null;            super.vfunc_set_actor(actor);        }    });
 |