diff --git a/SukiUI/Content/Shaders/Background/flat.sksl b/SukiUI/Content/Shaders/Background/flat.sksl index c671dcff3..a468ad30d 100644 --- a/SukiUI/Content/Shaders/Background/flat.sksl +++ b/SukiUI/Content/Shaders/Background/flat.sksl @@ -1,7 +1,3 @@ vec4 main(vec2 fragCoord) { - - if(iDark == 1) - return vec4(iBase * 1, iAlpha); - return vec4(iBase, iAlpha); } \ No newline at end of file diff --git a/docs/docs/.vitepress/config/en.mts b/docs/docs/.vitepress/config/en.mts index 904db0507..22fb55009 100644 --- a/docs/docs/.vitepress/config/en.mts +++ b/docs/docs/.vitepress/config/en.mts @@ -23,6 +23,7 @@ export const en = defineConfig({ { text: 'Basic', link: '/documentation/theming/basic' }, { text: 'Light & Dark', link: '/documentation/theming/theme' }, { text: 'Color', link: '/documentation/theming/theme-color' }, + { text: 'Background', link: '/documentation/theming/background' }, ] }, { diff --git a/docs/docs/documentation/theming/background.md b/docs/docs/documentation/theming/background.md new file mode 100644 index 000000000..7be992936 --- /dev/null +++ b/docs/docs/documentation/theming/background.md @@ -0,0 +1,58 @@ +# Backgrounds + +SukiUI includes a background renderer which utilises GPU acceleration and shaders to draw complex runtime background effects that update with theme changes. All properties mentioned on this page can be accessed out of the box via the `Background{Property}` properties present in `SukiWindow`. If you wish to host a `SukiBackground` control of your own in another context then these properties should be similarly named without the `Background` prefix. + +## Styles + +Changing style to one of the defaults is done via `BackgroundStyle` - Available out of the box are `Gradient`, `Flat` and `Bubble`. It is possible however to use custom shaders (written in SKSL) to create your own backgrounds. There are two methods to use your own shaders written in this language: + +#### BackgroundShaderFile +By including an embedded resource in your application with the correct file extension (E.G. `MyShader.sksl`) it is possibly to simply set the `BackgroundShaderFile` property to the name of the file (without the extension). SukiUI will search your embedded resources for the file and load the shader for use automatically. + +SukiUI includes a few shaders that are not included in the default enum but are nonetheless accessible this way including `Cells` and `Waves`. + +#### BackgroundShaderCode +Simply assigning a string representing your shader to this property will create the runtime effect and render it without the need for embedded files, it is possible to bind to this property and dynamically alter the shader code at runtime if you so desire, any change will be reflected immediately. + +#### Notes +When choosing which background style to render, if more than one property is assigned to a non-null value at once, then SukiUI will prioritize the properties in the following order `BackgroundShaderFile` -> `BackgroundShaderCode` -> `BackgroundStyle` + +## Custom Styles + +In order to render custom backgrounds via the properties mentioned before, it is necessary to write SKSL. This might seem daunting at first but it is a fairly simple language in which you write an entry point function that returns a `vec4` representing the colour of each pixel. With GPU parallelization it is possible to execute large numbers of fairly complex mathematical calculations very quickly. + +SukiUI automatically includes a set of uniforms in these effects before shader compilation for you to use in your shaders, these are: + +- `float iTime` - A representation of the current ticks since the background began rendering. Only changed when animation is enabled. +- `float iDark` - Whether the application is in light or dark mode - 0 = light, 1 = dark. +- `float iAlpha` - The alpha at which the background is being drawn, largely controlled by opacity of the background control. +- `vec3 iResolution` - The resolution of the background in pixels, `x` and `y` are the only elements used, `z` is always 0. +- `vec3 iPrimary` - A (not exact) representation of the current active primary theme color. +- `vec3 iAccent` - A (not exact) representation of the current active accent theme color. +- `vec3 iBase` - A pre-calculated background colour for the theme - or an off-white if the app is in light mode. + +These uniforms are included automatically in any shader file or code you supply and can be used as if they were globally scoped variables. They are updated per-frame and any change in the application state will be reflected in these uniforms. + +The simplest example of a shader is our `Flat` style which simply returns the base background colour for every pixel. + +```glsl +vec4 main(vec2 fragCoord) { + return vec4(iBase, iAlpha); +} +``` + +## Transitions + +Enabling `BackgroundTransitionsEnabled` will cause any change in the background style to "fade" between the two with a simple opacity switch, this is where the `iAlpha` property is mostly used. `BackgroundTransitionTime` can also be set to define the time in seconds for the transition (default: 1 second). + +## Animation + +The background renderer does support animation via `BackgroundAnimationEnabled` and will run at native framerates, all default SukiUI backgrounds support animation out of the box (except for `Flat`). + +::: warning +Due to the need for an invalidation and repaint of the entire visual tree, animations can have a significant impact on performance and it is recommended that you only use it if absolutely necessary. In limited testing we see a roughly 5% bump in CPU and 20% bump in GPU utilization _at all times_ when animation is enabled. +::: + +## Software fallback + +In the case SkiaSharp (Avalonia's underlying rendering engine) is unable to find any usable hardware acceleration, SukiUI will fall back to a software rendering solution which is simply the `Flat` background style rendered on the CPU. \ No newline at end of file