Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Canvas. 2d-контекст. Z-буфер. (https://javascript.ru/forum/misc/69392-canvas-2d-kontekst-z-bufer.html)

laimas 19.06.2017 18:44

Цитата:

Сообщение от Alexandroppolus
ну, если нарисовать непрозрачную хрень поверх чего-то уже нарисованного, то выходит, это что-то рисовали зря.

Это можно определять режимом наложения - globalCompositeOperation.

laimas 19.06.2017 18:55

Цитата:

Сообщение от Rise
да крутая штука

ну в общем полезная при наложении - https://developer.mozilla.org/ru/doc...ositeOperation ;)

Alexandroppolus 19.06.2017 18:57

Цитата:

Сообщение от laimas
globalCompositeOperation

он тут вообще не причем. Его надо оставить как есть, "source-over". Автору топика интересно, как это всё оптимизировать, и не рисовать те части нижних слоев, которые потом закроются верхними.

laimas 19.06.2017 19:06

Цитата:

Сообщение от Alexandroppolus
он тут вообще не причем. Его надо оставить как есть, "source-over".

Цитата:

Сообщение от Валес
И не хочу отрисовывать сначала фон, потом класть на него детали, а на эти детали ещё что-то рисовать последовательно.

Деталь, это может быть 10х10, которая накладывается по указанной координате. А вот как эти детали должны взаимодействовать на холсте, это уже как раз режимом можно определить.

MallSerg 19.06.2017 20:00

Цитата:

Сообщение от Rise (Сообщение 455944)
Alexandroppolus, но есть подозрение что канвас перерисовывается полностью каждый раз на любое изменение)

Это зависит от режима(контекста) в котором поступают команды на отрисовку но если вкратце то команды сначала накапливаются и только после этого рисуются и то далеко не всегда.
Перекрытые регионы перерисовыватся не будут.

Люди с зарплатой в 50к $ из крупнейщих IT корпораций в течении десятков лет оптимизируют рендер браузера и канваса в том числе (это про браузерными войны). И тут приходит автор топика и реально думает что у него на скриптовом языке в браузере получится лучше. 99% таких оптимизаций приводят к обратному эффекту.

Если автор действительно хочет оптимизировать то ему нужно начать с отладчика и поиска узких мест.

Оптимизация без причины - признак дурачины.

Alexandroppolus 19.06.2017 21:02

Цитата:

Сообщение от Rise
Но при globalCompositeOperation обычно в обратном порядке рисуют, т.е. сначало детали, затем фон (source-out) за вычетом деталей

Вот рисование "сначала фон, потом картинка" - https://jsfiddle.net/3gg1j09y/
А вот - как ты предложил - https://jsfiddle.net/ojxtsode/


Часовой пояс GMT +3, время: 21:32.