skulpin 0.2.2

This crate provides an easy option for drawing hardware-accelerated 2D by combining Vulkan and Skia.
docs.rs failed to build skulpin-0.2.2
Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.

skulpin

Skia + Vulkan = Skulpin

This crate provides an easy option for drawing hardware-accelerated 2D by combining vulkan and skia. (And a dash of winit!)

Build Status Crates.io

Example Screenshot

This crate mainly depends on:

  • ash - Vulkan bindings for Rust
  • skia-safe - Skia bindings for Rust
  • winit - Cross-platform window handling

Usage

Currently there are two ways to use this library.

  • app - Implement the AppHandler trait and launch the app. It's simple but not as flexible.
  • renderer_only - You manage the window and event loop yourself. Then add the renderer to draw to it.

The interactive example is good to look at for an easy way to get keyboard/mouse input.

Don't forget to install the prerequisites below appropriate to your platform! (See "Requirements")

Running the Examples

First, ensure that the below requirements are met depending on OS. Afterwards, the examples can be run normally:

cargo run --example interactive

Requirements

Minimum required rust version: 1.36.0

Windows

All examples require the LunarG Validation layers and a Vulkan library that is visible in your PATH. An easy way to get started is to use the LunarG Vulkan SDK

MacOS

All examples require the LunarG Validation layers and a Vulkan library that is visible in your PATH. An easy way to get started is to use the LunarG Vulkan SDK

Linux

All examples require the LunarG Validation layers and a Vulkan library that is visible in your PATH. An easy way to get started is to use the LunarG Vulkan SDK

On linux you'll also need to link against bz2, GL, fontconfig, and freetype.

On ubuntu, you could use libbz2-dev, libfreetype6-dev, libfontconfig1-dev, and libgl-dev. (And libvulkan-dev to pick up the Vulkan SDK)

Other Platforms

It may be possible to build this for mobile platforms, but I've not investigated this yet.

Status

For now this is a proof-of-concept. I think there is desire for a simple entry point to drawing on the screen, and that this approach can provide a good balance of performance, features, and ease-of-use for many applications.

Flutter, Google's new UI framework, uses a Skia + Vulkan stack to achieve 60+ FPS on mobile devices. So I expect this type of usage to be maintained and improved as needed in the upstream libraries.

A note on High-DPI Display Support

For the common case, you can draw to the skia canvas using winit's "logical" coordinates and not worry about dpi/scaling issues.

Internally, the skia surface will match the swapchain size, but this size is not necessarily winit's LogicalSize or PhysicalSize of the window. In order to produce consistently-sized results, the renderer will apply a scaling factor to the skia canvas before handing it off to your draw implementation.

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.

See LICENSE-APACHE and LICENSE-MIT.