rgb to gray image indeces matching

1 回表示 (過去 30 日間)
Sokhib Tukhtayev
Sokhib Tukhtayev 2017 年 4 月 27 日
コメント済み: Sokhib Tukhtayev 2017 年 5 月 6 日
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 件のコメント
Adam
Adam 2017 年 4 月 27 日
Don't call a variable length, it is a builtin function that you just over-rode.
Sokhib Tukhtayev
Sokhib Tukhtayev 2017 年 4 月 27 日
編集済み: Sokhib Tukhtayev 2017 年 4 月 27 日
ok, it is just for reference, it could be any name. I changed it. Thank you, by the way!

サインインしてコメントする。

回答 (1 件)

Image Analyst
Image Analyst 2017 年 4 月 27 日
編集済み: Image Analyst 2017 年 4 月 27 日
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 件のコメント
Image Analyst
Image Analyst 2017 年 5 月 4 日
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 2017 年 5 月 6 日
Sorry sir, I combined your code with other code and got some side effects. Therefore I thought it didn't work. Thank you!

サインインしてコメントする。

Community Treasure Hunt

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

Start Hunting!

Translated by