shchemes/doc/cookbook.md
2024-04-12 17:48:25 -06:00

4.7 KiB

Cookbook

This document is a collection of ways to use shchemes. While many of these examples are useful for creating scripts to automatically change your whole desktop's color scheme, many of the examples given are meant to be ran in the terminal, to grow a greater familiarity with the techniques used.

GTK

Oomox

Shchemes can generate colors for oomox-gtk-theme, allowing your theme to spread to most of your desktop, providing it uses the GTK toolkit. oomox-gtk-theme includes a script we can call with the theme Shchemes generates to install a GTK theme with your colors.

"./change_color.sh" -o shchemes <(shchemes create_theme oomox-gtk -s=base16:horizon-terminal-dark)

This will install the theme to ~/.themes/shchemes.

Reload XFCE theme

If you're generating an Oomox theme, as detailed above, you may want some way of automatically setting or refreshing the GTK theme XFCE uses.

xfconf-query -c xsettings -p /Net/ThemeName -r
xfconf-query -c xsettings -p /Net/ThemeName -s shchemes

You may need to replace shchemes with the name of your theme in ~/.themes

ImageMagick

Shchemes can create ImageMagick pixel enumeration files, with a vertical strip of all the colors in the scheme. This is optimal for getting the color data into an image, or simply displaying the palette.

Displaying a palette at a reasonable size

This converts the pixel enumeration to a png and resizes it to 24px high with no interpolation.

shchemes create_theme imagemagick -s=base16:monokai | convert txt:- -filter point -resize 2400% palette.png

Result:

A strip of all the colors in the monokai scheme

Apply a color scheme to an image using -remap

shchemes create_theme --scheme=base16:blueforest imagemagick | \
	| convert source.jpg -colorspace srgb -remap txt:- out.jpg

Note that this is isn't like theming an app where your colors are simply slotted into the theme. It's trying to recreate your image the best it can with your color scheme. Images with a palette closer to your scheme will yield better results.

A trick I've found for wallpapers is using an image twice your actual monitor resolution--This makes the dithering less visible while still somewhat retaining the color scheme change.

Apply a color scheme to an image with -dither

shchemes create_theme --scheme=base16:blueforest imagemagick | \
	| convert source.jpg -colorspace srgb -dither FloydSteinberg -remap txt:- out.jpg

Another dithering model available is Riemersma, which gives a more splotchy, "boiled" look.

BSPWM

Generate a script to set bspwm colors

bspwm_theme="$HOME/.config/bspwm/colors"
shchemes create_theme bspwm > "$bspwm_theme"
"$bspwm_theme"

You'll need to call it from your bspwmrc

"$(dirname $0)/colors"

Reloading configs

Remotely reloading your Qutebrowser configuration

Qutebrowser can be remotely reloaded by sending it a HUP signal.

pkill -HUP qutebrowser

Note on older versions (<=3.1.0) this will simply kill Qutebrowser.

Remotely reloading your Kitty configuration

Kitty will reload it's configuration on a USR1 signal.

pkill -USR1 kitty

Creating an script to automatically theme your whole desktop

This is the use case that shchemes was designed to fulfill.

SCHEME environment variable

To avoid having to use -s or --scheme in every command of your script, shchemes will also read a SCHEME environment variable if those flags aren't set.

This is a useful pattern to put at the top of a script.

export SCHEME=$1

Automatically installing a tinted-theming scheme

This snippet will automatically install your scheme from the tinted-theming collection and exit if it can't be found.

if ! shchemes install_tinted_scheme ; then
	exit 1
fi

.profile injection

Sometimes you have other scripts that need to know what theme is currently applied on your system. One way to do this is to set the SCHEME environment variable in your .profile.

echo '#START SHCHEMES BLOCK : printf "SCHEME=\"%s\"\n" "$SCHEME"' > ~/.profile

And in your script:

shchemes inject "$HOME/.profile"

Caution

Shchemes injection is literally one Awk script. While lots of care has been taken, we are not liable for it mangling your configuration files, and we give no guarantees. It is recommended you backup your configs, preferably in something with version control in case you don't realise something's gone wrong until later.