早教吧 育儿知识 作业答案 考试题库 百科 知识分享

下面这个函数是不是取像素值的void*CDIB::GetPixelAddress(intx,inty){intiWidth;//makesureit'sinrangeandifnotreturnzeroif((x>=DibWidth())||(y>=DibHeight())){TRACE("Attempttogetoutofrangep

题目详情
下面这个函数是不是取像素值的
void* CDIB::GetPixelAddress(int x, int y)
{
int iWidth;
// make sure it's in range and if not return zero
if ((x >= DibWidth())
|| (y >= DibHeight())) {
TRACE("Attempt to get out of range pixel addr");
return NULL;
}
// Calculate the scan line storage width
iWidth = StorageWidth();
switch (m_pBMI->bmiHeader.biBitCount) {
case 1:
return m_pBits + (DibHeight()-y-1) * iWidth + (x+7)/8 ;
case 4:
return m_pBits + (DibHeight()-y-1) * iWidth + (x+3)/4;
case 8:
return m_pBits + (DibHeight()-y-1) * iWidth + x;
case 16:
return m_pBits + (DibHeight()-y-1) * iWidth + x*2;
case 24:
return m_pBits + (DibHeight()-y-1) * iWidth + x*3;
case 32:
default:
TRACE("Unsupported format");
ASSERT(0);
return NULL;
}
}
下面那些值:1、2、4、8、16、32分别是什么意思.
▼优质解答
答案和解析
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])