函数实现
function color_map = gray2color(heat_map)
%将灰度图像转换为彩色图像
cmap = jet;
sz = size(heat_map);
color_map = zeros(sz(1), sz(2), 3);
for i = 1:256
ind = find(heat_map == i-1);
[r,c] = ind2sub(sz, ind);
for j = 1:3
color_map(sub2ind([sz(1), sz(2), 3], r, c, j+zeros(size(r)))) = cmap(i, j);
end
end
end
说明
上面那个函数中实现的是像素级的替换,jet也就是我们最常使用的一种彩色矩阵,为256*3的二维数组,如果我们想把原始灰度图像中灰度值为0的颜色映射之后的值还是0,则可以:
cmap[1,:] = 0;
即可,如果我们仅仅需要显示的时候为彩色,则在imshow函数之后直接
colormap cmap;
即可