Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tyt2y3/vaserenderer
VASE renderer is a polyline and curve renderer on OpenGL.
https://github.com/tyt2y3/vaserenderer
Last synced: 5 days ago
JSON representation
VASE renderer is a polyline and curve renderer on OpenGL.
- Host: GitHub
- URL: https://github.com/tyt2y3/vaserenderer
- Owner: tyt2y3
- License: bsd-3-clause
- Created: 2013-07-07T11:15:29.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2023-11-05T12:32:58.000Z (about 1 year ago)
- Last Synced: 2025-01-13T23:09:04.551Z (12 days ago)
- Language: C++
- Homepage: tyt2y3.github.io/vaser-web
- Size: 7.73 MB
- Stars: 345
- Watchers: 21
- Forks: 39
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- AwesomeCppGameDev - vaserenderer
README
> This project was started many, many years ago. The C++ implementation is a pre-OpenGL 3 relic. The C# implementation is more "modern" and uses fragment shader, which is better.
VASE renderer
About
VASE renderer version 0.42 (VASEr 0.42) is a tessellating library for rendering high quality 2D vector graphics. It is an attempt to address unconventional features in 2d graphics. It is intended for OpenGL 1.1+, but much of the code is API independent C++.
Unconventional features
Per vertex coloring and weighting
VASEr revolutionarily lets you control the color and thickness at each vertex for a polyline. This feature is unseen on any commonly available graphics library.
Linear gradient along curve
A similar feature is also available to curves. Because there are so many vertices on a curve that it is impractical to specify data on each point, VASEr lets you define a linear gradient of color and thickness along the length of a curve, giving you two more degrees of freedom.
Feathering for brush like effects
VASEr must use an outsetting polygon anyway, so it is free (as in computational cost) to scale it up, and it is called feathering in VASEr.
Premium quality anti aliasing
From left to right: raw polygon without anti aliasing,
anti aliased with outset fade polygon,
exaggerated outsetting polygon with wireframe,
same as left without wireframe.
Outset-fade polygon is the high quality, fast, portable, consistent and hassle free technique for anti aliasing. The difficulties are to calibrate the outsetting distance to achieve believable result and to perform tedious tessellation. Luckily VASEr did this for you.
Below are line rendering comparison between VASEr and Cairo and AGG:
VASEr
Cairo
AGG
There is small difference, but it is more a matter of taste than correctness. In terms of clarity VASEr is like between Cairo and AGG, and VASEr is the most crisp among the three. VASEr even do pixel alignment to 1px completely horizontal or vertical lines.
The flaw is, because the outsetting distance is resolution dependent, while the triangulation is unaffected under rotational transformation, fidelity will be lost under scale and sheer.
Articles
+ Drawing polylines by tessellation.
+ Drawing nearly perfect 2D line segments in OpenGLRelated Work
- If you only need uniform color & width and only wanted a clean mesh, you can try out Polyline2D.
Acknowledgement
Bezier curve subdivision code is extracted from Anti-Grain Geometry V2.4 by Maxim Shemanarev (McSeem).
The open-source graphics library AGG inspired me a lot during my teenage.