近期学习使用matlab处理图像,对于显示double型图像遇到些问题,查阅相关博客、论坛,总结如下:1、在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从uint8型变成double型。
    2、如果直接运行imshow(I),我们会发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0~ 1范围内,即大于1时都是显示为白色,而imshow显示uint8型时是0~255范围。

    解决办法如下:
    1、imshow(I/256); % 将图像矩阵转化到0-1之间
    2、imshow(I,[]); % 自动调整数据的范围以便于显示
    3、inshow(uint8(I)); % 转成uint8

    针对第二种解决方法,官方文档(https://cn.mathworks.com/help/matlab/ref/imshow.html?searchHighlight=imshow&s_tid=doc_srchtitle )中提示:
    imshow(I,[low high]) 显示灰度图像 I,将该显示范围指定为一个二元素向量 [low high]。
    参数 “[low high]” 可简写为 “[]”, 即将I的最大值 max(I) 和最小值 min(I) 分别作为纯白(255)和纯黑(0),中间的K值相应地映射为0到255之间的标准灰度值,相当于将double型的矩阵I拉伸成为了0-255的uint8型的矩阵。这里需要注意当图像的所有像素值相同时,该函数会将像素值当做最大值映射为255,图像会显示为白色,因此这时需要给定显示范围,如 imshow(I,[0 255])。
    ————————————————
    版权声明:本文为CSDN博主「感染虫」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/u012162771/article/details/79901160