2021-08-23 22:31:42 +02:00
|
|
|
## Transparency within rofi
|
|
|
|
|
|
|
|
> The images in this guide are outdated, but the principals still hold.
|
|
|
|
|
|
|
|
**Rofi** window is build up by first drawing the background, and then each
|
|
|
|
widget above it, with the correct transparency factor.
|
|
|
|
|
|
|
|
Remember the general widget structure:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a8806/a880630b28439c778c991ff963ed4023e09b280e" alt="structure"
|
|
|
|
|
2021-08-23 22:36:24 +02:00
|
|
|
This means if you set every widget to be 30% transparent on a white background: it will look like:
|
2021-08-23 22:31:42 +02:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f16c5/f16c50c74785fc38a38c7e3f92b1235d47275361" alt="images"
|
|
|
|
|
|
|
|
The transparency applies one on top of the other, so while they all are 30%, in
|
|
|
|
the end it will be less transparent.
|
|
|
|
|
|
|
|
> Try it yourself
|
|
|
|
|
|
|
|
```bash
|
|
|
|
rofi -theme-str '@theme "/dev/null" window { background-color: white; }* { padding:5; background-color: rgba(20,20,20,0.5);}' -show run
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
This can sometimes be difficult when creating themes with a nice transparent
|
|
|
|
background.
|
|
|
|
The trick to make this work nicely is the following.
|
|
|
|
|
|
|
|
Specify fully transparent background on the highest level.
|
|
|
|
|
|
|
|
```css
|
|
|
|
* {
|
2021-08-23 22:36:24 +02:00
|
|
|
background: transparent;
|
2021-08-23 22:31:42 +02:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Then set the background on the window box.
|
|
|
|
|
|
|
|
```css
|
|
|
|
window {
|
|
|
|
background: #cc1c1c1c;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Now if you only set the background on widgets you want differently colored, it
|
|
|
|
nicely works out.
|
|
|
|
|
|
|
|
|
|
|
|
## Transparency on the window
|
|
|
|
|
|
|
|
This determines how transparency on the window is handled.
|
|
|
|
This is set the be `transparency` option on the `window` widget.
|
|
|
|
The option takes a string. There are basically 4 options:
|
|
|
|
|
|
|
|
### No transparency or "real"
|
|
|
|
|
|
|
|
The background of the window is black and fully transparent, and everything is drawn on top of this.
|
|
|
|
This means that if you have a composite manager (ARGB window), you get a fully transparent
|
|
|
|
background, otherwise fully black.
|
|
|
|
|
|
|
|
This is the preferred option if you have a composite manager running.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0c95a/0c95a8fcd959b0ae7e4d8f8f3e0510a367c637f1" alt="rofi real"
|
|
|
|
|
|
|
|
This image is actually partially transparent (won't show here clearly as block
|
|
|
|
background is white.)
|
|
|
|
|
|
|
|
### Fake transparency or "screenshot"
|
|
|
|
|
|
|
|
This tries to emulate a transparent window by taking a screenshot of the window
|
|
|
|
before showing and then drawing everything on top of this. While this is not an
|
2021-08-23 22:36:24 +02:00
|
|
|
ideal solution (it won't update if something changes in the background) it is
|
2021-08-23 22:31:42 +02:00
|
|
|
often a very usable facsimile.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d25ca/d25ca67a275d104d449cd8c0cce07a2d3471d8f7" alt="rofi fake"
|
|
|
|
|
|
|
|
> Note: It can get very slow, especially on high resolution (4k) monitors.
|
|
|
|
|
|
|
|
### Background transparency or "background"
|
|
|
|
|
|
|
|
This uses the background image (the root window image). This is, in my opinion,
|
|
|
|
mostly useful when used fullscreen.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/74954/749540b431fd0e989f50a6bbc82a1018ac797b34" alt="rofi background"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4244a/4244adddcc281d581474e073ae13661b288eb936" alt="rofi background2"
|
|
|
|
|
|
|
|
### Picture
|
|
|
|
|
|
|
|
If instead of one of the above option, you specify a path to a png file this is
|
2021-08-24 23:48:00 +02:00
|
|
|
used as background image. This can create a theme where you use paper as
|
2021-08-23 22:31:42 +02:00
|
|
|
background.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4870e/4870ed86e12206b464c060b8eff407fab9c49ca7" alt="rofi paper"
|