Генератор палитр цветов CIE Lab (Lch) - линейных с точки зрения человеческого восприятия ++ Raphael сolorpicker

02.12.13

Разработка - Работа с интерфейсом

Генератор палитр + пипетка. Для цветового оформления данных в цветовом пространстве CIE Lch (полярное CIE Lab). Особенностью данного цветового пространства является его отличная адаптация к человеческому восприятию, гораздо более точная, чем RGB. CIE Lch используется для автоматической генерации градиентов или последовательности цветов для представления большого количества данных, приятного человеческому глазу. Используется в таких web-проектах, как, например, d3js, Adobe Kuler и т.п.

Скачать исходный код

Наименование Файл Версия Размер
бсГармонияЦвета4.epf
.epf 79,09Kb
24
.epf 79,09Kb 24 Скачать

Продолжая тему интересных проектов с использованием javascript, представляю сразу два-в-одном - "пипетка для выбора цвета" и "генератор палитр CIE Lab (Lch)".

Сгенерированная палитра отображается в табличном документе, что позволяет Вам простым копированием использовать эту палитру в своих макетах.

Обработка создана на основе скриптов http://labs.adamluptak.com/javascript-color-blending/

 

Зачем это нужно?

 

Каждый, кто сталкивается с задачами автоматического оформления цветом большого количества разнообразных данных, мечтает об автоматической генерации гармонично воспринимаемых пользователем комбинаций цветов. Первым шагом к решению этой задачи является генерация цветов в цветовом пространстве CIE Lab (Lch). Данное цветовое пространство разрабатывалось таким образом, чтобы расстояние между цветами было идентично человеческому восприятию. Цветовое пространство RGB не отвечает этому требованию, что мы часто наблюдали на заре зарождения Интернета (когда html страницы пестрили линейно вычисленными цветами RGB).

В настоящее время, кроме CIE Lab, существуют более совершенные модели CIE CAM и NCS, но они пока не применяется в промышленных масштабах, в отличие от CIE Lab.

В модели CIE Lab осуществляет внутреннюю программную обработку изображений такой известный программный продукт, как Adobe Photoshop, для которого это пространство является базовым (в него происходит преобразование из RGB или CMYK, затем обрабатывается, затем преобразовывается обратно). Модель CIE Lab (HCL, Lch) используется в проекте d3js (визуализация многомерных связанных данных) для автоматического построения палитр цветов серий.

Рассмотрим проблему с RGB более подробно - почему RGB нам не подходит.

Обычный переход между цветами RGB описывается следующим алгоритмом линейной интерполяции:

R' = R1 + е * (R2 - R1) 

G' = G1 + е * (G2 - G1) 

В' = B1 + е * (В2 - В1)

где e - позиция отрезка в диапазоне от 0 до 1.

Такая линейная RGB интерполяция выглядит не очень приятно, что можно увидеть на следующих примерах:

RGB blending 

или более наглядно от синего к желтому

Обратите внимание на последнем изображении в центре палитры - серый цвет.

Если мы измерим насыщенность этих цветов, например, в Photoshop, то получим следующую последовательность:

 [1.0] [0.8] [0.5] [0.0] [0.5] [0.8] [1.0]

 Таким же образом будет изменяться и яркость!

Можно попытаться сохранить яркость и насыщенность, используя полярное представление RGB в виде HSB (HSL), путем изменения угла Hue. Но в этом случае, у нас будет ограничен выбор конечного цвета - ведь у него должны совпасть и яркость, и насыщенность с первоначальным цветом. Поэтому, для перехода между цветами нам придется использовать линейную интерполяцию.

Попробуем провести линейную интерполяцию между двумя цветами HSB по классическому алгоритму:

d = h2 - h1
if (h1 > h2) then swap(h1, h2), d = -d, f = 1 - f
if (d > 180) then h1 = h1 + 360, h = ( h1 + f * (h2 - h1) ) mod 360
if (d

 где h изменяется в диапазоне от 0 до 360 градусов.

Попробовав переход от синего к желтому, получим следующую последовательность:

Математически все ровно, насыщенность и яркость у всех цветов в RGB вроде бы одинаковая. Но как воспринимает эти цвета человеческий глаз? Посмотрите сами на эту картинку еще раз. Синий гораздо темнее желтого, cyan - ярче всех, а зеленые цвета очень близки (виден резкий переход к cyan).

Более полное описание недостатков пространства RGB можно прочитать в этой статье википедии: http://en.wikipedia.org/wiki/HSL_and_HSV#Disadvantages

Теперь посмотрим, как будет выглядеть такой же градиент в пространстве CIE Lab (Lch):

 

Давайте подведем итоги. На следующих изображения показаны отличия градиентов в моделях RGB (верхняя строка), HSB (средняя строка) и CIE Lab (Lch) (нижняя строка).

 

Выбор очевиден.

java script javascript color colorpicker цвет выбор цвета градиент Lab CIELab CIELch HCL пипетка палитра

См. также

Богатый редактор картинок, хранимых в базе, с возможностью РИСОВАНИЯ. Редактор внешних файлов картинок. Объект, расширяющий возможности работы с картинками из встроенного языка (Три в одном) + Обработка «Стандартизация картинок»

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Обработка предназначена для редактирования картинок в режиме «Предприятие», с возможностью РИСОВАТЬ на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Также обработка может быть использована из встроенного языка как объект для редактирования картинок. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Данная обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6000 руб.

16.01.2015    61938    43    59    

80

[Расширения] Динамическое управление видимостью и доступностью элементов форм (УФ) (8.3.6+)

Работа с интерфейсом Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Механизм «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

5000 руб.

14.01.2016    54566    16    21    

42

Управление дашбордами

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    16821    21    4    

35

Новогоднее оформление для 1С

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    10993    756    elcoan    45    

106

Конструктор HTML, CSS и javascript

Инструментарий разработчика Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Подходит для создания web-страниц для замены управляемых форм 1С, красивых отчетов, интерфейса мобильного приложения на платформе 1С и для простых страниц веб-сайтов.

2 стартмани

10.04.2023    9792    153    acces969    31    

119

Модель состояния для MVC

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    3841    kalyaka    4    

29

Табло очереди заказов на экран телевизора

WEB-интеграция Работа с интерфейсом Платформа 1С v8.3 1С:Розница 2 Платные (руб)

Связка из веб-приложения и расширения для 1С: Розница 2.3.

3600 руб.

29.04.2022    12200    1    5    

10
Комментарии
Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. pfihr 374 02.12.13 11:05 Сейчас в теме
Обновление версии обработки - теперь расчет палитры идет по часовой стрелке до 360 градусов (раньше был только до 180).
2. TheGrr 141 02.12.13 14:43 Сейчас в теме
3. Serj1C 483 03.12.13 12:37 Сейчас в теме
не зачет. Как внедрять в свои решения?
Вся функциональность в ява-скрипте.
Тупо обертка в управляемую форму.
4. pfihr 374 03.12.13 14:41 Сейчас в теме
(3) Serj1C, так и внедрять, как функциональность в яваскрипте.
Можно перенести все процедуры по рассчету цветовых пространств в код 1С.
Но я пока этим не занимался, и не собираюсь.
5. sikuda 673 03.12.13 16:39 Сейчас в теме
(3) Serj1C, Легко. Вставить в макет(сжатый js). В 1с оставить только результат. Он там и нужен.
6. stanru1 91 04.12.13 09:06 Сейчас в теме
Спасибо и за статью, и за идею! То, о чем я давно мечтал - красивые сочетания цветов!
7. karakozov 04.12.13 10:53 Сейчас в теме
Благодарность за статью, решение не для всех, но кому то будет несомненно полезно.
8. Den_D 54 15.10.15 10:57 Сейчас в теме
Интересный подход. На сколько я понимаю, что бы эффективно работать под веб клиентом все чаще решения уходят в сторону HTML-полей на форме и соответственно весь их функционал включая JS будет все более востребован прогрессивными программистами.
Оставьте свое сообщение