Alphamap using Binary Mask
2 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Sordin
am 22 Apr. 2017
Kommentiert: Walter Roberson
am 24 Apr. 2017
Is it possible to make an alphamap for a figure based on its binary mask?
Here is a sample image and its binary:
I = imread('saturn.png');
a = im2bw(I, graythresh(I));
I want the regions in black to be made transparent and white regions to be opaque. So the only area visible is the image itself without the background.
Is this possible in Matlab? I couldn't find any information or examples in the documentation.
2 Kommentare
Image Analyst
am 22 Apr. 2017
Do you mean that you want to create a PNG file with transparent pixels? If so, clarify which pixels are to be transparent - Saturn, or the space? Because when you say "the image itself", well, that is the entire image - both Saturn and the space. They're both part of the image.
Akzeptierte Antwort
Image Analyst
am 23 Apr. 2017
When you say "Being able to exclude the background of each image (i.e., the parts of the image that contain no useful data) would help a lot." It sounds like you want masking. So if the unwanted stuff was segmented so that it's white (like the Saturn in your binary image), then you can exclude that from the original image by masking like this:
% Mask the image using bsxfun() function
maskedRgbImage = bsxfun(@times, rgbImage, cast(mask, 'like', rgbImage));
that will give you a color image of the space/universe while the Saturn pixels would be completely black ("removed" from the image). Invert the mask using mask=~mask if you want the opposite stuff blacked out.
% Mask the image using bsxfun() function
maskedRgbImage = bsxfun(@times, rgbImage, cast(~mask, 'like', rgbImage));
If it's a simple grayscale image, you can erase mask pixels like this:
maskedGrayImage = grayImage; % Initialize
maskedGrayImage(mask) = 0;
2 Kommentare
Walter Roberson
am 24 Apr. 2017
You are using an older MATLAB that does not support that syntax. You can replace
cast(~mask, 'like', rgbImage)
with
cast(~mask, class(rgbImage))
Weitere Antworten (2)
KSSV
am 22 Apr. 2017
I = imread('saturn.jpg') ;
I = rgb2gray(I) ;
I(I<50) = 255 ;
imshow(I)
0 Kommentare
Walter Roberson
am 23 Apr. 2017
I = imread('saturn.png');
a = im2bw(I, graythresh(I));
image(I, 'alphadata', double(a) )
Alpha data needs to be between 0 and 1 (inclusive), so just double() the logical data to get suitable alpha data.
0 Kommentare
Siehe auch
Kategorien
Mehr zu Lighting, Transparency, and Shading finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!