现在有一张彩图,该图片的有些地方是有颜色的,有些地方是没有颜色的,MATLAB如何将这张彩图变成白色,底色是白色,而且颜色的轮廓保留
该回答通过自己思路及引用到各个渠道搜索综合及思考,得到内容具体如下:
在MATLAB中,您可以使用以下步骤将一张彩色图变成白色底色并保留颜色轮廓:
1、读取彩色图像并显示出来:
img = imread('your_image.png'); % 读取彩色图像
imshow(img); % 显示彩色图像
2、将彩色图像转换为灰度图像:
gray_img = rgb2gray(img); % 将彩色图像转换为灰度图像
3、将灰度图像二值化,使颜色部分变成白色,背景部分变成黑色:
bw_img = gray_img > 0; % 将灰度图像二值化
4、反转二值图像的颜色,使颜色部分变成黑色,背景部分变成白色:
bw_img = 1 - bw_img; % 反转二值图像的颜色
5、将原始彩色图像和反转后的二值图像合并,使颜色部分在白色底色上保留颜色轮廓:
R = uint8(bw_img) .* img(:,:,1); % 提取原始彩色图像的红色通道并乘以反转后的二值图像
G = uint8(bw_img) .* img(:,:,2); % 提取原始彩色图像的绿色通道并乘以反转后的二值图像
B = uint8(bw_img) .* img(:,:,3); % 提取原始彩色图像的蓝色通道并乘以反转后的二值图像
white_img = cat(3, R, G, B); % 将三个通道合并成彩色图像
6、显示最终得到的白底彩色图像:
imshow(white_img); % 显示白底彩色图像
这样,您就可以将一张彩色图像变成白色底色并保留颜色轮廓了。
如果以上回答对您有所帮助,点击一下采纳该答案~谢谢
RGB = imread('你的图片.jpg');
grayImage = rgb2gray(RGB);
binaryImage = imbinarize(grayImage, 0.5);
filledImage = imfill(binaryImage,'holes');
smoothed = bwmorph(filledImage, 'thicken', 1);
boundary = bwperim(smoothed);
dilatedBoundary = imdilate(boundary, strel('disk', 1));
whiteImage = uint8(255*ones(size(RGB)));
whiteImage(dilatedBoundary) = RGB(dilatedBoundary);
imshow(whiteImage);
注意:本方法不适用于公网远程通信,具体原因看我这篇文章: