资源简介
SIFT算法实现全景图像拼接
这是VC源码
在VC6.0下编译可以运行(绝对可以运行,不是骗分的)
有中文注释
代码片段和文件信息
// 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 2010-04-22 22:19 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 2010-04-19 20:27 ImageProcessing1\ColorTable.h
文件 57 1995-08-03 13:28 ImageProcessing1\Default.SUP
文件 17028 2010-03-13 14:15 ImageProcessing1\DIBPrcs.cpp
文件 5028 2004-06-13 23:30 ImageProcessing1\DlgMosaicRes.cpp
文件 1505 2004-06-12 02:51 ImageProcessing1\DlgMosaicRes.h
文件 16216 2010-04-22 22:02 ImageProcessing1\DlgMosaics.cpp
文件 2738 2010-04-22 21:12 ImageProcessing1\DlgMosaics.h
文件 2699 2010-04-19 21:27 ImageProcessing1\GlobalApi.h
文件 37556 2010-11-21 19:09 ImageProcessing1\ImageProcessing.aps
文件 5167 2010-11-21 19:11 ImageProcessing1\ImageProcessing.clw
文件 5367 2010-03-16 15:20 ImageProcessing1\ImageProcessing.cpp
文件 5433 2010-04-22 21:29 ImageProcessing1\ImageProcessing.dsp
文件 555 1995-08-03 13:28 ImageProcessing1\ImageProcessing.dsw
文件 1372 2007-04-24 19:36 ImageProcessing1\ImageProcessing.h
文件 2016256 2010-11-21 19:11 ImageProcessing1\ImageProcessing.ncb
文件 67584 2010-11-21 19:11 ImageProcessing1\ImageProcessing.opt
文件 1499 2010-11-21 19:09 ImageProcessing1\ImageProcessing.plg
文件 17117 2010-04-22 21:02 ImageProcessing1\ImageProcessing.rc
文件 586 2004-05-14 19:49 ImageProcessing1\ImageProcessing.sln
..A..H. 6656 2004-05-14 19:54 ImageProcessing1\ImageProcessing.suo
文件 4363 2010-03-16 15:05 ImageProcessing1\ImageProcessingDoc.cpp
文件 1643 2007-04-24 20:51 ImageProcessing1\ImageProcessingDoc.h
文件 4261 2010-04-19 22:12 ImageProcessing1\ImageProcessingView.cpp
文件 3754 2010-04-19 21:40 ImageProcessing1\ImageProcessingView.h
............此处省略56个文件信息
- 上一篇:24位图转8位图像
- 下一篇:vs2008 MFC窗口皮肤50套+使用方法
相关资源
- APAP图像拼接开源代码
- 基于SIFT特征全景图像拼接C语言实现
- C++运用opencv进行二维多张全景图拼接
- opencv+MFC实现图像拼接
- 纯C语言写的sift算法,亲测,可用,可
- 基于块匹配的图像拼接 源码,C++实现
- 全景拼接c++代码
- sift算法C++opencv实现代码
- sift算法的C源码(网上唯一原创版本不
- sift-surf-orb通用程序
- BOW+SIFT特征提取OpenCV实现
- surfsift算法配准,利用Ransac去除误匹配
- 全景图像拼接程序源代码VC++
- 图像拼接使用VC++实现完成两幅又重叠
- SIFT代码,C/C++
- 全景图像拼接
- Opencv3中SIFT算法详解
- yuv编解码(2x2 YUV图像拼接)
- OpenCV图像拼接项目
- c++ 图像拼接
评论
共有 条评论