Генератор палитр цветов 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 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

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

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

Продолжая тему интересных проектов с использованием 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С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

31720 руб.

27.03.2025    85881    61    42    

72

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

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

5246 руб.

29.06.2020    25176    34    6    

53

Консолидация данных Работа с интерфейсом Программист Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 1C:ERP Узбекистан Беларусь Кыргызстан Россия Казахстан Платные (руб)

Знакомая ситуация? Пользователи, особенно менеджеры, уверены: отборов много не бывает. Идут пожелания добавить в форму списка еще один быстрый фильтр, еще два, еще пять... В итоге интерфейс превращается в нагромождение полей отбора, а потребность в «самом главном» отборе, который «вот прямо сейчас нужен», все равно не закрыта. Универсальное расширение, которое решает эту проблему элегантно и технологично. С его помощью в любую форму списка можно легко добавить панель настраиваемых кнопок-закладок, каждая из которых применяет сложный фильтр-запрос, а так же показывает актуальное количество элементов в реальном времени.

6088 руб.

17.10.2025    2435    3    0    

2

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36600 руб.

28.08.2025    8450    2    2    

6

Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

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

20.08.2024    51280    mrXoxot    44    

139

Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

27.05.2024    26997    smielka    39    

117

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

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

1 стартмани

10.04.2023    17845    182    acces969    31    

132

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

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

12.08.2022    13347    top_1c    39    

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