#javascript #css #canvas #цвета
На сайте мне необходима функция цветовой пипетки, то есть возможность скопировать цвет пикселя, который находится под курсором. Для этого я использую canvas и функцию ctx.getImageData и получаю массив с нужными цветами rgba. С помощью этого массива можно повторить цвет, в рамках самого Canvas, но если попытаться применить этот цвет на стили CSS, то цвет будет другой. Как я понимаю, между цветовой схемой Canvas и CSS существуют различия. Как построить JavaScript-функцию, которая бы устраняла эти различия? UPD: я создал небольшой пример. Там можно увидеть три элемента — широкий div, с цветом rgb(36,43,51), внутри которого находится элемент Canvas, на котором размещено изображение, состоящее из фона такого же цвета и белой полосы слева, и ниже него элемент img с тем же содержимым. Вы не увидите разницы между цветами div и img, потому что они одни и те же. Но изображение, отображаемое внутри Canvas имеет совсем другой цвет и заметно выделяется на общем фоне. Как я понимаю, использование функции ctx.getImageData показывает правильные цвета и для CSS, и для Canvas, но проблема в том, что все цвета внутри тега canvas искажаются.
Ответы
Ответ 1
Цветовые схемы не должны отличаться, если вы все делаете верно, приведу рабочий пример: let canvas = document.getElementById('canvas_id'), ctx = canvas.getContext('2d'), base_image = new Image(); //Изображение в base64 чтобы небыло ошибок с cross origin при вызове getImageData base_image.src = ""; base_image.onload = () => { canvas.width = base_image.width; canvas.height = base_image.height; ctx.drawImage(base_image, 0, 0); } //При наведении мышки на канвас будем менять цвет у DIV блока canvas.addEventListener('mousemove', event => { let x = event.pageX - canvas.offsetLeft, y = event.pageY - canvas.offsetTop, imgData = ctx.getImageData(x, y, 1, 1).data; document.querySelector('#color_div').style.backgroundColor = `rgba(${imgData[0]}, ${imgData[1]}, ${imgData[2]}, 1)`; });Все ровно так, как вы и описывали, в момент наведения мышки мы высчитываем ее x\y координаты относительно canvas, далее получаем по этим координатам imageData и получаем 4 значения соответствующих red,green,blue,aplha.color
Комментариев нет:
Отправить комментарий