mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-25 18:56:35 +11:00
Render strokes
As of this point, it mostly renders stroke outlines for tiger. Some dropouts are because the scan in the elements pass doesn't do lookback yet, others are probably a bug.
This commit is contained in:
parent
1240da3870
commit
868b0320a4
5 changed files with 52 additions and 8 deletions
|
@ -57,6 +57,26 @@ void alloc_cmd(inout CmdRef cmd_ref, inout uint cmd_limit) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Ensure that there is space to encode a segment.
|
||||||
|
void alloc_chunk(inout uint chunk_n_segs, inout SegChunkRef seg_chunk_ref,
|
||||||
|
inout SegChunkRef first_seg_chunk, inout uint seg_limit)
|
||||||
|
{
|
||||||
|
// TODO: Reduce divergence of atomic alloc?
|
||||||
|
if (chunk_n_segs == 0) {
|
||||||
|
if (seg_chunk_ref.offset + 40 > seg_limit) {
|
||||||
|
seg_chunk_ref.offset = atomicAdd(alloc, SEG_CHUNK_ALLOC);
|
||||||
|
seg_limit = seg_chunk_ref.offset + SEG_CHUNK_ALLOC - Segment_size;
|
||||||
|
}
|
||||||
|
first_seg_chunk = seg_chunk_ref;
|
||||||
|
} else if (seg_chunk_ref.offset + SegChunk_size + Segment_size * chunk_n_segs > seg_limit) {
|
||||||
|
uint new_chunk_ref = atomicAdd(alloc, SEG_CHUNK_ALLOC);
|
||||||
|
seg_limit = new_chunk_ref + SEG_CHUNK_ALLOC - Segment_size;
|
||||||
|
SegChunk_write(seg_chunk_ref, SegChunk(chunk_n_segs, SegChunkRef(new_chunk_ref)));
|
||||||
|
seg_chunk_ref.offset = new_chunk_ref;
|
||||||
|
chunk_n_segs = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
// Could use either linear or 2d layouts for both dispatch and
|
// Could use either linear or 2d layouts for both dispatch and
|
||||||
// invocations within the workgroup. We'll use variables to abstract.
|
// invocations within the workgroup. We'll use variables to abstract.
|
||||||
|
@ -71,6 +91,12 @@ void main() {
|
||||||
CmdRef cmd_ref = CmdRef(tile_ix * PTCL_INITIAL_ALLOC);
|
CmdRef cmd_ref = CmdRef(tile_ix * PTCL_INITIAL_ALLOC);
|
||||||
uint cmd_limit = cmd_ref.offset + PTCL_INITIAL_ALLOC - 2 * Cmd_size;
|
uint cmd_limit = cmd_ref.offset + PTCL_INITIAL_ALLOC - 2 * Cmd_size;
|
||||||
|
|
||||||
|
// Allocation and management of segment output
|
||||||
|
SegChunkRef seg_chunk_ref = SegChunkRef(0);
|
||||||
|
SegChunkRef first_seg_chunk = SegChunkRef(0);
|
||||||
|
uint seg_limit = 0;
|
||||||
|
uint chunk_n_segs = 0;
|
||||||
|
|
||||||
uint wr_ix = 0;
|
uint wr_ix = 0;
|
||||||
uint rd_ix = 0;
|
uint rd_ix = 0;
|
||||||
uint first_el;
|
uint first_el;
|
||||||
|
@ -216,13 +242,30 @@ void main() {
|
||||||
tag = Annotated_tag(ref);
|
tag = Annotated_tag(ref);
|
||||||
|
|
||||||
switch (tag) {
|
switch (tag) {
|
||||||
|
case Annotated_Line:
|
||||||
|
AnnoLineSeg line = Annotated_Line_read(ref);
|
||||||
|
Segment seg = Segment(line.p0, line.p1);
|
||||||
|
alloc_chunk(chunk_n_segs, seg_chunk_ref, first_seg_chunk, seg_limit);
|
||||||
|
Segment_write(SegmentRef(seg_chunk_ref.offset + SegChunk_size + Segment_size * chunk_n_segs), seg);
|
||||||
|
chunk_n_segs++;
|
||||||
|
break;
|
||||||
case Annotated_Fill:
|
case Annotated_Fill:
|
||||||
|
chunk_n_segs = 0;
|
||||||
|
break;
|
||||||
case Annotated_Stroke:
|
case Annotated_Stroke:
|
||||||
// Note: we take advantage of the fact that fills and strokes
|
if (chunk_n_segs > 0) {
|
||||||
// have compatible layout.
|
AnnoStroke stroke = Annotated_Stroke_read(ref);
|
||||||
AnnoFill fill = Annotated_Fill_read(ref);
|
SegChunk_write(seg_chunk_ref, SegChunk(chunk_n_segs, SegChunkRef(0)));
|
||||||
alloc_cmd(cmd_ref, cmd_limit);
|
seg_chunk_ref.offset += SegChunk_size + Segment_size * chunk_n_segs;
|
||||||
Cmd_Solid_write(cmd_ref, CmdSolid(fill.rgba_color));
|
CmdStroke cmd_stroke;
|
||||||
|
cmd_stroke.seg_ref = first_seg_chunk.offset;
|
||||||
|
cmd_stroke.half_width = 0.5 * stroke.linewidth;
|
||||||
|
cmd_stroke.rgba_color = stroke.rgba_color;
|
||||||
|
alloc_cmd(cmd_ref, cmd_limit);
|
||||||
|
Cmd_Stroke_write(cmd_ref, cmd_stroke);
|
||||||
|
cmd_ref.offset += Cmd_size;
|
||||||
|
chunk_n_segs = 0;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -71,7 +71,7 @@ State map_element(ElementRef ref) {
|
||||||
c.bbox = vec4(0.0, 0.0, 0.0, 0.0);
|
c.bbox = vec4(0.0, 0.0, 0.0, 0.0);
|
||||||
c.mat = vec4(1.0, 0.0, 0.0, 1.0);
|
c.mat = vec4(1.0, 0.0, 0.0, 1.0);
|
||||||
c.translate = vec2(0.0, 0.0);
|
c.translate = vec2(0.0, 0.0);
|
||||||
c.linewidth = 0.0;
|
c.linewidth = 1.0; // TODO should be 0.0
|
||||||
c.flags = 0;
|
c.flags = 0;
|
||||||
switch (tag) {
|
switch (tag) {
|
||||||
case Element_Line:
|
case Element_Line:
|
||||||
|
@ -169,7 +169,7 @@ void main() {
|
||||||
exclusive.bbox = vec4(0.0, 0.0, 0.0, 0.0);
|
exclusive.bbox = vec4(0.0, 0.0, 0.0, 0.0);
|
||||||
exclusive.mat = vec4(1.0, 0.0, 0.0, 1.0);
|
exclusive.mat = vec4(1.0, 0.0, 0.0, 1.0);
|
||||||
exclusive.translate = vec2(0.0, 0.0);
|
exclusive.translate = vec2(0.0, 0.0);
|
||||||
exclusive.linewidth = 0.0;
|
exclusive.linewidth = 1.0; //TODO should be 0.0
|
||||||
exclusive.flags = 0;
|
exclusive.flags = 0;
|
||||||
// TODO: do decoupled look-back
|
// TODO: do decoupled look-back
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -61,7 +61,8 @@ impl PicoSvg {
|
||||||
for item in &self.items {
|
for item in &self.items {
|
||||||
match item {
|
match item {
|
||||||
Item::Fill(fill_item) => {
|
Item::Fill(fill_item) => {
|
||||||
rc.fill(&fill_item.path, &fill_item.color);
|
//rc.fill(&fill_item.path, &fill_item.color);
|
||||||
|
rc.stroke(&fill_item.path, &fill_item.color, 1.0);
|
||||||
}
|
}
|
||||||
Item::Stroke(stroke_item) => {
|
Item::Stroke(stroke_item) => {
|
||||||
rc.stroke(&stroke_item.path, &stroke_item.color, stroke_item.width);
|
rc.stroke(&stroke_item.path, &stroke_item.color, stroke_item.width);
|
||||||
|
|
Loading…
Add table
Reference in a new issue