KAS GUI

Test Status kas-text Docs Minimum rustc version

KAS, (historically the toolKit Abstraction System), is a general-purpose GUI toolkit. KAS's design provides:

Documentation

Examples

Examples can be found in kas-wgpu/examples/. Further examples can be found in kas-gui/7guis.

Precompiled example apps can be downloaded as follows:

Gallery

Features

The below should give a rough idea of what's done and what's not. See also the [ROADMAP].

Installation and dependencies

Rust

KAS requires [Rust] version 1.52 or greater (currently in beta: usually we maintain compatibility with the latest stable release). Using the nightly channel does have a couple of advantages:

Quick-start

Install dependencies: ```sh

For Ubuntu:

sudo apt-get install build-essential git libxcb-shape0-dev libxcb-xfixes0-dev libharfbuzz-dev

For Fedora:

glslc is optional; see kas-wgpu/README.md

sudo dnf install libxcb-devel harfbuzz-devel glslc ```

Next, clone the repository and run the examples as follows: sh git clone https://github.com/kas-gui/kas.git cd kas cargo test cd kas-wgpu cargo build --examples cargo run --example gallery cargo run --example layout cargo run --example mandlebrot

If possible, wgpu ([WebGPU]) will use the Vulkan, Metal or DirectX 12 graphics API. If none of these are available it may instead use OpenGL, however this currently requires the wgpu/cross feature: sh cargo run --example gallery --features wgpu/cross (To force OpenGL on other platforms, set KAS_BACKENDS=GL.)

To build docs locally: RUSTDOCFLAGS="--cfg doc_cfg" cargo +nightly doc --features markdown --no-deps --all --open

Crates

A user depends on kas to write their complete UI specification, selects a theme from kas-theme, instances a kas_wgpu::Toolkit, adds the window(s), and runs the UI.

Feature flags

The kas crate has the following feature flags:

Additionally, the following flags require a nightly compiler:

Configuration

Formats are not yet stabilised, hence reading/writing configuration is disabled by default. Ensure that the yaml and/or json feature flag is enabled, then configure with environment variables: ```sh

Set the config path:

export KAS_CONFIG=kas-config.yaml

Use write-mode to write out default config:

KASCONFIGMODE=writedefault cargo run --example gallery

Now just edit the config and run like normal:

cargo run --example gallery ```

Copyright and Licence

The COPYRIGHT file includes a list of contributors who claim copyright on this project. This list may be incomplete; new contributors may optionally add themselves to this list.

The KAS library is published under the terms of the Apache License, Version 2.0. You may obtain a copy of this licence from the LICENSE file or on the following webpage: https://www.apache.org/licenses/LICENSE-2.0