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

02.12.13

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

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
бсГармонияЦвета4.epf
.epf 79,09Kb
25
25 Скачать (1 SM) Купить за 1 850 руб.

Продолжая тему интересных проектов с использованием 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 Управляемые формы 1C:Бухгалтерия Платные (руб)

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

5000 руб.

14.01.2016    55630    17    23    

43

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

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

6000 руб.

16.01.2015    63946    45    60    

83

Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

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

2400 руб.

29.06.2020    19937    28    6    

44

Работа с интерфейсом Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Это инструкция по дизайну форм в среде 1С. Гайд охватывает рекомендации и стандарты для оптимизации пользовательского интерфейса. В гайде содержатся указания по использованию элементов интерфейса, включая как основные, так и продвинутые аспекты. Предоставляются также примеры и антипримеры для наглядного понимания принципов дизайна

20.08.2024    23482    mrXoxot    44    

130

Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    12033    smielka    37    

105

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

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

27.12.2023    18361    1228    elcoan    53    

125

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    12890    167    acces969    31    

126

Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

1 стартмани

05.07.2022    7993    kalyaka    6    

33
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. pfihr 375 02.12.13 11:05 Сейчас в теме
Обновление версии обработки - теперь расчет палитры идет по часовой стрелке до 360 градусов (раньше был только до 180).
2. TheGrr 142 02.12.13 14:43 Сейчас в теме
3. Serj1C 483 03.12.13 12:37 Сейчас в теме
не зачет. Как внедрять в свои решения?
Вся функциональность в ява-скрипте.
Тупо обертка в управляемую форму.
4. pfihr 375 03.12.13 14:41 Сейчас в теме
(3) Serj1C, так и внедрять, как функциональность в яваскрипте.
Можно перенести все процедуры по рассчету цветовых пространств в код 1С.
Но я пока этим не занимался, и не собираюсь.
5. sikuda 678 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 будет все более востребован прогрессивными программистами.
Оставьте свое сообщение