Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/MeadowlarkDAW/rootvg
A 2D vector graphics library optimized for GUIs, written in Rust and wgpu
https://github.com/MeadowlarkDAW/rootvg
Last synced: about 2 months ago
JSON representation
A 2D vector graphics library optimized for GUIs, written in Rust and wgpu
- Host: GitHub
- URL: https://github.com/MeadowlarkDAW/rootvg
- Owner: MeadowlarkDAW
- License: mit
- Created: 2024-04-05T22:23:16.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-05-28T22:17:38.000Z (8 months ago)
- Last Synced: 2024-05-29T11:59:59.820Z (8 months ago)
- Language: Rust
- Size: 229 KB
- Stars: 11
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# RootVG
[![Documentation](https://docs.rs/rootvg/badge.svg)](https://docs.rs/rootvg)
[![Crates.io](https://img.shields.io/crates/v/rootvg.svg)](https://crates.io/crates/rootvg)
[![License](https://img.shields.io/crates/l/rootvg.svg)](https://github.com/MeadowlarkDAW/rootvg/blob/main/LICENSE)A 2D vector graphics library optimized for GUIs, written in Rust and [wgpu](https://github.com/gfx-rs/wgpu)
## How it Works
Unlike other 2D vector graphics libraries which have a streaming drawing API similar to [HTML5's Canvas API](https://www.w3schools.com/jsref/api_canvas.asp), users of RootVG construct reusable "primitives" that can be cheaply cloned and added in any order with any z index and inside of any scissoring rectangle. Primitives of the same type, z index, and scissoring rectangle are automatically batched together so that the number of draw calls to the GPU are greatly reduced.
See the [demo](examples/demo.rs) for a quick overview of how the API works.
## Primitive Types
RootVG provides six primitive types:
* `SolidQuadPrimitive` and `GradientQuadPrimitive` - based on the quad primitives from [Iced](https://github.com/iced-rs/iced)
* `SolidMeshPrimitive` and `GradientMeshPrimitive` - draws arbitrary triangles with a solid color or a gradient. The [lyon](https://github.com/nical/lyon) crate is used to generate meshes.
* `TextPrimitive` - powered by [glyphon](https://github.com/grovesNL/glyphon/tree/main)
* `ImagePrimitive` - supports scale and rotation. The output of a previous render pass can also be used as a texture source.Additionally, users can create custom primitives with custom rendering pipelines. This can be useful for creating things like efficient spectrometer and oscilloscope displays.
Primitives types that aren't needed can be disabled in the feature flags.
## Motivation
This library was created for the [Yarrow](https://github.com/MeadowlarkDAW/Yarrow) GUI library which powers the [Meadowlark](https://github.com/MeadowlarkDAW/Meadowlark) DAW.