A new format for simple vector graphics.
Quoting the german Wikipedia on SVG:
Praktisch alle relevanten Webbrowser können einen Großteil des Sprachumfangs darstellen.
Translated:
Virtually all relevant web browsers can display most of the language specification.
SVG is a horribly complex format, allowing the embedding of JavaScript and other features no sane person ever wants to have in their images. Other relevant vector graphics formats do not exist or don't have a documentation or specification (looking at you, HVIF!).
This project tries to create and specify a new vector format suitable for:
- Small and medium icons (think toolbar, buttons, …)
- Low complexity graphics (think graphs, diagrams, …)
- Embedded platforms (low resource requirements)
Create a vector graphics format that fulfils the following requirements:
- Binary encoded ✅
- Small file size (must be smaller than equivalent bitmaps or SVG graphics) ✅
- Can be rendered without floating point support (suitable for embedded) ✅
- Can be rendered efficiently with modern GPUs (suitable for PC, games) ✅
- Supports the following drawing primitives:
- points / circles ✅
- lines ✅
- triangles / polygons ✅
- Support drawing styles
- filled ✅
- outline ✅
- filled with outline ✅
- Support
- flat colors ✅
- bitmap textures ❌ (won't be included)
- linear gradients ✅
- line widths ✅
- Can use hinting to allow really small rendering (16²) ❌ (won't be included due to increased complexity)
The use cases here are listed to be considered while working on the specification and give the project a shape and boundary:
- Application Icons (large, fine details)
- Toolbar Icons (small, simple)
- Graphs (large structure, no details, text, think graphviz)
- Diagrams (colored surfaces, text, lines)
- Mangas/Comics (complex shapes, different line thickness)
This project is coming close to finishing Version 1 of the format, and the written spec is the last thing missing.
See the following documents:
See also this image to have a preview of what is already implemented:
- Create prototype implementation
- Finalize prototype
- Add smaller/bigger colors (16 bit, 30 bit)
- Add color space information (the color space is defined as sRGB)
- Add extended coordinate space (32 bit coordinates)
- Encode primary style in command, reduces command to 63 variants, allows bigger encoding
- Improve rendering
- Add anti-aliasing
- Add missing line width modifier for path rendering
- Improve rendering performance
- Move anti-aliased rendering into core library
- Implement textual representation
- Convert to
.tvg
- Convert to text
- Format text
- Convert to SVG
- Convert to
- Add auxiliary tools
- C Library frontend
- Build SDK
- Zig package
- Native packages
- dynamic macOS x86_64, aarch64
- static macOS x86_64, aarch64
- dynamic Windows x86_64
- static Windows x86_64 (TODO: Linker error with COMDAT when using VS)
- dynamic Linux x86_64, aarch64, arm
- static Linux x86_64, aarch64, arm
- Wasm Polyfill
- Improve website
- Add manual to tools
- Add
tiger.tvg
example file - Add
comic.tvg
example file - Add
charts.tvg
example file (pie, line and bar chart) - Add
app-icon.tvg
example file - Add
graph.tvg
example file - Add text file spec/examples
- Fix polyfill (change CI)
- Benchmark Suite
- File Size (SVG vs. TinyVG)
- Update final benchmark
- Sort github issues
- Write specification
- Review specification
- Release!
- Lock the specification into Version 1.
- Convert from SVG (via external tool)
- SVG
<ellipse>
- SVG
- (Fill|Draw|Fill Outlined) Ellipse/Circle opcode
- Smooth Bezier (via mirror behaviour)
- Inkscape Plugin
- library/sdk feature: convert TinyVG to draw lists/commands
- CSS Gradients
- Radial and conic gradients can be used for nice 3D shading
- Previous Work: TurtleFont is a pure line-drawing vector format
- SVG Path Editor, a tool to easily design or inspect SVG paths