Как создать собственную цветовую карту программно?
Я хотел бы создать цветовую карту в 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);