fune/third_party/rust/wpf-gpu-raster/README.md
Lee Salzman 2ad13433da Bug 1801307 - Remember last interval to speed up insertion search. r=jrmuizel
This modifies AddInterval in wpf-gpu-raster to try to remember the last interval
it searched for so that it doesn't have to search the entire interval list for
every interval added. This should take us down from O(n^2) to closer to O(n) for
this phase of rasterization.

Differential Revision: https://phabricator.services.mozilla.com/D163795
2022-12-05 04:40:45 +00:00

22 lines
912 B
Markdown

This is a port of the WPF hardware rasterizer code to Rust. That
rasterizer is predecessor to the Direct2D rasterizer. Direct2D still
uses a similar technique when run on hardware that does not support
Target Independent Rasterization.
Design
======
The general algorithm used for rasterization is a vertical sweep of
the shape that maintains an active edge list. The sweep is done
at a sub-scanline resolution and results in either:
1. Sub-scanlines being combined in the coverage buffer and output
as "complex scans". These are emitted as lines constructed out
of triangle strips.
2. Simple trapezoids being recognized in the active edge list
and output using a faster simple trapezoid path.
Bezier flattening is done using an approach that uses forward differencing
of the error metric to compute a flattened version that would match a traditional
adaptive recursive flattening.