早教吧作业答案频道 -->其他-->
下面这个函数是不是取像素值的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分别是什么意思.
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])
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])
看了下面这个函数是不是取像素值的v...的网友还看了以下:
以下各正方形的边长是无理数的是a面积为25的正方形b面积为16的正方形c面积为8的正方形d以下各正 2020-04-27 …
下面试题:11111111111对于化学反应A+B=C+D的下列说法中,正确的是()A.若A、B、 2020-04-27 …
如下图中,若在容器左右两管分别注入清水和食用油(清水密度大于食用油),液面相平,当将阀门AB打开时 2020-05-13 …
右图为伽利略温度计(烧瓶内有空气,细管中有液体),若气温降低时(c)A.液体收缩,液面上升 B.液 2020-05-14 …
一物体沿斜面向上滑动时,动能每减小1J,势能增加0.75J,当物体沿此面下滑时:D动能每增加1J, 2020-05-14 …
上面写不下我写在下面,下列方程变形正确的是().①3x+6=0变形为x+2=0②x+7=5-3x变 2020-05-19 …
关系模式r(a,b,c,d,e)中有下列函数依赖:a→bc,d→e,c→d。下面对r的分解中哪一个( 2020-05-26 …
如图轨道ABCD平滑连接,其中AB为光滑的曲面,BC为粗糙水平面且摩擦因数为μ,CD为半径为r内壁 2020-06-15 …
一道建筑工程井点系统布置和设计的题某基坑面积为20m×30m,基坑深4m,地下水位在地面下1m,不 2020-07-08 …
土木工程施工中井点系统布置设计问题!某基坑面积为20m*30m,基坑深4m,地下水位在地面下1m, 2020-07-08 …