基于数字图片处理的数控G代码生成源程序


对网络上的字体图片进行处理,提取轮廓以后设定加工尺寸,然后生成G代码,可惜现在只能进行直线拟合,生成基于直线的G代码,不过精度还可以,注:由于在图片处理的过程中用到了openCV库,所以在编译生成之前要配置openCV数据库,另外灰显的功能正在添加中,能进行轮廓的加工代码生成,临时不能进行区域切除,也就是行切环切,在生成加工代码的生成一些参数还没有进行处理,不过那是很容易的,修改一下就可以了
资源截图
代码片段和文件信息
// 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 - 映射文件的路径名
 *   BOOL bShare -

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     目录           0  2012-06-12 17:05  程序
     文件          38  2012-05-27 22:01  程序.txt
     文件      199178  2012-05-28 13:27  程序856245_2.bmp
     目录           0  2012-06-12 17:05  程序Debug
     文件        2601  2012-06-12 17:05  程序MainFrm.cpp
     文件        1581  2012-05-27 22:01  程序MainFrm.h
     文件       34992  2012-06-12 16:58  程序MyDIP.aps
     文件        5063  2012-06-12 17:05  程序MyDIP.clw
     文件        4158  2012-05-27 22:01  程序MyDIP.cpp
     文件        5069  2012-05-27 22:01  程序MyDIP.dsp
     文件         533  2012-05-27 22:01  程序MyDIP.dsw
     文件        1345  2012-05-27 22:01  程序MyDIP.h
     文件      492544  2012-06-12 17:05  程序MyDIP.ncb
     文件       54784  2012-06-12 17:05  程序MyDIP.opt
     文件        1315  2012-06-12 17:05  程序MyDIP.plg
     文件       16490  2012-05-29 12:01  程序MyDIP.rc
     文件        4727  2012-05-27 22:01  程序MyDIPDoc.cpp
     文件        1921  2012-05-27 22:01  程序MyDIPDoc.h
     文件       24934  2012-06-12 17:01  程序MyDIPView.cpp
     文件        2214  2012-06-12 17:01  程序MyDIPView.h
     文件         948  2012-05-27 22:01  程序Out.cpp
     文件        1189  2012-05-27 22:01  程序Out.h
     文件        3363  2012-05-28 18:10  程序OutPut.cpp
     文件        1285  2012-05-28 18:02  程序OutPut.h
     文件        4287  2012-05-27 22:01  程序ReadMe.txt
     目录           0  2012-06-12 16:58  程序Release
     文件         864  2012-05-27 22:01  程序ReleaseInput2.sbr
     文件       13006  2012-06-12 17:05  程序ReleaseMainFrm.obj
     文件        4345  2012-06-12 17:05  程序ReleaseMainFrm.sbr
     文件     5882880  2012-05-27 22:01  程序ReleaseMyDIP.bsc
     文件       49152  2012-06-12 17:05  程序ReleaseMyDIP.exe
............此处省略58个文件信息

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。

发表评论

评论列表(条)