kasuari

Crates.iokasuari
lib.rskasuari
version0.0.0
sourcesrc
created_at2024-10-04 03:54:18.613511
updated_at2024-10-04 03:54:18.613511
descriptionA rust layout solver for GUIs, based on the Cassowary algorithm. A fork of the unmaintained cassowary-rs crate with improvments and bug fixes. Kasuari is the indonesian name for the cassowary bird.
homepagehttps://github.com/joshka/kasuari
repositoryhttps://github.com/joshka/kasuari
max_upload_size
id1396067
size5,398
Josh McKinney (joshka)

documentation

https://docs.rs/kasuari

README

Kasuari

Placeholder - code to come soon.

A Rust implementation of the Cassowary constraint solving algorithm (Badros et. al 2001). It is based heavily on the implementation the C++ Kiwi library. The implementation does however differ in some details.

This library is a fork of Cassowary-rs, by Dylan Ede, which hasn't been maintained since 2018. Kasuari is the Indonesian name for the Cassowary bird.

Cassowary is designed for solving constraints to lay out user interfaces. Constraints typically take the form "this button must line up with this text box", or "this box should try to be 3 times the size of this other box". Its most popular incarnation by far is in Apple's Autolayout system for Mac OS X and iOS user interfaces. UI libraries using the Cassowary algorithm manage to achieve a much more natural approach to specifying UI layouts than traditional approaches like those found in HTML.

This library is a low level interface to the solving algorithm, though it tries to be as convenient as possible. As a result it does not have any intrinsic knowledge of common user interface conventions like rectangular regions or even two dimensions. These abstractions belong in a higher level crate.

For more information, please read the Kasuari API docs.

Getting Started

Add this crate to your Cargo.toml file

cargo add kasuari

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Commit count: 0

cargo fmt