Plotting pcolor plot on an image at a particular area.
7 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
waqas
am 1 Okt. 2019
Kommentiert: waqas
am 9 Okt. 2019
Hi,
I have done some analysis on a particular region of an image which I now want to plot on the over the image. Following image is an example of what I am trying to get as output ( In my case it is a complete pacman shape but some region would be removed because of NaNs):
Now, I can plot the pcolor of the colored region separatly but am unable to get it with image. Colorbar changes to the gray values. Attached is the relevant binary matrix (region) which shows the region where the profile should be as well as image (img) which is suppose to be in the background and (out) is the values in the disc region.
2 Kommentare
Mahesh Taparia
am 4 Okt. 2019
Hi,
It is not clear what you want to do with the 3 images you have attached. Can you explain clearly?
Akzeptierte Antwort
Walter Roberson
am 8 Okt. 2019
pcolor() accepts x and y arguments as well as the data, so to plot it on top of something else, plot the other things first, "hold on", then pcolor() passing in appropriate coordinates.
pcolor() is, by the way, surf() followed by view(2) internally, except that pcolor() does not accept all of the options that surf() accepts.
3 Kommentare
Walter Roberson
am 8 Okt. 2019
All items on the same axes share the same colormap.
You can create multiple axes in the same place and have one colormap for each. If you do that, make sure that the background color of the top axes is set to 'none' .
However, the better approach is to convert the grayscale image to RGB so that it does not require a colormap. You can do that by using
rgb_version = repmat(YourGrayImage, 1, 1, 3);
Weitere Antworten (1)
darova
am 4 Okt. 2019
You can just merge images
clc,clear
load matlab.mat
[m,n] = size(img);
[X,Y] = ndgrid(1:m,1:n);
Z = (X.*Y).*region; % try (X+Y)
Z = Z/max(Z(:)); % just scale 0 .. 1
% make RGB image: RED - 1, GREEN - changes, BLUE - 0
% result: red to orange
I1 = cat(3,Z*0+1,Z,Z*0);
mask = repmat(region,[1 1 3]);
I2 = double( repmat(img,[1 1 3]) );
I2 = I2/max(I2(:)); % scale 0 .. 1
I = I1 .* mask + I2 .* ~mask; % merge images
imshow(I);
cm = flipud(autumn);
colormap(cm)
h = colorbar;
Siehe auch
Kategorien
Mehr zu Red finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!