资源简介
该文件可实现对手势二值图的轮廓跟踪,并且提取手势轮廓图的傅立叶描述子提取,VC++6.0运行成功。

代码片段和文件信息
// cdib.cpp
// new version for WIN32
#include “stdafx.h“
#include “cdib.h“
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
IMPLEMENT_SERIAL(CDib Cobject 0);
CDib::CDib()
{
m_hFile = NULL;
m_hBitmap = NULL;
m_hPalette = NULL;
m_nBmihAlloc = m_nImageAlloc = noAlloc;
Empty();
}
CDib::CDib(CSize size int nBitCount)
{
m_hFile = NULL;
m_hBitmap = NULL;
m_hPalette = NULL;
m_nBmihAlloc = m_nImageAlloc = noAlloc;
Empty();
ComputePaletteSize(nBitCount);
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;
ComputeMetrics();
memset(m_lpvColorTable 0 sizeof(RGBQUAD) * m_nColorTableEntries);
m_lpImage = NULL; // no data yet
}
CDib::~CDib()
{
Empty();
}
CSize CDib::GetDimensions()
{
if(m_lpBMIH == NULL) return CSize(0 0);
return CSize((int) m_lpBMIH->biWidth (int) m_lpBMIH->biHeight);
}
BOOL CDib::AttachMapFile(const char* strPathname BOOL bShare) // for reading
{
// if we open the same file twice Windows treats it as 2 separate files
// doesn‘t work with rare BMP files where # palette entries > biClrUsed
HANDLE hFile = ::CreateFile(strPathname GENERIC_WRITE | GENERIC_READ
bShare ? FILE_SHARE_READ : 0
NULL OPEN_EXISTING FILE_ATTRIBUTE_NORMAL NULL);
ASSERT(hFile != INVALID_HANDLE_VALUE);
DWORD dwFileSize = ::GetFileSize(hFile NULL);
HANDLE hMap = ::CreateFileMapping(hFile NULL PAGE_READWRITE 0 0 NULL);
DWORD dwErr = ::GetLastError();
if(hMap == NULL) {
AfxMessageBox(“Empty bitmap file“);
return FALSE;
}
LPVOID lpvFile = ::MapViewOfFile(hMap FILE_MAP_WRITE 0 0 0); // map whole file
ASSERT(lpvFile != NULL);
if(((LPBITMAPFILEHEADER) lpvFile)->bfType != 0x4d42) {
AfxMessageBox(“Invalid bitmap file“);
DetachMapFile();
return FALSE;
}
AttachMemory((LPBYTE) lpvFile + sizeof(BITMAPFILEHEADER));
m_lpvFile = lpvFile;
m_hFile = hFile;
m_hMap = hMap;
return TRUE;
}
BOOL CDib::CopyToMapFile(const char* strPathname)
{
// copies DIB to a new file releases prior pointers
// if you previously used CreateSection the HBITMAP will be NULL (and unusable)
BITMAPFILEHEADER bmfh;
bmfh.bfType = 0x4d42; // ‘BM‘
bmfh.bfSize = m_dwSizeImage + sizeof(BITMAPINFOHEADER) +
sizeof(RGBQUAD) * m_nColorTableEntries + sizeof(BITMAPFILEHEADER);
// meaning of bfSize open to interpretation
bmfh.bfReserved1 = bmfh.bfReserved2 = 0;
bmfh.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADE
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 4804 2008-05-28 12:30 fuliye\fuliye.dsp
文件 54784 2008-07-25 15:06 fuliye\fuliye.opt
文件 2952 2008-07-25 15:06 fuliye\fuliye.clw
文件 4766 2008-05-23 16:22 fuliye\ReadMe.txt
文件 13432 2008-07-25 09:05 fuliye\fuliye.rc
文件 1054 2008-05-23 16:22 fuliye\StdAfx.h
文件 208 2008-05-23 16:22 fuliye\StdAfx.cpp
文件 1542 2008-05-23 16:22 fuliye\MainFrm.h
文件 2523 2008-05-23 16:22 fuliye\MainFrm.cpp
文件 1397 2008-05-23 16:22 fuliye\ChildFrm.h
文件 1533 2008-05-23 16:22 fuliye\ChildFrm.cpp
文件 1968 2008-05-23 16:22 fuliye\fuliyeView.h
文件 535 2008-05-23 16:22 fuliye\fuliye.dsw
文件 181248 2008-07-25 15:06 fuliye\fuliye.ncb
文件 2012 2008-01-09 10:28 fuliye\cdib.h
文件 16576 2008-03-07 21:29 fuliye\cdib.cpp
文件 246 2008-07-25 15:05 fuliye\fuliye.plg
文件 3008 2008-05-23 16:26 fuliye\fuliyeView.cpp
文件 45328 2008-07-25 09:05 fuliye\fuliye.aps
文件 781 2008-07-24 16:32 fuliye\Resource.h
文件 33902 2008-07-24 21:13 fuliye\fuliyeDoc.cpp
文件 398 2008-05-23 16:22 fuliye\res\fuliye.rc2
文件 1078 2008-05-23 16:22 fuliye\res\fuliyeDoc.ico
文件 1078 2008-05-23 16:22 fuliye\res\fuliye.ico
文件 1198 2008-07-24 09:06 fuliye\res\Toolbar.bmp
文件 1382 2008-07-24 15:17 fuliye\fuliye.h
文件 7109 2008-07-24 15:20 fuliye\fuliye.cpp
文件 1600 2008-07-24 16:30 fuliye\fuliyeDoc.h
目录 0 2008-06-02 10:29 fuliye\Debug
目录 0 2008-06-02 10:29 fuliye\res
............此处省略5个文件信息
- 上一篇:C++中国象棋人机下棋 高智商版
- 下一篇:二叉树c++源代码实现查找,删除,插入等
相关资源
- VC++ 多线程文件读写操作
- 移木块游戏,可以自编自玩,vc6.0编写
- VC++MFC小游戏实例教程(实例)+MFC类库
- VC++实现CMD命令执行与获得返回信息
- VC++基于OpenGL模拟的一个3维空间模型
- 基于VC++的SolidWorks二次开发SolidWorks
- 派克变换VC++源码(附文档)
- VC++ 串口
- VC++ 大富翁4_大富翁游戏源码
- VC++ 摄像头视频采集与回放源程序
- 转 VC++ 实现电子邮件(Email)发送
- 基于MFC的VC++仿QQ浏览器源码(雏形)
- VC++ 服务程序编写及安装与卸载
- VC++6.0番茄西红柿VAXvirsual assist X完美破
- 基于改进的fcm算法的图像分割vc++
- VC++6.0 绿色版,免安装,非常好用。
- Microsoft Visual C++ 2005 Redistributable Pack
- VC++MFC课程设计的学生成绩管理系统
- 大智慧365DLL插件设计
- FFT(快速傅里叶变换)C++源程序
- VC++6.0汉化包
- VC++完整商业界面源码(再上传)
- VC++编程技术600个大型项目源码.rar
- VC++实现RSA加密算法
- VC++ 中国象棋经典游戏源代码
- 郁金香VC++游戏辅助视频教程
- C语言进阶源码---基于graphics实现图书
- 摄影测量相对定向VC++程序
- VC++数字图像处理典型算法及实现
- VC++酒店客房管理系统 MFC
评论
共有 条评论