mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-25 18:56:35 +11:00
tightly pack fine rasterizer commands
Reclaims the space waste from splitting fill mode commands from fill commands. For example, a CmdStroke + CmdColor use an extra tag word compared to the former combined CmdStroke. This change shaves off that one word. In the future, we can pack several command tags into one tag word, saving even more space. Fixes #66 Signed-off-by: Elias Naur <mail@eliasnaur.com>
This commit is contained in:
parent
8db77e180e
commit
f0127812eb
4 changed files with 22 additions and 9 deletions
|
@ -324,16 +324,18 @@ void main() {
|
||||||
if (tile.tile.offset != 0) {
|
if (tile.tile.offset != 0) {
|
||||||
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
||||||
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
||||||
|
cmd_ref.offset += 4 + CmdFill_size;
|
||||||
} else {
|
} else {
|
||||||
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
||||||
|
cmd_ref.offset += 4;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * fill.linewidth);
|
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * fill.linewidth);
|
||||||
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
||||||
|
cmd_ref.offset += 4 + CmdStroke_size;
|
||||||
}
|
}
|
||||||
cmd_ref.offset += Cmd_size;
|
|
||||||
Cmd_Color_write(cmd_alloc, cmd_ref, CmdColor(fill.rgba_color));
|
Cmd_Color_write(cmd_alloc, cmd_ref, CmdColor(fill.rgba_color));
|
||||||
cmd_ref.offset += Cmd_size;
|
cmd_ref.offset += 4 + CmdColor_size;
|
||||||
break;
|
break;
|
||||||
case Annotated_Image:
|
case Annotated_Image:
|
||||||
tile = Tile_read(read_tile_alloc(element_ref_ix), TileRef(sh_tile_base[element_ref_ix]
|
tile = Tile_read(read_tile_alloc(element_ref_ix), TileRef(sh_tile_base[element_ref_ix]
|
||||||
|
@ -346,16 +348,18 @@ void main() {
|
||||||
if (tile.tile.offset != 0) {
|
if (tile.tile.offset != 0) {
|
||||||
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
||||||
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
||||||
|
cmd_ref.offset += 4 + CmdFill_size;
|
||||||
} else {
|
} else {
|
||||||
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
||||||
|
cmd_ref.offset += 4;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * fill_img.linewidth);
|
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * fill_img.linewidth);
|
||||||
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
||||||
|
cmd_ref.offset += 4 + CmdStroke_size;
|
||||||
}
|
}
|
||||||
cmd_ref.offset += Cmd_size;
|
|
||||||
Cmd_Image_write(cmd_alloc, cmd_ref, CmdImage(fill_img.index, fill_img.offset));
|
Cmd_Image_write(cmd_alloc, cmd_ref, CmdImage(fill_img.index, fill_img.offset));
|
||||||
cmd_ref.offset += Cmd_size;
|
cmd_ref.offset += 4 + CmdImage_size;
|
||||||
break;
|
break;
|
||||||
case Annotated_BeginClip:
|
case Annotated_BeginClip:
|
||||||
tile = Tile_read(read_tile_alloc(element_ref_ix), TileRef(sh_tile_base[element_ref_ix]
|
tile = Tile_read(read_tile_alloc(element_ref_ix), TileRef(sh_tile_base[element_ref_ix]
|
||||||
|
@ -373,18 +377,20 @@ void main() {
|
||||||
if (tile.tile.offset != 0) {
|
if (tile.tile.offset != 0) {
|
||||||
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
CmdFill cmd_fill = CmdFill(tile.tile.offset, tile.backdrop);
|
||||||
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
Cmd_Fill_write(cmd_alloc, cmd_ref, cmd_fill);
|
||||||
|
cmd_ref.offset += 4 + CmdFill_size;
|
||||||
} else {
|
} else {
|
||||||
// TODO: here is where a bunch of optimization magic should happen
|
// TODO: here is where a bunch of optimization magic should happen
|
||||||
float alpha = tile.backdrop == 0 ? 0.0 : 1.0;
|
float alpha = tile.backdrop == 0 ? 0.0 : 1.0;
|
||||||
Cmd_Alpha_write(cmd_alloc, cmd_ref, CmdAlpha(alpha));
|
Cmd_Alpha_write(cmd_alloc, cmd_ref, CmdAlpha(alpha));
|
||||||
|
cmd_ref.offset += 4 + CmdAlpha_size;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * begin_clip.linewidth);
|
CmdStroke cmd_stroke = CmdStroke(tile.tile.offset, 0.5 * begin_clip.linewidth);
|
||||||
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
Cmd_Stroke_write(cmd_alloc, cmd_ref, cmd_stroke);
|
||||||
|
cmd_ref.offset += 4 + CmdStroke_size;
|
||||||
}
|
}
|
||||||
cmd_ref.offset += Cmd_size;
|
|
||||||
Cmd_BeginClip_write(cmd_alloc, cmd_ref);
|
Cmd_BeginClip_write(cmd_alloc, cmd_ref);
|
||||||
cmd_ref.offset += Cmd_size;
|
cmd_ref.offset += 4;
|
||||||
if (clip_depth < 32) {
|
if (clip_depth < 32) {
|
||||||
clip_one_mask &= ~(1 << clip_depth);
|
clip_one_mask &= ~(1 << clip_depth);
|
||||||
}
|
}
|
||||||
|
@ -398,9 +404,9 @@ void main() {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
Cmd_Solid_write(cmd_alloc, cmd_ref);
|
||||||
cmd_ref.offset += Cmd_size;
|
cmd_ref.offset += 4;
|
||||||
Cmd_EndClip_write(cmd_alloc, cmd_ref);
|
Cmd_EndClip_write(cmd_alloc, cmd_ref);
|
||||||
cmd_ref.offset += Cmd_size;
|
cmd_ref.offset += 4;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
|
@ -153,6 +153,7 @@ void main() {
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
area[k] = clamp(stroke.half_width + 0.5 - df[k], 0.0, 1.0);
|
area[k] = clamp(stroke.half_width + 0.5 - df[k], 0.0, 1.0);
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4 + CmdStroke_size;
|
||||||
break;
|
break;
|
||||||
case Cmd_Fill:
|
case Cmd_Fill:
|
||||||
CmdFill fill = Cmd_Fill_read(cmd_alloc, cmd_ref);
|
CmdFill fill = Cmd_Fill_read(cmd_alloc, cmd_ref);
|
||||||
|
@ -184,17 +185,20 @@ void main() {
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
area[k] = min(abs(area[k]), 1.0);
|
area[k] = min(abs(area[k]), 1.0);
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4 + CmdFill_size;
|
||||||
break;
|
break;
|
||||||
case Cmd_Solid:
|
case Cmd_Solid:
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
area[k] = 1.0;
|
area[k] = 1.0;
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4;
|
||||||
break;
|
break;
|
||||||
case Cmd_Alpha:
|
case Cmd_Alpha:
|
||||||
CmdAlpha alpha = Cmd_Alpha_read(cmd_alloc, cmd_ref);
|
CmdAlpha alpha = Cmd_Alpha_read(cmd_alloc, cmd_ref);
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
area[k] = alpha.alpha;
|
area[k] = alpha.alpha;
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4 + CmdAlpha_size;
|
||||||
break;
|
break;
|
||||||
case Cmd_Color:
|
case Cmd_Color:
|
||||||
CmdColor color = Cmd_Color_read(cmd_alloc, cmd_ref);
|
CmdColor color = Cmd_Color_read(cmd_alloc, cmd_ref);
|
||||||
|
@ -202,6 +206,7 @@ void main() {
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
rgb[k] = mix(rgb[k], fg_rgba.rgb, mask[k] * area[k] * fg_rgba.a);
|
rgb[k] = mix(rgb[k], fg_rgba.rgb, mask[k] * area[k] * fg_rgba.a);
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4 + CmdColor_size;
|
||||||
break;
|
break;
|
||||||
case Cmd_Image:
|
case Cmd_Image:
|
||||||
CmdImage fill_img = Cmd_Image_read(cmd_alloc, cmd_ref);
|
CmdImage fill_img = Cmd_Image_read(cmd_alloc, cmd_ref);
|
||||||
|
@ -209,6 +214,7 @@ void main() {
|
||||||
for (uint k = 0; k < CHUNK; k++) {
|
for (uint k = 0; k < CHUNK; k++) {
|
||||||
rgb[k] = mix(rgb[k], rgba[k].rgb, mask[k] * area[k] * rgba[k].a);
|
rgb[k] = mix(rgb[k], rgba[k].rgb, mask[k] * area[k] * rgba[k].a);
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4 + CmdImage_size;
|
||||||
break;
|
break;
|
||||||
case Cmd_BeginClip:
|
case Cmd_BeginClip:
|
||||||
uint blend_slot = blend_sp % BLEND_STACK_SIZE;
|
uint blend_slot = blend_sp % BLEND_STACK_SIZE;
|
||||||
|
@ -229,6 +235,7 @@ void main() {
|
||||||
blend_stack[blend_slot][k] = packsRGB(vec4(rgb[k], clamp(abs(area[k]), 0.0, 1.0)));
|
blend_stack[blend_slot][k] = packsRGB(vec4(rgb[k], clamp(abs(area[k]), 0.0, 1.0)));
|
||||||
}
|
}
|
||||||
blend_sp++;
|
blend_sp++;
|
||||||
|
cmd_ref.offset += 4;
|
||||||
break;
|
break;
|
||||||
case Cmd_EndClip:
|
case Cmd_EndClip:
|
||||||
blend_slot = (blend_sp - 1) % BLEND_STACK_SIZE;
|
blend_slot = (blend_sp - 1) % BLEND_STACK_SIZE;
|
||||||
|
@ -245,13 +252,13 @@ void main() {
|
||||||
vec4 rgba = unpacksRGB(blend_stack[blend_slot][k]);
|
vec4 rgba = unpacksRGB(blend_stack[blend_slot][k]);
|
||||||
rgb[k] = mix(rgba.rgb, rgb[k], area[k] * rgba.a);
|
rgb[k] = mix(rgba.rgb, rgb[k], area[k] * rgba.a);
|
||||||
}
|
}
|
||||||
|
cmd_ref.offset += 4;
|
||||||
break;
|
break;
|
||||||
case Cmd_Jump:
|
case Cmd_Jump:
|
||||||
cmd_ref = CmdRef(Cmd_Jump_read(cmd_alloc, cmd_ref).new_ref);
|
cmd_ref = CmdRef(Cmd_Jump_read(cmd_alloc, cmd_ref).new_ref);
|
||||||
cmd_alloc.offset = cmd_ref.offset;
|
cmd_alloc.offset = cmd_ref.offset;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
cmd_ref.offset += Cmd_size;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (uint i = 0; i < CHUNK; i++) {
|
for (uint i = 0; i < CHUNK; i++) {
|
||||||
|
|
Binary file not shown.
Loading…
Add table
Reference in a new issue