rgb to gray image indeces matching

1 visualización (últimos 30 días)
Sokhib Tukhtayev
Sokhib Tukhtayev el 27 de Abr. de 2017
Comentada: Sokhib Tukhtayev el 6 de Mayo de 2017
I have an RGB color image with dimensions: 460x640x3 and a gray image with the same dimensions: 460x640. They are of the same type, that is, uint8. I want to get the intensity information of the gray image using the coordinate values from color image if that coordinate value is not black (intensity value ~= 0). if not the intensity value of gray image should be 0 (black).
If I loop through each values for example like below:
img_length = 460x640;
for i = 1:img_length
if rgbImage(i) ~= 0;
depthImage(i) = i;
else if rgbImage(i) == 0;
depthImage(i) = 0;
i = i+1;
end;
As for color image how can I use only large dimensions as if it is a gray image?
  2 comentarios
Adam
Adam el 27 de Abr. de 2017
Don't call a variable length, it is a builtin function that you just over-rode.
Sokhib Tukhtayev
Sokhib Tukhtayev el 27 de Abr. de 2017
Editada: Sokhib Tukhtayev el 27 de Abr. de 2017
ok, it is just for reference, it could be any name. I changed it. Thank you, by the way!

Iniciar sesión para comentar.

Respuestas (1)

Image Analyst
Image Analyst el 27 de Abr. de 2017
Editada: Image Analyst el 27 de Abr. de 2017
Try this:
sumImage = rgbImage(:,:,1) + rgbImage(:,:,2) + rgbImage(:,:,3);
mask = sumImage == 0;
grayValues = grayImage(mask); % 1-d list of gray levels where the color image is black.
  6 comentarios
Image Analyst
Image Analyst el 4 de Mayo de 2017
I don't understand how it does not do what you want. First it finds all the locations (pixels) where the image is totally black - each of red, green, and blue is exactly zero. Then it gives you the gray levels from the gray scale image at those locations. Your code does nothing like that (nothing like what you asked for) whereas mine does.
Sokhib Tukhtayev
Sokhib Tukhtayev el 6 de Mayo de 2017
Sorry sir, I combined your code with other code and got some side effects. Therefore I thought it didn't work. Thank you!

Iniciar sesión para comentar.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by