Borrar filtros
Borrar filtros

how to mask the image and keep only one color "green channel"?

29 visualizaciones (últimos 30 días)
Hi, here I have one photo and the code, please anyone help me to fix my code, I want to mask the binary with the RGB.
% Extract the individual red, green and blue color channel
redChannel = hasilcontrast(:,:,1);
greenChannel = hasilcontrast(:,:,2);
blueChannel = hasilcontrast(:,:,3);
% Create the mask
mask = cast(green, class(hasilcontrast));
redmask = redChannel.*mask;
greenmask = greenChannel.*mask;
bluemask = blueChannel.*mask;
% segmentasi
maskRGBimage = cat(3,redmask, greenmask, bluemask);
I not get the result, how I do to show the image. please help me sir
  3 comentarios
Oman Wisni
Oman Wisni el 26 de Sept. de 2018
Yes, I want like that, can you show me the code? I'm sorry, I confused how I explain, but your answer is right
Oman Wisni
Oman Wisni el 26 de Sept. de 2018
How you get the maskedRGB? Do you multiply multiply the original image with mask?

Iniciar sesión para comentar.

Respuesta aceptada

Image Analyst
Image Analyst el 26 de Sept. de 2018
I've done this so many times I lost track, and some time back decided to make a demo of it. Leaf, fruit, money, handwriting, leaf, fruit, money, handwriting, everyone wants to segment a leaf, fruit, money, or handwriting. Click on the tag "leaf" on the right hand side of this page. See attached demo.
  11 comentarios
Image Analyst
Image Analyst el 27 de Sept. de 2018
If you get holes in your leaf, and don't want them, you can call
mask = imfill(mask, 'holes');
Oman Wisni
Oman Wisni el 27 de Sept. de 2018
Yes sir, thanks.. Sir, the value 200, is that default value?

Iniciar sesión para comentar.

Más respuestas (1)

Akira Agata
Akira Agata el 26 de Sept. de 2018
Hi Oman-san,
Thank you for your prompt reply. The following is the code to generate the posted figure. I hope this will be some help for your research!
% Read the image
I = imread('base1.bmp');
% Create a mask based on a green channel of the image
BWmask = ~imbinarize(I(:,:,2));
BWmask = imfill(BWmask,'holes');
% Create a masked RGB image
Imasked = immultiply(I,repmat(BWmask,[1 1 3]));
% Show the results
figure
subplot(2,2,1)
imshow(I)
title('Original','FontSize',12)
subplot(2,2,2)
imshow(BWmask)
title('Mask','FontSize',12)
subplot(2,2,3)
imshow(Imasked)
title('Masked RGB','FontSize',12)
  1 comentario
Oman Wisni
Oman Wisni el 26 de Sept. de 2018
Editada: Oman Wisni el 26 de Sept. de 2018
thanks sir, you only keep green channel, I think all channel have been mask than you recombine again..
Im sorry sir, after I see your code that is not I mean. Like my code in above I want mask all channel in RGB channel, I get the mask every channel then I combine again. for mask I using multiply, and for recombine I using maskRGBimage = cat(3,redmask, greenmask, bluemask); and the result only keep green channel, I already upload the picture index.jpg, I want like that but no saturation channel.

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