<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 495,comments - 227,trackbacks - 0
    合并兩張jpg圖片為一張jpg圖片,思路是先把兩張圖片jpg圖片都轉(zhuǎn)化成bmp圖片,然后把兩張bmp圖片合并成一張bmp圖片,然后是把這張bmp圖片轉(zhuǎn)化為jpg圖片。

    一。jpg,bmp互相轉(zhuǎn)化
    /*********************************
    format:bmp轉(zhuǎn)為jpg, format為image/jpeg,jpg轉(zhuǎn)為bmp,format為image/bmp
    strDst為最終轉(zhuǎn)化結(jié)果的圖片路徑
    strSrc為原來圖片的路徑
    **********************************/
    BOOL ConvertPic(const WCHAR *format, const CString &strDst, const CString &strSrc)
    {
    BOOL bConvert = false;
    CLSID clsid;
    int nRet = 0;
    nRet = GetEncoderClsid(format,&clsid);  //得到CLSID
    USES_CONVERSION;
    if (nRet>=0)
    {
      Image image(A2W(strSrc));
      image.Save(A2W(strDst),&clsid,NULL);
      bConvert = true;
    }
    return bConvert;
    }
    其中GetEncoderClsid函數(shù)如下:
    /*****************************************************
    返回值為-1表示失敗,其他為成功
    ******************************************************/
    int GetEncoderClsid(const WCHAR *format, CLSID *pClsid)
    {
    int nRet = -1;
    ImageCodecInfo * pCodecInfo = NULL;
    UINT nNum = 0,nSize = 0;
    GetImageEncodersSize(&nNum,&nSize);
    if (nSize<0)
    {
      return nRet;
    }
    pCodecInfo = new ImageCodecInfo[nSize];
    if (pCodecInfo==NULL)
    {
      return nRet;
    }
    GetImageEncoders(nNum,nSize,pCodecInfo);
    for (UINT i=0; i<nNum; i++)
    {
      if (wcscmp(pCodecInfo[i].MimeType,format)==0)
      {
       *pClsid = pCodecInfo[i].Clsid;
       nRet = i;

       delete[] pCodecInfo;
       return nRet;
      }
      else
      {
       continue;
      }
    }
    delete[] pCodecInfo;
    return nRet;
    }
    bmp轉(zhuǎn)化為jpg
    ConvertPic(L"image/jpeg","c:""1.jpg","c:""1.bmp")
    jpg轉(zhuǎn)化為bmp
    ConvertPic(L"image/bmp","c:""1.bmp","c:""1.jpg")

    二。bmp圖片合并
    BOOL CombinePic(const WCHAR *format, const CString &strDst, const CString &strPic1, "
                   const CString &strPic2)
    {
    BOOL bCombine = false;
    int nRet = 0;
    CLSID clsid;
    nRet = GetEncoderClsid(format,&clsid);
    if (nRet>=0)
    {
      USES_CONVERSION;
      Bitmap bmp1(A2W(strPic1));
      Bitmap bmp2(A2W(strPic2));
      
      int nWidth = 0, nHeight = 0;
      nWidth = bmp1.GetWidth();   //假設(shè)兩圖片大小同
      nHeight = bmp1.GetHeight();
      Bitmap bmpCombine(2*nWidth,nHeight);  //高不變,寬*2,水平合并
      Graphics * pG = NULL;
      pG = Graphics::FromImage(&bmpCombine);
      if (pG!=NULL)
      {
       pG->DrawImage(&bmp1,0,0);
       pG->DrawImage(&bmp2,nWidth,0);

    // Create a string.
               WCHAR string[] = L"simone";
              
               // Initialize arguments.
               Font myFont(L"Arial", 16);
               PointF origin(50.0f, 5.0f);
               SolidBrush blackBrush(Color(255, 255, 0, 0));
               StringFormat format;
               format.SetAlignment(StringAlignmentCenter);
                // Draw string.
               pG->DrawString(
                   string,
                   6,
                   &myFont,
                   origin,
                   &format,
                   &blackBrush);

       bmpCombine.Save(A2W(strDst),&clsid,NULL);
      }
    }
    return bCombine;
    }
    例子:
    CombinePic(L"image/bmp","12.bmp","1.bmp","2.bmp");

    有了上面的功能,其他的就沒問題了
    posted on 2008-07-05 17:32 SIMONE 閱讀(616) 評論(0)  編輯  收藏 所屬分類: C++
    主站蜘蛛池模板: 青苹果乐园免费高清在线| 免费无码国产在线观国内自拍中文字幕| 99精品视频免费| 亚洲色大成网站WWW久久九九| 一个人免费播放在线视频看片| 亚洲国产精品综合久久网络| 免费无码国产在线观国内自拍中文字幕| 国产色爽免费视频| 美女视频黄视大全视频免费的| 免费成人黄色大片| 国产精品福利片免费看| 亚洲色欲色欲www在线丝 | 视频一区二区三区免费观看| 国产无遮挡裸体免费视频| 免费国产va视频永久在线观看| 精品亚洲视频在线观看| 毛片在线播放免费观看| 亚洲美女视频网站| 女性无套免费网站在线看| 特级无码毛片免费视频| 国产亚洲精品资源在线26u| 亚洲视频免费在线看| 亚洲色大成网站www久久九| 免费在线观看理论片| 男女作爱在线播放免费网站| 亚洲国产精品人久久| 最新中文字幕免费视频| 无套内射无矿码免费看黄| 久久综合九九亚洲一区| 久久电影网午夜鲁丝片免费| 一级成人a做片免费| 亚洲精品成人久久| 四虎免费永久在线播放| 无人在线观看免费高清| 亚洲欧洲无码一区二区三区| 国产亚洲欧洲Aⅴ综合一区 | 久久精品国产亚洲香蕉| 成年性羞羞视频免费观看无限 | 免费视频一区二区| 亚洲另类自拍丝袜第五页| 亚洲日本va中文字幕久久|