程序莫名其妙的崩溃,加断点刚进入函数就崩溃,断点不往下走,读取图片数据到程序并保存到一个HBITMAP 中...

HPR_INT32 CCarManageDlg::DrawPic2UIForm(IUIFormObj* pUIForm,string& strPicName)
{//程序崩溃的地方
 HPR_INT32 iReval=HPR_ERROR;
 char* buff=NULL;
 do
 {
  if (NULL == pUIForm||strPicName=="")
  {
   CLIENT_ERROR("DrawPic2UIForm into paras is wrong ");
   break;
  }
   //buff= g_MemPool.MemAlloc(PICTURE_SIZE);

char buff[10*1024*1024]={0};//出现崩溃的地方,这里申请的内存太大,线程的堆栈没有这么大的内存所以会在函数刚进入的地方就崩溃,断点都不会往下走;
  if (buff ==NULL)
  {
   CLIENT_ERROR(" g_MemPool.MemAlloc fialed ");
   break;
  }
  HPR_UINT32 iLen=0;
  if (ReadFlagPicData(strPicName,buff,iLen)!=HPR_OK)
  {
   CLIENT_ERROR("ReadFlagPicData failed %s ",strPicName.c_str());
   break;
  }
  char* pData =buff; //(char*)strPicContext.c_str();
  int dataLen =iLen;
  CImage img;
  IStream* pIStream;
  HGLOBAL hGlobal = GlobalAlloc(GMEM_MOVEABLE, dataLen);
  if (!hGlobal)
  {
   CLIENT_ERROR("GlobalAlloc failed  %s ",strPicName.c_str());
   break;
  }
  void* pBuf = GlobalLock(hGlobal);
  memcpy(pBuf, (void*)pData, dataLen);
  GlobalUnlock(hGlobal);
  HRESULT hr = CreateStreamOnHGlobal(hGlobal,TRUE,&pIStream);
  if(S_OK == img.Load(pIStream))
  {
   HBITMAP hBmp = img.Detach();
   if (hBmp != NULL)
   {
    pUIForm->SetBackBitmap((OLE_HANDLE)hBmp);
    ::DeleteObject(hBmp);
   }
  }
  if (pIStream)
  {
   pIStream->Release();
  }
  GlobalFree(hGlobal);
  iReval=HPR_OK;
 } while (0);
 if (iReval!=HPR_OK)
 {
  if (pUIForm)
  {
   pUIForm->SetDrawColor(TRUE);
  }
 }
 if (buff!=NULL)
 {
  g_MemPool.MemRstore(buff);
 }
 return iReval;
}
HPR_INT32 CCarManageDlg::ReadFlagPicData(string strPicName,char* buff,HPR_UINT32& iLen)
{
 HPR_INT32 iReval=HPR_ERROR;
 do
 {
  if (strPicName=="")
  {
   break;
  }
  HPR_HANDLE DirFlag=HPR_OpenDir("countryflag");
  if (DirFlag==NULL)
  {
   CLIENT_ERROR("open dir countryflag failed");
   break;
  }
  HPR_FILEFIND_INFO FileInfo;
  HPR_Snprintf(FileInfo.sFileName,HPR_MAX_PATH,"%s",strPicName.c_str());
  if (HPR_FindFileInDir(DirFlag,&FileInfo)==HPR_ERROR)
  {
   CLIENT_ERROR("HPR_FindFileInDir %s faild ",strPicName.c_str());
   break;
  }
  strPicName="./countryflag/"+strPicName;
  strPicName=strPicName+".png";
  HPR_HANDLE hFile=HPR_OpenFile(strPicName.c_str(),HPR_READ,HPR_WREAD);
  if (hFile==HPR_INVALID_FILE)
  {
   CLIENT_ERROR("HPR_OpenFile %s faild ",strPicName.c_str());
   break;
  }
  if (HPR_ReadFile(hFile,buff,PICTURE_SIZE,&iLen)==HPR_ERROR||iLen==0)
  {
   CLIENT_ERROR("HPR_ReadFile %s faild len %d",strPicName.c_str(),iLen);
   break;
  }
  iReval=HPR_OK;
 } while (0);
 return iReval;
}

 

自己编了一个股票监控软件,有如下功能,有兴趣的朋友可以下载;

(1)   个股监测。监测个股实时变化,可以监测个股大单交易、急速拉升和下降、主力入场和出场、股票最高点和最低点提醒。检测到最高点、最低点、主力进场点、主力退场点、急速拉升点、急速下跌点,给出语音或者声音提醒,不用再时刻看着大盘了,给你更多自由的时间;

(2)   大盘监测。监测大盘的走势,采用上证、深证、创业三大指数的综合指数作为大盘走势。并实时监测大盘的最高点和最低点、中间的转折点。

(3)   股票推荐。还能根据历史数据长期或短期走势进行分析,对股市3千多个股票进行分析对比,选出涨势良好的股票,按照增长速度从大到小排序,推荐给你涨势良好的股票;

下载地址:

1.0.3版本(修复大盘指数崩溃缺陷)下载地址:

链接:https://pan.baidu.com/s/1BJcTp-kdniM7VE9K5Kd3vg 提取码:003h

更新链接:

https://www.cnblogs.com/bclshuai/p/10621613.html

转载于:https://www.cnblogs.com/bclshuai/p/8574511.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个示例代码,可以将一个bmp图像数据上抗锯齿算法并生成图片: ```c++ // 载bmp图像数据 CImage image; image.Load(L"test.bmp"); // 获取图像宽度和高度 int width = image.GetWidth(); int height = image.GetHeight(); // 创建新的bitmap对象 CBitmap bitmap; bitmap.CreateBitmap(width, height, 1, 32, NULL); // 创建DC对象 CDC memDC; memDC.CreateCompatibleDC(NULL); // 将bitmap对象选入DC CBitmap* pOldBitmap = memDC.SelectObject(&bitmap); // 绘制原始图像到DC image.BitBlt(memDC.GetSafeHdc(), 0, 0); // 创建新的bitmap对象,用于存储上抗锯齿算法后的图像 CBitmap antialiasedBitmap; antialiasedBitmap.CreateBitmap(width, height, 1, 32, NULL); // 将antialiasedBitmap对象选入DC CBitmap* pOldAntialiasedBitmap = memDC.SelectObject(&antialiasedBitmap); // 创建antialiasing DC对象 CDC antialiasDC; antialiasDC.CreateCompatibleDC(NULL); // 将antialiasedBitmap对象选入antialiasDC CBitmap* pOldAntialiasedBitmap2 = antialiasDC.SelectObject(&antialiasedBitmap); // 设置antialiasing DC对象的参数 antialiasDC.SetStretchBltMode(HALFTONE); antialiasDC.SetBrushOrg(0, 0); // 执行antialiasing算法,并将结果存储到antialiasedBitmap对象 antialiasDC.StretchBlt(0, 0, width, height, &memDC, 0, 0, width, height, SRCCOPY); // 释放DC对象 memDC.SelectObject(pOldBitmap); antialiasDC.SelectObject(pOldAntialiasedBitmap2); // 保存antialiasedBitmap对象为bmp文件 CImage antialiasedImage; antialiasedImage.Attach((HBITMAP)antialiasedBitmap.Detach()); antialiasedImage.Save(L"antialiased.bmp"); antialiasedImage.Detach(); ``` 上述代码,我们首先载了一个bmp图像数据,并获取了图像的宽度和高度。然后,我们创建了一个新的bitmap对象,并创建了一个DC对象,将bitmap对象选入DC,并将原始图像绘制到DC。接着,我们创建了一个新的bitmap对象,并用于存储上抗锯齿算法后的图像。我们将antialiasedBitmap对象选入DC,并创建了一个antialiasing DC对象,将antialiasedBitmap对象选入antialiasDC。然后,我们设置antialiasing DC对象的参数,执行antialiasing算法,并将结果存储到antialiasedBitmap对象。最后,我们保存antialiasedBitmap对象为bmp文件,释放DC对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值