Как создать собственную цветовую карту программно?

Я хотел бы создать цветовую карту в Matlab. Я хочу выцветать в соответствии с уровнем серого в пикселях.

Например:

from 255 to 160 -> white 
from 159 to 120 -> pink
from 119 to 50 -> brown
from 49 to 0 -> dark

2 ответа

Решение

Из документов:

Цветовая карта - это матрица размером 3 на 3 из вещественных чисел от 0,0 до 1,0. Каждая строка представляет собой вектор RGB, который определяет один цвет. K-я строка цветовой карты определяет k-й цвет, где map(k,:) = [r(k) g(k) b(k)]) определяет интенсивность красного, зеленого и синего цветов.

Итак, для начала мы собираемся создать матрицу размером 3 на 3, в вашем случае m равно 161:

m = 161;
map = zeros(m , 3);

Теперь вы хотите, чтобы дно было темным (я иду с черным), а 50-я точка была коричневой. но давайте возьмем для примера красный, так как это проще. RGB утраивается для черного и красного соответственно: [0,0,0] а также [1,0,0]

Итак, в настоящее время наша цветовая карта enitre черная. Мы знаем, что хотим map(50,:) = [1, 0 ,0] то есть красный, но теперь мы хотим градиент между ними, верно? Так что давайте использовать для этого linspace (обратите внимание, что есть лучший метод, использующий interp1 вместо linspace в конце этого ответа):

R0to50 = linspace(0,1,50)';

положить это на карте:

map(1:50, 1) = R0to50;

Итак, теперь давайте используем коричневый вместо красного, чтобы получить тройку по этой ссылке, разделить каждый компонент цвета на 255, чтобы наша тройка была t = [101, 67, 33]./255, Хорошо, теперь просто повторите эту процедуру для каждого цвета:

R = linspace(0,t(1),50);
G = linspace(0,t(2),50);
B = linspace(0,t(3),50);

T = [R', G', B'];

map(1:50, :) = T;

А теперь повторите для каждого из ваших других узлов.

Например:

I = linspace(0,1,161);
imagesc(I(:, ones(10)))
colormap(map)

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


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

Создайте матрицу, в которой каждая строка представляет собой цветовую тройку

T = [0,   0,   0          %// dark
     101, 67,  33         %// brown
     255, 105, 180        %// pink
     255, 255, 255        %// white
     255, 255, 255]./255; %// white again  -> note that this means values between 161 and 255 will be indistinguishable

А теперь создайте вектор, в каком диапазоне должен находиться каждый цвет (т.е. этот вектор определяет расстояние между цветами, они не должны быть равномерно / равномерно распределены):

x = [0
     50
     120
     160
     255];

И, наконец, вы можете создать всю карту с помощью одной простой интерполяции:

map = interp1(x/255,T,linspace(0,1,255));

тестирование

I = linspace(0,1,255);
imagesc(I(ones(1,10),:)')
colormap(map)

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

В качестве альтернативы вы можете использовать AdvancedColormap функция от FEX. Если вам нужна гладкая цветовая карта, вы можете сделать это так:

map = AdvancedColormap('kbpw',256,[0 50 120 255]/255);
Другие вопросы по тегам