在matlab中如何在一个子函数中调用另一个函数的参数
1个回答
展开全部
inshow主要用于调用图像索引,比如:
imshow(X,map)
其功能等同于:
image(X)
colormap(map)
但是,inshow的功能要强大一些,比如用于灰度图像,RGB图像,二进制图像,都可以应用。imagesc属于图像缩放函数具体说一些例子:
要显示一副灰度图像,可以调用函数
imshow
或
imagesc
(即
imagescale,图像缩放函数)
(1)
imshow
函数显示灰度图像
使用
imshow(I)
或
使用明确指定的灰度级书目:imshow(I,32)
由于Matlab自动对灰度图像进行标度以适合调色板的范围,因而可以使用自定义
大小的调色板。其调用格式如下:
imshow(I,[low,high])
其中,low
和
high
分别为数据数组的最小值和最大值。
(2)
imagesc
函数显示灰度图像
下面的代码是具有两个输入参数的
imagesc
函数显示一副灰度图像
imagesc(1,[0,1]);
colormap(gray);
imagesc
函数中的第二个参数确定灰度范围。灰度范围中的第一个值(通常是0),
对应于颜色映象表中的第一个值(颜色),第二个值(通常是1)则对应与颜色映象表
中的最后一个值(颜色)。灰度范围中间的值则线型对应与颜色映象表中剩余的值(颜色)。
在调用
imagesc
函数时,若只使用一个参数,可以用任意灰度范围显示图像。在该
调用方式下,数据矩阵中的最小值对应于颜色映象表中的第一个颜色值,数据矩阵中的最大
值对应于颜色映象表中的最后一个颜色值。5.3
RGB
图像及其显示
(1)
image(RGB)
不管RGB图像的类型是double浮点型,还是
uint8
或
uint16
无符号整数型,Matlab都
能通过
image
函数将其正确显示出来。
RGB8
=
uint8(round(RGB64×255));
%
将
double
浮点型转换为
uint8
无符号整型
RGB64
=
double(RGB8)/255;
%
将
uint8
无符号整型转换为
double
浮点型
RGB16
=
uint16(round(RGB64×65535));
%
将
double
浮点型转换为
uint16
无符号整型
RGB64
=
double(RGB16)/65535;
%
将
uint16
无符号整型转换为
double
浮点型
(2)
imshow(RGB)
参数是一个
m×n×3
的数组5.4
二进制图像及其显示
(1)
imshow(BW)
在
Matlab
7.0
中,二进制图像是一个逻辑类,仅包括
0
和
1
两个数值。像素
0
显示
为黑色,像素
1
显示为白色。
显示时,也可通过NOT(~)命令,对二进制图象进行取反,使数值
0
显示为白色;1
显示
为黑色。
例如:
imshow(~BW)
(2)
此外,还可以使用一个调色板显示一副二进制图像。如果图形是
uint8
数据类型,
则数值
0
显示为调色板的第一个颜色,数值
1
显示为第二个颜色。
例如:
imshow(BW,[1
0
0;0
0
1])
imshow(X,map)
其功能等同于:
image(X)
colormap(map)
但是,inshow的功能要强大一些,比如用于灰度图像,RGB图像,二进制图像,都可以应用。imagesc属于图像缩放函数具体说一些例子:
要显示一副灰度图像,可以调用函数
imshow
或
imagesc
(即
imagescale,图像缩放函数)
(1)
imshow
函数显示灰度图像
使用
imshow(I)
或
使用明确指定的灰度级书目:imshow(I,32)
由于Matlab自动对灰度图像进行标度以适合调色板的范围,因而可以使用自定义
大小的调色板。其调用格式如下:
imshow(I,[low,high])
其中,low
和
high
分别为数据数组的最小值和最大值。
(2)
imagesc
函数显示灰度图像
下面的代码是具有两个输入参数的
imagesc
函数显示一副灰度图像
imagesc(1,[0,1]);
colormap(gray);
imagesc
函数中的第二个参数确定灰度范围。灰度范围中的第一个值(通常是0),
对应于颜色映象表中的第一个值(颜色),第二个值(通常是1)则对应与颜色映象表
中的最后一个值(颜色)。灰度范围中间的值则线型对应与颜色映象表中剩余的值(颜色)。
在调用
imagesc
函数时,若只使用一个参数,可以用任意灰度范围显示图像。在该
调用方式下,数据矩阵中的最小值对应于颜色映象表中的第一个颜色值,数据矩阵中的最大
值对应于颜色映象表中的最后一个颜色值。5.3
RGB
图像及其显示
(1)
image(RGB)
不管RGB图像的类型是double浮点型,还是
uint8
或
uint16
无符号整数型,Matlab都
能通过
image
函数将其正确显示出来。
RGB8
=
uint8(round(RGB64×255));
%
将
double
浮点型转换为
uint8
无符号整型
RGB64
=
double(RGB8)/255;
%
将
uint8
无符号整型转换为
double
浮点型
RGB16
=
uint16(round(RGB64×65535));
%
将
double
浮点型转换为
uint16
无符号整型
RGB64
=
double(RGB16)/65535;
%
将
uint16
无符号整型转换为
double
浮点型
(2)
imshow(RGB)
参数是一个
m×n×3
的数组5.4
二进制图像及其显示
(1)
imshow(BW)
在
Matlab
7.0
中,二进制图像是一个逻辑类,仅包括
0
和
1
两个数值。像素
0
显示
为黑色,像素
1
显示为白色。
显示时,也可通过NOT(~)命令,对二进制图象进行取反,使数值
0
显示为白色;1
显示
为黑色。
例如:
imshow(~BW)
(2)
此外,还可以使用一个调色板显示一副二进制图像。如果图形是
uint8
数据类型,
则数值
0
显示为调色板的第一个颜色,数值
1
显示为第二个颜色。
例如:
imshow(BW,[1
0
0;0
0
1])
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询