mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-22 06:36:29 +01:00
renice x-fade rendering w/cairo-antialiasing
This commit is contained in:
parent
e06a7e60f0
commit
93fea9021e
2 changed files with 8 additions and 2 deletions
|
|
@ -189,11 +189,14 @@ Curve::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
|
||||||
window_space = item_to_window (Duple (samples[left].x, samples[left].y));
|
window_space = item_to_window (Duple (samples[left].x, samples[left].y));
|
||||||
context->move_to (window_space.x, window_space.y);
|
context->move_to (window_space.x, window_space.y);
|
||||||
Coord last_x = round(window_space.x);
|
Coord last_x = round(window_space.x);
|
||||||
|
Coord last_y = round(window_space.y);
|
||||||
for (uint32_t idx = left + 1; idx < right; ++idx) {
|
for (uint32_t idx = left + 1; idx < right; ++idx) {
|
||||||
window_space = item_to_window (Duple (samples[idx].x, samples[idx].y));
|
window_space = item_to_window (Duple (samples[idx].x, samples[idx].y));
|
||||||
if (last_x == round(window_space.x)) continue;
|
if (last_x == round(window_space.x)) continue;
|
||||||
|
if (last_y == round(window_space.y)) continue;
|
||||||
last_x = round(window_space.x);
|
last_x = round(window_space.x);
|
||||||
context->line_to (last_x - .5 , window_space.y);
|
last_y = round(window_space.y);
|
||||||
|
context->line_to (last_x - .5 , last_y + .5);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (curve_fill) {
|
switch (curve_fill) {
|
||||||
|
|
|
||||||
|
|
@ -165,11 +165,14 @@ XFadeCurve::get_path(Rect const & area, Cairo::RefPtr<Cairo::Context> context, C
|
||||||
window_space = item_to_window (Duple (c.samples[left].x, c.samples[left].y));
|
window_space = item_to_window (Duple (c.samples[left].x, c.samples[left].y));
|
||||||
context->move_to (window_space.x, window_space.y);
|
context->move_to (window_space.x, window_space.y);
|
||||||
Coord last_x = round(window_space.x);
|
Coord last_x = round(window_space.x);
|
||||||
|
Coord last_y = round(window_space.y);
|
||||||
for (uint32_t idx = left + 1; idx < right; ++idx) {
|
for (uint32_t idx = left + 1; idx < right; ++idx) {
|
||||||
window_space = item_to_window (Duple (c.samples[idx].x, c.samples[idx].y));
|
window_space = item_to_window (Duple (c.samples[idx].x, c.samples[idx].y));
|
||||||
if (last_x == round(window_space.x)) continue;
|
if (last_x == round(window_space.x)) continue;
|
||||||
|
if (last_y == round(window_space.y)) continue;
|
||||||
last_x = round(window_space.x);
|
last_x = round(window_space.x);
|
||||||
context->line_to (last_x - .5 , window_space.y);
|
last_y = round(window_space.y);
|
||||||
|
context->line_to (last_x - .5 , last_y + .5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return context->copy_path ();
|
return context->copy_path ();
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue