matlab 绘制灰度图

该代码段使用MATLAB生成一个矩阵,并将其转化为灰度图像。不同数值的区域用不同灰度表示,矩阵中特定区域被设定为特定数值。之后,它创建多个子图,每个子图显示矩阵中一个独特的数值区域,通过调整灰度间隔增强区分度。每个图像都隐藏了坐标轴标签并在画布上全屏显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 matlab 将矩阵中不同数值所对应的区域用 不同深度的灰度图画出来,不显示坐标轴标签,并设置在画布上全屏显示。

 if 1
        close  all
        rng (7)
        mask_all=rand(256,256)*10;
        mask_all=round(mod(mask_all,2));
        mask_all=sort(mask_all);
        mask_all(1:100,1:50)=0;
        mask_all(100:256,200:256)=2;
    end
    %     mask_all=TT;
    maskNotes=unique(mask_all);
    SegmentNum=length(maskNotes);
    for k=1:SegmentNum
        mask_per_pic(:,:,k)=mask_all==maskNotes(k);
    end
    d1=200;
    d2=200;
    p1=500;
    p2=200;
    for kk=1:SegmentNum
        MM=mask_per_pic(:,:,kk);
        MM=mat2gray(MM)*0.7;
        MM=MM-(MM>0)*(kk-1)*0.2;    % 使MM的非零值分别间隔0.2,提高区分度
        figure
        himg=imshow(MM);            % 灰度图
        %himg=imagesc(MM);          % 彩色图
        set(himg,'alphadata',(MM>0))
        %  axis([xmin,xmax,ymin,ymax]);
        set(gcf,'position',[p1,p2,d1,d2]);
        set(gca,'xticklabel',[],'yticklabel',[]);
        %         set(gca,'xtick',[],'ytick',[]);
        set(gca,'position',[0 0 1 1]);
        axis on
        grid on
        picName=sprintf('D:/R&D/TWC/demoPic/imaskPer%d.emf',kk);
        %         saveas(gcf,picName);
    end

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值