Страницы

Поиск по вопросам

суббота, 11 января 2020 г.

Javascript Canvas и CSS цвета

#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)`; });
color
Все ровно так, как вы и описывали, в момент наведения мышки мы высчитываем ее x\y координаты относительно canvas, далее получаем по этим координатам imageData и получаем 4 значения соответствующих red,green,blue,aplha.

Комментариев нет:

Отправить комментарий