资源简介
用MATLAB 实现两幅有重叠区域图像的拼接,很好用。

代码片段和文件信息
// cdib.cpp
#include “stdafx.h“
#include “math.h“
// #include “process.h“ //后来删除,暂时不发现影响
#include “cdib.h“
#include “GlobalApi.h“
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
// 声明串行化过程
IMPLEMENT_SERIAL(CDib Cobject 0);
/*************************************************************************
*
* \函数名称:
* CDib()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 构造函数
*
************************************************************************
*/
CDib::CDib()
{
m_hFile = NULL;
m_hBitmap = NULL;
m_hPalette = NULL;
m_nBmihAlloc = m_nImageAlloc = noAlloc;
Empty();
}
/*************************************************************************
*
* \函数名称:
* CDib()
*
* \输入参数:
* CSize size - 位图尺寸
* int nBitCount - 象素位数
*
* \返回值:
* 无
*
* \说明:
* 构造函数
* 根据给定的位图尺寸和象素位数构造CDib对象,并对信息头和调色板分配内存
* 但并没有给位图数据分配内存
*
************************************************************************
*/
CDib::CDib(CSize size int nBitCount)
{
m_hFile = NULL;
m_hBitmap = NULL;
m_hPalette = NULL;
m_nBmihAlloc = m_nImageAlloc = noAlloc;
Empty();
// 根据象素位数计算调色板尺寸
ComputePaletteSize(nBitCount);
// 分配DIB信息头和调色板的内存
m_lpBMIH = (LPBITMAPINFOHEADER) new
char[sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries];
// 设置信息头内存分配状态
m_nBmihAlloc = crtAlloc;
// 设置信息头中的信息
m_lpBMIH->biSize = sizeof(BITMAPINFOHEADER);
m_lpBMIH->biWidth = size.cx;
m_lpBMIH->biHeight = size.cy;
m_lpBMIH->biPlanes = 1;
m_lpBMIH->biBitCount = nBitCount;
m_lpBMIH->biCompression = BI_RGB;
m_lpBMIH->biSizeImage = 0;
m_lpBMIH->biXPelsPerMeter = 0;
m_lpBMIH->biYPelsPerMeter = 0;
m_lpBMIH->biClrUsed = m_nColorTableEntries;
m_lpBMIH->biClrImportant= m_nColorTableEntries;
// 计算图象数据内存的大小,并设置此DIB的调色板的指针
ComputeMetrics();
// 将此DIB的调色板初始化为0
memset(m_lpvColorTable 0 sizeof(RGBQUAD) * m_nColorTableEntries);
// 暂时不分配图象数据内存
m_lpImage = NULL;
}
/*************************************************************************
*
* \函数名称:
* ~CDib()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 析构函数,并释放所有分配的DIB内存
*
************************************************************************
*/
CDib::~CDib()
{
Empty();
}
/*************************************************************************
*
* \函数名称:
* GetDimensions()
*
* \输入参数:
* 无
*
* \返回值:
* CSize - DIB的宽度和高度
*
* \说明:
* 返回以象素表示的DIB的宽度和高度
*
************************************************************************
*/
CSize CDib::GetDimensions()
{
if(m_lpBMIH == NULL) return CSize(0 0);
return CSize((int) m_lpBMIH->biWidth (int) m_lpBMIH->biHeight);
}
/*************************************************************************
*
* \函数名称:
* AttachMapFile()
*
* \输入参数:
* const char* strPathname - 映射文件的路径
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 143062 2007-04-18 20:38 ImageProcessing1\3.BMP
文件 138514 2007-04-18 20:39 ImageProcessing1\4.BMP
文件 38683 2007-04-24 17:17 ImageProcessing1\cdib.cpp
文件 3673 2004-06-11 14:52 ImageProcessing1\cdib.h
文件 1542 1995-08-03 13:28 ImageProcessing1\ChildFrm.cpp
文件 1397 1995-08-03 13:28 ImageProcessing1\ChildFrm.h
文件 65095 1995-09-27 16:03 ImageProcessing1\ColorTable.h
文件 57 1995-08-03 13:28 ImageProcessing1\Default.SUP
文件 17030 1995-08-03 13:28 ImageProcessing1\DIBPrcs.cpp
文件 7646 1995-08-03 13:28 ImageProcessing1\DibShow.cpp
文件 5380 2005-03-18 22:37 ImageProcessing1\DlgAftReg.cpp
文件 1465 2004-06-12 02:38 ImageProcessing1\DlgAftReg.h
文件 1058 2005-03-22 03:00 ImageProcessing1\DlgCAP.cpp
文件 1198 2005-03-22 03:00 ImageProcessing1\DlgCAP.h
文件 9285 1996-11-01 02:40 ImageProcessing1\DlgEhnLinTrans.cpp
文件 1993 1996-11-01 01:56 ImageProcessing1\DlgEhnLinTrans.h
文件 1813 1995-09-27 15:57 ImageProcessing1\DlgEnhColor.cpp
文件 1464 1995-09-27 15:54 ImageProcessing1\DlgEnhColor.h
文件 1099 1995-08-03 17:52 ImageProcessing1\DlgHistShow.cpp
文件 1371 1995-08-03 17:52 ImageProcessing1\DlgHistShow.h
文件 4423 2000-01-01 04:26 ImageProcessing1\DlgHistShow1.cpp
文件 1377 2000-01-01 04:26 ImageProcessing1\DlgHistShow1.h
文件 3879 1995-08-07 17:27 ImageProcessing1\DlgMedian.cpp
文件 1551 1995-08-07 17:16 ImageProcessing1\DlgMedian.h
文件 5028 2004-06-13 23:30 ImageProcessing1\DlgMosaicRes.cpp
文件 1505 2004-06-12 02:51 ImageProcessing1\DlgMosaicRes.h
文件 16155 2005-04-13 22:07 ImageProcessing1\DlgMosaics.cpp
文件 2783 2004-06-16 00:34 ImageProcessing1\DlgMosaics.h
文件 18063 2005-03-17 21:24 ImageProcessing1\DlgRecMatch.cpp
文件 1966 1996-11-04 05:51 ImageProcessing1\DlgRecMatch.h
............此处省略51个文件信息
- 上一篇:k近邻分类matlab实现
- 下一篇:用A*算法路径规划, matlab程序
相关资源
- MATLAB 经典程序源代码大全
- MATLAB小波软阈值去噪代码33473
- 天线阵的波束形成在MATLAB仿真程序及
- 非线性SVM算法-matlab实现
- 《MATLAB 智能算法超级学习手册》-程序
- 组合导航matlab程序
- 读取txt文件内容matlab代码实现
- Matlab实现基于相关的模板匹配程序
- matlab优化工具箱讲解
- 基于MATLAB的快速傅里叶变换
- 光纤传输中的分布傅立叶算法matlab实
- 基于matlab的图像处理源程序
- matlab 椭圆拟合程序
- 算术编码解码matlab源代码
- optical_flow 光流法 matlab 实现程序
- 引导图像滤波器 Matlab实现
- 分形几何中一些经典图形的Matlab画法
- OFDM系统MATLAB仿真代码
- SVM工具箱(matlab中运行)
- 图像小波变换MatLab源代码
- LU分解的MATLAB实现
- 冈萨雷斯数字图像处理matlab版(第三
- 替代数据法的matlab程序
- 用matlab实现的多站定位系统性能仿真
- 通过不同方法进行粗糙集属性约简m
- k近邻算法matlab实现
- matlab识别系统
- 神经网络分类matlab程序
- matlab正弦信号发生器的设计
- matlab程序用Hopfield网络解决TSP
评论
共有 条评论