Bring to front в Paper.js

Здравствуйте. Никак не могу разобраться как правильно поместить элемент поверх всех элементов. Сейчас это сделано так (подсмотрено в примере от разработчиков http://paperjs.org/examples/hit-testing/):

function onMouseMove(event) {
    var hitResult = project.hitTest(event.point, {
        fill: true
    });
    project.activeLayer.strokeColor = conf.gridLineColors;
    if (hitResult && hitResult.item) {
        hitResult.item.strokeColor = "green";
        project.activeLayer.addChild(hitResult.item);
    }
}

Но блин, тут же нет никакого «перемещения», а добавляется новый потомок в активный слой (и я не понимаю, куда девается текущий элемент). Я плохо знаком с canvas и javascript и делаю это в академических целях, но разве, если очень долго исполнять данный скрипт, не наберется ли такое большое количество объектов в слое, что все начнет тормозить? Как правильно или так и должно быть?
  • Вопрос задан
  • 3238 просмотров
Решения вопроса 1
KEKSOV
@KEKSOV
Если залезть в исходники paper.js, то там видно, что addChild вызывает insertChild, который сначала удаляет объект из списка своих детей, а потом добавляет этот же объект в этот список, а потом вызывает redraw. Очевидно, что последний объект будет отрисован поверх всех остальных.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы
01 мая 2024, в 00:29
2000 руб./за проект
01 мая 2024, в 00:20
15000 руб./за проект
30 апр. 2024, в 23:39
3000 руб./за проект