Как организовать терминальные цветовые последовательности в удобные для восприятия человеком цветовые градации?

Как организовать терминальные цветовые последовательности в удобные для восприятия человеком цветовые градации?

Я создал этот скрипт для отображения цветов терминала, но расположение цветов мне непонятно.

Вот скрипт, который довольно прост. Он просто увеличивает цветовой код для палитры из 256 цветов и располагает их в ряды по 6.

#!/bin/env python3

def fg(n):
    assert -1 < n < 256, f"{n} value outside (0,255)"
    return f"\x1b[38;5;{n}m"

def bg(n):
    assert -1 < n < 256, f"{n} value outside (0,255)"
    return f"\x1b[48;5;{n}m"
    
RESET = "\x1b[0m"

print("The 1st 16 colors")
for i in range(0,16):
    print(f"{fg(0)}{bg(i)}[{i:03d}]{bg(0)}" , end = RESET)

print("\nthe rest\n")
for i in range(16,255,6):
    for j in range(0,6):
        print(f"{fg(0)}{bg(i + j)}[{i + j:03d}]", end = RESET)
    print()

Который выводит эту сетку, и я думаю, что она могла бы быть лучше.

введите описание изображения здесь

Но я хотел бы знать, как я могу организовать это в более человеческом стиле. Что-то похожее на эту сетку ниже, где цвета являются градациями одного и того же оттенка. Есть ли какой-то процесс, чтобы сделать это?

введите описание изображения здесь

Целью этого является возможность иметь функцию градации цвета, которую можно применять к кодированию терминалов.

решение1

На основе комментария @DavidPostill я понял, что смотрю на слои цветового блока RGB. Так что этот ответ частично отвечает на мой собственный вопрос. Однако мне пришлось выбирать значения каждого оттенка в несколько списков, которые я бы предпочел инкапсулировать в функцию, которая могла бы брать 2 цвета в блоке и обрабатывать тона между ними.

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

введите описание изображения здесь

Я понял, что рисование линии от любого числа к любому другому числу даст вам цветовой градиент. Противоположный угол к белому (231) будет черным (16).

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

введите описание изображения здесь

добавив этот код к моему исходному коду:

def print_color_range(name, clist):
    rangelen = len(clist)
    fore = fg(0) # black pen
    for i in range(rangelen):
        code = clist[i]
        back = bg(clist[i])
        print(f"{fore}{back}[{clist[i]:03d}]",  end = RESET)
    print(name)

WHITE_BLACK = [231,188,145,102,59,16]
WHITE_RED_BLACK     = [231,224,217,210,203,196,160,124,88,52,16]
WHITE_BLUE_BLACK    = [231,189,147,105,63,21,20,19,18,17,16]
WHITE_GREEN_BLACK   = [231,194,157,120,83,46,40,34,28,22,16]
WHITE_CYAN_BLACK    = [231,195,159,123,87,51,44,37,30,23,16]
WHITE_MAGENTA_BLACK = [231,225,219,213,207,201,164,127,90,53,16]
WHITE_YELLOW_BLACK = [231,230,229,228,227,226,184,142,100,58,16]
GREYS = [231,255,254,253,252,251,250,249,248,247,246,245,244,243,242,241,240,239,238,237,236,235,234,233,232,16]

print_color_range('reds', WHITE_RED_BLACK )
print_color_range('yellows', WHITE_YELLOW_BLACK    )
print_color_range('greens', WHITE_GREEN_BLACK  )
print_color_range('cyans', WHITE_CYAN_BLACK   )
print_color_range('blues', WHITE_BLUE_BLACK   )
print_color_range('magentas', WHITE_MAGENTA_BLACK)
print_color_range('white to black', WHITE_BLACK)
print_color_range('grays', GREYS)

произвел это

введите описание изображения здесь

Связанный контент