Как плавно стереть линию на канвасе?

Привет.
У меня есть скрипт, который рисует линии при движении мыши.
Он работает следующим образом:
При событии mousemove фиксируются точки, через которые прошел курсор и они заносятся в массив.
Далее в цикле анимации между этими точками рисуются линии.
Проблема в том, что если быстро двигать мышкой, то будет зафиксировано мало точек и некоторые линии будут очень длинными. И если просто удалять точку из массива через this.points.shift(), то никакого плавного удаления не будет, эта большая линия просто резко исчезнет.
Я решил пойти таким путем:
Смещать последнюю точку в сторону следующей точки. И когда она дойдет до нее просто удалить ее из массива и тогда не будет видно никаких резких удалений. Вроде бы я реализовал эту идею, но почему-то иногда происходят резкие глюки, мерцания (скриншот внизу). Как можно это исправить? Также я хотел бы реализовать эффект плавного перехода с прозрачностью, чтобы она уменьшалась в хвосте, как это можно реализовать?
Не пытайтесь полностью изменить мой код. Это лишь кусок из моего проекта, я его специально упростил для вас, чтобы никто не терял время и смог быстрее вникнуть в код. Поэтому мне нужно, чтобы был массив точек, мне нужно использовать requestAnimationFrame и т. д.

Код: https://jsfiddle.net/0f62oegx

615ec05478df3388214599.png
  • Вопрос задан
  • 255 просмотров
Решения вопроса 1
twobomb
@twobomb
Метод shift() удаляет первый элемент из массива и возвращает его значение. Этот метод изменяет длину массива.

Также упростил немного
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 11:53
3000 руб./за проект
22 нояб. 2024, в 11:51
20000 руб./за проект
22 нояб. 2024, в 11:50
200000 руб./за проект